@shepai/cli 1.66.4 → 1.68.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/src/presentation/web/components/common/base-drawer/base-drawer.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/base-drawer/base-drawer.js +21 -1
- package/dist/src/presentation/web/components/common/base-drawer/base-drawer.stories.d.ts +15 -1
- package/dist/src/presentation/web/components/common/base-drawer/base-drawer.stories.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/base-drawer/base-drawer.stories.js +16 -2
- package/dist/src/presentation/web/components/common/control-center-drawer/control-center-drawer.d.ts +12 -0
- package/dist/src/presentation/web/components/common/control-center-drawer/control-center-drawer.d.ts.map +1 -0
- package/dist/src/presentation/web/components/common/control-center-drawer/control-center-drawer.js +284 -0
- package/dist/src/presentation/web/components/common/control-center-drawer/control-center-drawer.stories.d.ts +33 -0
- package/dist/src/presentation/web/components/common/control-center-drawer/control-center-drawer.stories.d.ts.map +1 -0
- package/dist/src/presentation/web/components/common/control-center-drawer/control-center-drawer.stories.js +210 -0
- package/dist/src/presentation/web/components/common/control-center-drawer/drawer-view.d.ts +56 -0
- package/dist/src/presentation/web/components/common/control-center-drawer/drawer-view.d.ts.map +1 -0
- package/dist/src/presentation/web/components/common/control-center-drawer/drawer-view.js +32 -0
- package/dist/src/presentation/web/components/common/control-center-drawer/index.d.ts +3 -0
- package/dist/src/presentation/web/components/common/control-center-drawer/index.d.ts.map +1 -0
- package/dist/src/presentation/web/components/common/control-center-drawer/index.js +2 -0
- package/dist/src/presentation/web/components/common/drawer-action-bar/drawer-action-bar-config.d.ts +0 -4
- package/dist/src/presentation/web/components/common/drawer-action-bar/drawer-action-bar-config.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/drawer-action-bar/drawer-action-bar.d.ts +1 -1
- package/dist/src/presentation/web/components/common/drawer-action-bar/drawer-action-bar.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/drawer-action-bar/drawer-action-bar.js +18 -12
- package/dist/src/presentation/web/components/common/drawer-action-bar/drawer-action-bar.stories.d.ts +4 -6
- package/dist/src/presentation/web/components/common/drawer-action-bar/drawer-action-bar.stories.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/drawer-action-bar/drawer-action-bar.stories.js +5 -13
- package/dist/src/presentation/web/components/common/feature-create-drawer/feature-create-drawer.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/feature-create-drawer/feature-create-drawer.js +2 -13
- package/dist/src/presentation/web/components/common/feature-create-drawer/feature-create-drawer.stories.d.ts +2 -10
- package/dist/src/presentation/web/components/common/feature-create-drawer/feature-create-drawer.stories.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/feature-create-drawer/feature-create-drawer.stories.js +21 -1
- package/dist/src/presentation/web/components/common/feature-create-drawer/index.d.ts +1 -1
- package/dist/src/presentation/web/components/common/feature-create-drawer/index.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/feature-drawer/feature-drawer.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/feature-drawer/feature-drawer.js +14 -20
- package/dist/src/presentation/web/components/common/feature-drawer/feature-drawer.stories.d.ts +7 -1
- package/dist/src/presentation/web/components/common/feature-drawer/feature-drawer.stories.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/feature-drawer/feature-drawer.stories.js +37 -2
- package/dist/src/presentation/web/components/common/feature-node/feature-node-state-config.d.ts +1 -0
- package/dist/src/presentation/web/components/common/feature-node/feature-node-state-config.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/feature-node/feature-node.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/feature-node/feature-node.js +9 -2
- package/dist/src/presentation/web/components/common/feature-node/feature-node.stories.d.ts +1 -0
- package/dist/src/presentation/web/components/common/feature-node/feature-node.stories.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/feature-node/feature-node.stories.js +13 -1
- package/dist/src/presentation/web/components/common/index.d.ts +1 -0
- package/dist/src/presentation/web/components/common/index.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/index.js +1 -0
- package/dist/src/presentation/web/components/common/merge-review/merge-review.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/merge-review/merge-review.js +2 -2
- package/dist/src/presentation/web/components/common/merge-review/merge-review.stories.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/merge-review/merge-review.stories.js +1 -2
- package/dist/src/presentation/web/components/common/prd-questionnaire/prd-questionnaire.js +1 -1
- package/dist/src/presentation/web/components/common/prd-questionnaire/prd-questionnaire.stories.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/prd-questionnaire/prd-questionnaire.stories.js +1 -2
- package/dist/src/presentation/web/components/common/repository-node/repository-drawer.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/repository-node/repository-drawer.js +5 -1
- package/dist/src/presentation/web/components/common/repository-node/repository-drawer.stories.d.ts +2 -0
- package/dist/src/presentation/web/components/common/repository-node/repository-drawer.stories.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/repository-node/repository-drawer.stories.js +13 -2
- package/dist/src/presentation/web/components/common/review-drawer-shell/review-drawer-shell.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/review-drawer-shell/review-drawer-shell.js +5 -2
- package/dist/src/presentation/web/components/common/review-drawer-shell/review-drawer-shell.stories.js +1 -1
- package/dist/src/presentation/web/components/common/tech-decisions-review/tech-decisions-review.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/tech-decisions-review/tech-decisions-review.js +1 -1
- package/dist/src/presentation/web/components/common/tech-decisions-review/tech-decisions-review.stories.d.ts.map +1 -1
- package/dist/src/presentation/web/components/common/tech-decisions-review/tech-decisions-review.stories.js +1 -2
- package/dist/src/presentation/web/components/features/control-center/control-center-inner.d.ts.map +1 -1
- package/dist/src/presentation/web/components/features/control-center/control-center-inner.js +20 -215
- package/dist/src/presentation/web/components/features/control-center/use-control-center-state.d.ts.map +1 -1
- package/dist/src/presentation/web/components/features/control-center/use-control-center-state.js +2 -1
- package/dist/src/presentation/web/components/features/features-canvas/features-canvas.d.ts +2 -1
- package/dist/src/presentation/web/components/features/features-canvas/features-canvas.d.ts.map +1 -1
- package/dist/src/presentation/web/components/features/features-canvas/features-canvas.js +4 -2
- package/dist/tsconfig.build.tsbuildinfo +1 -1
- package/package.json +2 -2
- package/web/.next/BUILD_ID +1 -1
- package/web/.next/build-manifest.json +5 -5
- package/web/.next/cache/.previewinfo +1 -1
- package/web/.next/cache/.rscinfo +1 -1
- package/web/.next/cache/.tsbuildinfo +1 -1
- package/web/.next/cache/config.json +3 -3
- package/web/.next/fallback-build-manifest.json +2 -2
- package/web/.next/prerender-manifest.json +3 -3
- package/web/.next/required-server-files.js +1 -1
- package/web/.next/required-server-files.json +1 -1
- package/web/.next/server/app/_global-error/page/build-manifest.json +3 -3
- package/web/.next/server/app/_global-error.html +2 -2
- package/web/.next/server/app/_global-error.rsc +1 -1
- package/web/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +1 -1
- package/web/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
- package/web/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
- package/web/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
- package/web/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
- package/web/.next/server/app/_not-found/page/build-manifest.json +3 -3
- package/web/.next/server/app/_not-found/page/server-reference-manifest.json +1 -1
- package/web/.next/server/app/_not-found/page.js.nft.json +1 -1
- package/web/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/page/build-manifest.json +3 -3
- package/web/.next/server/app/page/server-reference-manifest.json +88 -88
- package/web/.next/server/app/page.js +1 -1
- package/web/.next/server/app/page.js.nft.json +1 -1
- package/web/.next/server/app/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/skills/page/build-manifest.json +3 -3
- package/web/.next/server/app/skills/page/server-reference-manifest.json +5 -5
- package/web/.next/server/app/skills/page.js.nft.json +1 -1
- package/web/.next/server/app/skills/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/tools/page/build-manifest.json +3 -3
- package/web/.next/server/app/tools/page/server-reference-manifest.json +1 -1
- package/web/.next/server/app/tools/page.js.nft.json +1 -1
- package/web/.next/server/app/tools/page_client-reference-manifest.js +1 -1
- package/web/.next/server/app/version/page/build-manifest.json +3 -3
- package/web/.next/server/app/version/page/server-reference-manifest.json +1 -1
- package/web/.next/server/app/version/page.js.nft.json +1 -1
- package/web/.next/server/app/version/page_client-reference-manifest.js +1 -1
- package/web/.next/server/chunks/ssr/403f9_next_dist_a53cb908._.js +3 -0
- package/web/.next/server/chunks/ssr/403f9_next_dist_a53cb908._.js.map +1 -0
- package/web/.next/server/chunks/ssr/[root-of-the-server]__08ba9bd3._.js +1 -1
- package/web/.next/server/chunks/ssr/[root-of-the-server]__08ba9bd3._.js.map +1 -1
- package/web/.next/server/chunks/ssr/[root-of-the-server]__249c74f6._.js +1 -1
- package/web/.next/server/chunks/ssr/{[root-of-the-server]__f5830fa9._.js → [root-of-the-server]__2ffb27f1._.js} +2 -2
- package/web/.next/server/chunks/ssr/{[root-of-the-server]__f5830fa9._.js.map → [root-of-the-server]__2ffb27f1._.js.map} +1 -1
- package/web/.next/server/chunks/ssr/[root-of-the-server]__551fb7e1._.js +1 -1
- package/web/.next/server/chunks/ssr/[root-of-the-server]__551fb7e1._.js.map +1 -1
- package/web/.next/server/chunks/ssr/[root-of-the-server]__6b17a22d._.js +1 -1
- package/web/.next/server/chunks/ssr/[root-of-the-server]__6b17a22d._.js.map +1 -1
- package/web/.next/server/chunks/ssr/[root-of-the-server]__7f4180a1._.js +3 -0
- package/web/.next/server/chunks/ssr/[root-of-the-server]__7f4180a1._.js.map +1 -0
- package/web/.next/server/chunks/ssr/[root-of-the-server]__804c006d._.js +1 -1
- package/web/.next/server/chunks/ssr/[root-of-the-server]__804c006d._.js.map +1 -1
- package/web/.next/server/chunks/ssr/[root-of-the-server]__9add7c3a._.js +4 -4
- package/web/.next/server/chunks/ssr/[root-of-the-server]__9add7c3a._.js.map +1 -1
- package/web/.next/server/chunks/ssr/[root-of-the-server]__e41b5eec._.js +9 -0
- package/web/.next/server/chunks/ssr/{[root-of-the-server]__f648005b._.js.map → [root-of-the-server]__e41b5eec._.js.map} +1 -1
- package/web/.next/server/chunks/ssr/[root-of-the-server]__eaf6100f._.js +3 -0
- package/web/.next/server/chunks/ssr/[root-of-the-server]__eaf6100f._.js.map +1 -0
- package/web/.next/server/chunks/ssr/_23c92688._.js +6 -0
- package/web/.next/server/chunks/ssr/_23c92688._.js.map +1 -0
- package/web/.next/server/chunks/ssr/_28993370._.js +1 -1
- package/web/.next/server/chunks/ssr/_28993370._.js.map +1 -1
- package/web/.next/server/chunks/ssr/_49bf495c._.js +3 -0
- package/web/.next/server/chunks/ssr/_49bf495c._.js.map +1 -0
- package/web/.next/server/chunks/ssr/_690ea95f._.js +3 -0
- package/web/.next/server/chunks/ssr/{_2900ed94._.js.map → _690ea95f._.js.map} +1 -1
- package/web/.next/{standalone/src/presentation/web/.next/server/chunks/ssr/_c52cace8._.js → server/chunks/ssr/_725584e5._.js} +2 -2
- package/web/.next/server/chunks/ssr/_725584e5._.js.map +1 -0
- package/web/.next/server/chunks/ssr/src_presentation_web_components_e599bb8c._.js +1 -1
- package/web/.next/server/chunks/ssr/src_presentation_web_components_e599bb8c._.js.map +1 -1
- package/web/.next/server/middleware-build-manifest.js +3 -3
- package/web/.next/server/pages/500.html +2 -2
- package/web/.next/server/server-reference-manifest.js +1 -1
- package/web/.next/server/server-reference-manifest.json +115 -115
- package/web/.next/standalone/src/presentation/web/.next/BUILD_ID +1 -1
- package/web/.next/standalone/src/presentation/web/.next/build-manifest.json +5 -5
- package/web/.next/standalone/src/presentation/web/.next/prerender-manifest.json +3 -3
- package/web/.next/standalone/src/presentation/web/.next/required-server-files.json +1 -1
- package/web/.next/standalone/src/presentation/web/.next/server/app/_global-error/page/build-manifest.json +3 -3
- package/web/.next/standalone/src/presentation/web/.next/server/app/_global-error.html +2 -2
- package/web/.next/standalone/src/presentation/web/.next/server/app/_global-error.rsc +1 -1
- package/web/.next/standalone/src/presentation/web/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +1 -1
- package/web/.next/standalone/src/presentation/web/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
- package/web/.next/standalone/src/presentation/web/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
- package/web/.next/standalone/src/presentation/web/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
- package/web/.next/standalone/src/presentation/web/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
- package/web/.next/standalone/src/presentation/web/.next/server/app/_not-found/page/build-manifest.json +3 -3
- package/web/.next/standalone/src/presentation/web/.next/server/app/_not-found/page/server-reference-manifest.json +1 -1
- package/web/.next/standalone/src/presentation/web/.next/server/app/_not-found/page.js.nft.json +1 -1
- package/web/.next/standalone/src/presentation/web/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
- package/web/.next/standalone/src/presentation/web/.next/server/app/page/build-manifest.json +3 -3
- package/web/.next/standalone/src/presentation/web/.next/server/app/page/server-reference-manifest.json +88 -88
- package/web/.next/standalone/src/presentation/web/.next/server/app/page.js +1 -1
- package/web/.next/standalone/src/presentation/web/.next/server/app/page.js.nft.json +1 -1
- package/web/.next/standalone/src/presentation/web/.next/server/app/page_client-reference-manifest.js +1 -1
- package/web/.next/standalone/src/presentation/web/.next/server/app/skills/page/build-manifest.json +3 -3
- package/web/.next/standalone/src/presentation/web/.next/server/app/skills/page/server-reference-manifest.json +5 -5
- package/web/.next/standalone/src/presentation/web/.next/server/app/skills/page.js.nft.json +1 -1
- package/web/.next/standalone/src/presentation/web/.next/server/app/skills/page_client-reference-manifest.js +1 -1
- package/web/.next/standalone/src/presentation/web/.next/server/app/tools/page/build-manifest.json +3 -3
- package/web/.next/standalone/src/presentation/web/.next/server/app/tools/page/server-reference-manifest.json +1 -1
- package/web/.next/standalone/src/presentation/web/.next/server/app/tools/page.js.nft.json +1 -1
- package/web/.next/standalone/src/presentation/web/.next/server/app/tools/page_client-reference-manifest.js +1 -1
- package/web/.next/standalone/src/presentation/web/.next/server/app/version/page/build-manifest.json +3 -3
- package/web/.next/standalone/src/presentation/web/.next/server/app/version/page/server-reference-manifest.json +1 -1
- package/web/.next/standalone/src/presentation/web/.next/server/app/version/page.js.nft.json +1 -1
- package/web/.next/standalone/src/presentation/web/.next/server/app/version/page_client-reference-manifest.js +1 -1
- package/web/.next/standalone/src/presentation/web/.next/server/chunks/ssr/403f9_next_dist_a53cb908._.js +3 -0
- package/web/.next/standalone/src/presentation/web/.next/server/chunks/ssr/[root-of-the-server]__08ba9bd3._.js +1 -1
- package/web/.next/standalone/src/presentation/web/.next/server/chunks/ssr/[root-of-the-server]__249c74f6._.js +1 -1
- package/web/.next/standalone/src/presentation/web/.next/server/chunks/ssr/{[root-of-the-server]__f5830fa9._.js → [root-of-the-server]__2ffb27f1._.js} +2 -2
- package/web/.next/standalone/src/presentation/web/.next/server/chunks/ssr/[root-of-the-server]__551fb7e1._.js +1 -1
- package/web/.next/standalone/src/presentation/web/.next/server/chunks/ssr/[root-of-the-server]__6b17a22d._.js +1 -1
- package/web/.next/standalone/src/presentation/web/.next/server/chunks/ssr/[root-of-the-server]__7f4180a1._.js +3 -0
- package/web/.next/standalone/src/presentation/web/.next/server/chunks/ssr/[root-of-the-server]__804c006d._.js +1 -1
- package/web/.next/standalone/src/presentation/web/.next/server/chunks/ssr/[root-of-the-server]__9add7c3a._.js +4 -4
- package/web/.next/standalone/src/presentation/web/.next/server/chunks/ssr/[root-of-the-server]__e41b5eec._.js +9 -0
- package/web/.next/standalone/src/presentation/web/.next/server/chunks/ssr/[root-of-the-server]__eaf6100f._.js +3 -0
- package/web/.next/standalone/src/presentation/web/.next/server/chunks/ssr/_23c92688._.js +6 -0
- package/web/.next/standalone/src/presentation/web/.next/server/chunks/ssr/_28993370._.js +1 -1
- package/web/.next/standalone/src/presentation/web/.next/server/chunks/ssr/_49bf495c._.js +3 -0
- package/web/.next/standalone/src/presentation/web/.next/server/chunks/ssr/_690ea95f._.js +3 -0
- package/web/.next/{server/chunks/ssr/_c52cace8._.js → standalone/src/presentation/web/.next/server/chunks/ssr/_725584e5._.js} +2 -2
- package/web/.next/standalone/src/presentation/web/.next/server/chunks/ssr/src_presentation_web_components_e599bb8c._.js +1 -1
- package/web/.next/standalone/src/presentation/web/.next/server/middleware-build-manifest.js +3 -3
- package/web/.next/standalone/src/presentation/web/.next/server/pages/500.html +2 -2
- package/web/.next/standalone/src/presentation/web/.next/server/server-reference-manifest.js +1 -1
- package/web/.next/standalone/src/presentation/web/.next/server/server-reference-manifest.json +115 -115
- package/web/.next/standalone/src/presentation/web/components/common/base-drawer/base-drawer.stories.tsx +16 -2
- package/web/.next/standalone/src/presentation/web/components/common/base-drawer/base-drawer.tsx +35 -6
- package/web/.next/standalone/src/presentation/web/components/common/control-center-drawer/control-center-drawer.stories.tsx +285 -0
- package/web/.next/standalone/src/presentation/web/components/common/control-center-drawer/control-center-drawer.tsx +650 -0
- package/web/.next/standalone/src/presentation/web/components/common/control-center-drawer/drawer-view.ts +82 -0
- package/web/.next/standalone/src/presentation/web/components/common/control-center-drawer/index.ts +2 -0
- package/web/.next/standalone/src/presentation/web/components/common/drawer-action-bar/drawer-action-bar-config.ts +0 -4
- package/web/.next/standalone/src/presentation/web/components/common/drawer-action-bar/drawer-action-bar.stories.tsx +5 -14
- package/web/.next/standalone/src/presentation/web/components/common/drawer-action-bar/drawer-action-bar.tsx +58 -51
- package/web/.next/standalone/src/presentation/web/components/common/feature-create-drawer/feature-create-drawer.stories.tsx +42 -1
- package/web/.next/standalone/src/presentation/web/components/common/feature-create-drawer/feature-create-drawer.tsx +2 -16
- package/web/.next/standalone/src/presentation/web/components/common/feature-create-drawer/index.ts +1 -0
- package/web/.next/standalone/src/presentation/web/components/common/feature-drawer/feature-drawer.stories.tsx +55 -2
- package/web/.next/standalone/src/presentation/web/components/common/feature-drawer/feature-drawer.tsx +97 -106
- package/web/.next/standalone/src/presentation/web/components/common/feature-node/feature-node-state-config.ts +1 -0
- package/web/.next/standalone/src/presentation/web/components/common/feature-node/feature-node.stories.tsx +14 -1
- package/web/.next/standalone/src/presentation/web/components/common/feature-node/feature-node.tsx +61 -1
- package/web/.next/standalone/src/presentation/web/components/common/index.ts +6 -0
- package/web/.next/standalone/src/presentation/web/components/common/merge-review/merge-review.stories.tsx +1 -2
- package/web/.next/standalone/src/presentation/web/components/common/merge-review/merge-review.tsx +1 -2
- package/web/.next/standalone/src/presentation/web/components/common/prd-questionnaire/prd-questionnaire.stories.tsx +1 -2
- package/web/.next/standalone/src/presentation/web/components/common/prd-questionnaire/prd-questionnaire.tsx +1 -1
- package/web/.next/standalone/src/presentation/web/components/common/repository-node/repository-drawer.stories.tsx +28 -2
- package/web/.next/standalone/src/presentation/web/components/common/repository-node/repository-drawer.tsx +7 -2
- package/web/.next/standalone/src/presentation/web/components/common/review-drawer-shell/review-drawer-shell.stories.tsx +1 -1
- package/web/.next/standalone/src/presentation/web/components/common/review-drawer-shell/review-drawer-shell.tsx +7 -6
- package/web/.next/standalone/src/presentation/web/components/common/tech-decisions-review/tech-decisions-review.stories.tsx +1 -2
- package/web/.next/standalone/src/presentation/web/components/common/tech-decisions-review/tech-decisions-review.tsx +1 -2
- package/web/.next/standalone/src/presentation/web/components/features/control-center/control-center-inner.tsx +31 -348
- package/web/.next/standalone/src/presentation/web/components/features/control-center/use-control-center-state.ts +2 -1
- package/web/.next/standalone/src/presentation/web/components/features/features-canvas/features-canvas.tsx +9 -1
- package/web/.next/standalone/src/presentation/web/server.js +1 -1
- package/web/.next/static/chunks/0751efba75563e6a.js +1 -0
- package/web/.next/static/chunks/33b4e5444019ab64.js +1 -0
- package/web/.next/static/chunks/{35f41ba0a6d626d7.js → 491ae2bbae40857c.js} +1 -1
- package/web/.next/static/chunks/49feba0d1a871e2b.js +10 -0
- package/web/.next/static/chunks/4b6cc9f65260f2bd.js +2 -0
- package/web/.next/static/chunks/{e0073669b6bc24df.js → 7f6db87dc1fe9c3b.js} +1 -1
- package/web/.next/static/chunks/a186bbb822ccb655.css +2 -0
- package/web/.next/static/chunks/a5c59952485e875e.js +1 -0
- package/web/.next/static/chunks/{8c60d1bd87239066.js → a9626385607910b3.js} +1 -1
- package/web/.next/static/chunks/c1c15470a7b058c8.js +1 -0
- package/web/.next/static/chunks/caa2e7e1618e2179.js +1 -0
- package/web/.next/static/chunks/fb703cf73aba2eb8.js +1 -0
- package/web/.next/static/chunks/{turbopack-b6b5b4f015327a9a.js → turbopack-958ac34b879d0dce.js} +1 -1
- package/web/.next/trace +1 -1
- package/web/.next/trace-build +1 -1
- package/web/.next/server/chunks/ssr/403f9_next_dist_623b646a._.js +0 -3
- package/web/.next/server/chunks/ssr/403f9_next_dist_623b646a._.js.map +0 -1
- package/web/.next/server/chunks/ssr/[root-of-the-server]__6bb51fac._.js +0 -3
- package/web/.next/server/chunks/ssr/[root-of-the-server]__6bb51fac._.js.map +0 -1
- package/web/.next/server/chunks/ssr/[root-of-the-server]__c1f0f2a8._.js +0 -3
- package/web/.next/server/chunks/ssr/[root-of-the-server]__c1f0f2a8._.js.map +0 -1
- package/web/.next/server/chunks/ssr/[root-of-the-server]__f648005b._.js +0 -9
- package/web/.next/server/chunks/ssr/_2900ed94._.js +0 -3
- package/web/.next/server/chunks/ssr/_6978d868._.js +0 -3
- package/web/.next/server/chunks/ssr/_6978d868._.js.map +0 -1
- package/web/.next/server/chunks/ssr/_85965278._.js +0 -6
- package/web/.next/server/chunks/ssr/_85965278._.js.map +0 -1
- package/web/.next/server/chunks/ssr/_c52cace8._.js.map +0 -1
- package/web/.next/standalone/src/presentation/web/.next/server/chunks/ssr/403f9_next_dist_623b646a._.js +0 -3
- package/web/.next/standalone/src/presentation/web/.next/server/chunks/ssr/[root-of-the-server]__6bb51fac._.js +0 -3
- package/web/.next/standalone/src/presentation/web/.next/server/chunks/ssr/[root-of-the-server]__c1f0f2a8._.js +0 -3
- package/web/.next/standalone/src/presentation/web/.next/server/chunks/ssr/[root-of-the-server]__f648005b._.js +0 -9
- package/web/.next/standalone/src/presentation/web/.next/server/chunks/ssr/_2900ed94._.js +0 -3
- package/web/.next/standalone/src/presentation/web/.next/server/chunks/ssr/_6978d868._.js +0 -3
- package/web/.next/standalone/src/presentation/web/.next/server/chunks/ssr/_85965278._.js +0 -6
- package/web/.next/static/chunks/41a2adc09edfffaf.js +0 -1
- package/web/.next/static/chunks/5054c72b1c8f5912.js +0 -1
- package/web/.next/static/chunks/5f6d9f4647fc3093.js +0 -10
- package/web/.next/static/chunks/96f49affaceab206.css +0 -2
- package/web/.next/static/chunks/a6d1d774260fc927.js +0 -2
- package/web/.next/static/chunks/c0fdd832fc4ee8eb.js +0 -1
- package/web/.next/static/chunks/de70ba984363673f.js +0 -1
- package/web/.next/static/chunks/f5fb2f182ae9b015.js +0 -1
- /package/web/.next/static/{XGbKxw26cOCJQ-711YxBw → ntu60tngTU2e9MZgpdlz0}/_buildManifest.js +0 -0
- /package/web/.next/static/{XGbKxw26cOCJQ-711YxBw → ntu60tngTU2e9MZgpdlz0}/_clientMiddlewareManifest.json +0 -0
- /package/web/.next/static/{XGbKxw26cOCJQ-711YxBw → ntu60tngTU2e9MZgpdlz0}/_ssgManifest.js +0 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tech-decisions-review.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/common/tech-decisions-review/tech-decisions-review.tsx"],"names":[],"mappings":"AASA,OAAO,KAAK,EAAE,wBAAwB,EAAgB,MAAM,gCAAgC,CAAC;AAgH7F,wBAAgB,mBAAmB,CAAC,EAClC,IAAI,EACJ,SAAS,EACT,QAAQ,EACR,YAAoB,EACpB,WAAmB,GACpB,EAAE,wBAAwB,
|
|
1
|
+
{"version":3,"file":"tech-decisions-review.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/common/tech-decisions-review/tech-decisions-review.tsx"],"names":[],"mappings":"AASA,OAAO,KAAK,EAAE,wBAAwB,EAAgB,MAAM,gCAAgC,CAAC;AAgH7F,wBAAgB,mBAAmB,CAAC,EAClC,IAAI,EACJ,SAAS,EACT,QAAQ,EACR,YAAoB,EACpB,WAAmB,GACpB,EAAE,wBAAwB,kDA4C1B"}
|
package/dist/src/presentation/web/components/common/tech-decisions-review/tech-decisions-review.js
CHANGED
|
@@ -38,5 +38,5 @@ export function TechDecisionsReview({ data, onApprove, onReject, isProcessing =
|
|
|
38
38
|
const { summary, decisions } = data;
|
|
39
39
|
if (decisions.length === 0)
|
|
40
40
|
return null;
|
|
41
|
-
return (_jsxs("div", { className: "flex
|
|
41
|
+
return (_jsxs("div", { className: "flex flex-1 flex-col", children: [_jsxs("div", { className: "flex-1 space-y-4 overflow-y-auto p-4", children: [_jsxs("div", { className: "flex items-start gap-3", children: [_jsx("div", { className: "mt-1.5 h-2.5 w-2.5 shrink-0 rounded-full bg-blue-500" }), _jsxs("div", { className: "flex-1", children: [_jsx("h2", { className: "text-foreground text-sm font-bold", children: "Technical Implementation Plan Review" }), summary ? (_jsx("p", { className: "text-muted-foreground mt-1 text-xs leading-relaxed", children: summary })) : null] })] }), _jsxs("div", { className: "flex items-center gap-2 pt-1", children: [_jsx(GitCompareArrows, { className: "text-primary h-4 w-4" }), _jsx("h3", { className: "text-foreground text-sm font-bold", children: "Technical Decisions" })] }), decisions.map((decision, i) => (_jsx(DecisionCard, { decision: decision, index: i }, decision.title)))] }), _jsx(DrawerActionBar, { onReject: onReject, onApprove: onApprove, approveLabel: "Approve Plan", approveIcon: _jsx(Check, { className: "mr-1.5 h-4 w-4" }), revisionPlaceholder: "Ask AI to revise the plan...", isProcessing: isProcessing, isRejecting: isRejecting })] }));
|
|
42
42
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tech-decisions-review.stories.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/common/tech-decisions-review/tech-decisions-review.stories.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAEvD,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAC9D,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AA0C9D,QAAA,MAAM,IAAI,EAAE,IAAI,CAAC,OAAO,mBAAmB,CAc1C,CAAC;AAEF,eAAe,IAAI,CAAC;AACpB,KAAK,KAAK,GAAG,QAAQ,CAAC,OAAO,mBAAmB,CAAC,CAAC;AAElD,oHAAoH;AACpH,eAAO,MAAM,OAAO,EAAE,KAMrB,CAAC;AAEF,kDAAkD;AAClD,eAAO,MAAM,UAAU,EAAE,KAMxB,CAAC;AAEF,uBAAuB;AACvB,eAAO,MAAM,cAAc,EAAE,KAM5B,CAAC;AAEF,8BAA8B;AAC9B,eAAO,MAAM,cAAc,EAAE,KAM5B,CAAC;AAIF,KAAK,WAAW,GAAG,QAAQ,CAAC,OAAO,mBAAmB,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"tech-decisions-review.stories.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/common/tech-decisions-review/tech-decisions-review.stories.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAEvD,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAC9D,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AA0C9D,QAAA,MAAM,IAAI,EAAE,IAAI,CAAC,OAAO,mBAAmB,CAc1C,CAAC;AAEF,eAAe,IAAI,CAAC;AACpB,KAAK,KAAK,GAAG,QAAQ,CAAC,OAAO,mBAAmB,CAAC,CAAC;AAElD,oHAAoH;AACpH,eAAO,MAAM,OAAO,EAAE,KAMrB,CAAC;AAEF,kDAAkD;AAClD,eAAO,MAAM,UAAU,EAAE,KAMxB,CAAC;AAEF,uBAAuB;AACvB,eAAO,MAAM,cAAc,EAAE,KAM5B,CAAC;AAEF,8BAA8B;AAC9B,eAAO,MAAM,cAAc,EAAE,KAM5B,CAAC;AAIF,KAAK,WAAW,GAAG,QAAQ,CAAC,OAAO,mBAAmB,CAAC,CAAC;AA6BxD,uCAAuC;AACvC,eAAO,MAAM,QAAQ,EAAE,WAWtB,CAAC;AAEF,yCAAyC;AACzC,eAAO,MAAM,gBAAgB,EAAE,WAY9B,CAAC;AAEF,wDAAwD;AACxD,eAAO,MAAM,aAAa,EAAE,WAa3B,CAAC;AAIF,kDAAkD;AAClD,eAAO,MAAM,gBAAgB,EAAE,KAM9B,CAAC;AAEF,iFAAiF;AACjF,eAAO,MAAM,cAAc,EAAE,KAO5B,CAAC"}
|
|
@@ -36,7 +36,7 @@ const mockData = {
|
|
|
36
36
|
};
|
|
37
37
|
/* ─── Standalone TechDecisionsReview ─── */
|
|
38
38
|
const meta = {
|
|
39
|
-
title: '
|
|
39
|
+
title: 'Drawers/Review/TechDecisionsReview',
|
|
40
40
|
component: TechDecisionsReview,
|
|
41
41
|
tags: ['autodocs'],
|
|
42
42
|
parameters: {
|
|
@@ -80,7 +80,6 @@ export const NoTechnologies = {
|
|
|
80
80
|
},
|
|
81
81
|
};
|
|
82
82
|
const drawerMeta = {
|
|
83
|
-
title: 'Composed/TechDecisionsDrawer',
|
|
84
83
|
component: TechDecisionsDrawer,
|
|
85
84
|
tags: ['autodocs'],
|
|
86
85
|
parameters: {
|
package/dist/src/presentation/web/components/features/control-center/control-center-inner.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"control-center-inner.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/features/control-center/control-center-inner.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;
|
|
1
|
+
{"version":3,"file":"control-center-inner.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/features/control-center/control-center-inner.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAE1C,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAC;AAU5E,UAAU,uBAAuB;IAC/B,YAAY,EAAE,cAAc,EAAE,CAAC;IAC/B,YAAY,EAAE,IAAI,EAAE,CAAC;CACtB;AAED,wBAAgB,kBAAkB,CAAC,EAAE,YAAY,EAAE,YAAY,EAAE,EAAE,uBAAuB,2CAyJzF"}
|
package/dist/src/presentation/web/components/features/control-center/control-center-inner.js
CHANGED
|
@@ -1,59 +1,34 @@
|
|
|
1
1
|
'use client';
|
|
2
2
|
import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
3
|
import { useCallback, useEffect, useMemo, useState } from 'react';
|
|
4
|
-
import { toast } from 'sonner';
|
|
5
|
-
import { approveFeature } from '../../../app/actions/approve-feature.js';
|
|
6
|
-
import { rejectFeature } from '../../../app/actions/reject-feature.js';
|
|
7
|
-
import { getFeatureArtifact } from '../../../app/actions/get-feature-artifact.js';
|
|
8
|
-
import { getResearchArtifact } from '../../../app/actions/get-research-artifact.js';
|
|
9
|
-
import { getWorkflowDefaults } from '../../../app/actions/get-workflow-defaults.js';
|
|
10
|
-
import { getMergeReviewData } from '../../../app/actions/get-merge-review-data.js';
|
|
11
4
|
import { FeaturesCanvas } from '../../features/features-canvas/index.js';
|
|
12
|
-
import {
|
|
13
|
-
import { RepositoryDrawer } from '../../common/repository-node/index.js';
|
|
14
|
-
import { PrdQuestionnaireDrawer } from '../../common/prd-questionnaire/index.js';
|
|
15
|
-
import { TechDecisionsDrawer } from '../../common/tech-decisions-review/index.js';
|
|
16
|
-
import { MergeReviewDrawer } from '../../common/merge-review/index.js';
|
|
5
|
+
import { ControlCenterDrawer, computeDrawerView } from '../../common/control-center-drawer/index.js';
|
|
17
6
|
import { NotificationPermissionBanner } from '../../common/notification-permission-banner/index.js';
|
|
18
|
-
import {
|
|
7
|
+
import { getWorkflowDefaults } from '../../../app/actions/get-workflow-defaults.js';
|
|
19
8
|
import { ControlCenterEmptyState } from './control-center-empty-state.js';
|
|
20
9
|
import { useControlCenterState } from './use-control-center-state.js';
|
|
21
10
|
export function ControlCenterInner({ initialNodes, initialEdges }) {
|
|
22
11
|
const { nodes, edges, selectedNode, isCreateDrawerOpen, isDeleting, pendingRepositoryPath, onNodesChange, handleConnect, handleAddFeature, handleAddFeatureToRepo, handleAddFeatureToFeature, handleAddRepository, handleNodeClick, clearSelection, handleCreateFeatureSubmit, handleDeleteFeature, handleDeleteRepository, closeCreateDrawer, selectFeatureById, pendingParentFeatureId, } = useControlCenterState(initialNodes, initialEdges);
|
|
23
|
-
//
|
|
12
|
+
// Feature list for the parent selector in the create drawer
|
|
24
13
|
const featureOptions = useMemo(() => nodes
|
|
25
14
|
.filter((n) => n.type === 'featureNode')
|
|
26
15
|
.map((n) => {
|
|
27
16
|
const data = n.data;
|
|
28
17
|
return { id: data.featureId, name: data.name };
|
|
29
18
|
})
|
|
30
|
-
.filter((f) => f.id && !f.id.startsWith('#')),
|
|
31
|
-
[nodes]);
|
|
19
|
+
.filter((f) => f.id && !f.id.startsWith('#')), [nodes]);
|
|
32
20
|
// Workflow defaults for the create-feature drawer
|
|
33
21
|
const [workflowDefaults, setWorkflowDefaults] = useState();
|
|
34
22
|
useEffect(() => {
|
|
35
23
|
getWorkflowDefaults()
|
|
36
24
|
.then(setWorkflowDefaults)
|
|
37
25
|
.catch(() => {
|
|
38
|
-
// Settings unavailable — drawer falls back to all-false defaults
|
|
26
|
+
// Settings unavailable — create drawer falls back to all-false defaults
|
|
39
27
|
});
|
|
40
28
|
}, []);
|
|
41
|
-
//
|
|
42
|
-
const [prdSelections, setPrdSelections] = useState({});
|
|
43
|
-
const [questionnaireData, setQuestionnaireData] = useState(null);
|
|
44
|
-
const [isLoadingQuestionnaire, setIsLoadingQuestionnaire] = useState(false);
|
|
45
|
-
// Reject state (shared by both drawers)
|
|
46
|
-
const [isRejecting, setIsRejecting] = useState(false);
|
|
47
|
-
const rejectSound = useSoundAction('reject');
|
|
48
|
-
// Tech decisions drawer state
|
|
49
|
-
const [techDecisionsData, setTechDecisionsData] = useState(null);
|
|
50
|
-
const [isLoadingTechDecisions, setIsLoadingTechDecisions] = useState(false);
|
|
51
|
-
// Merge review drawer state
|
|
52
|
-
const [mergeReviewData, setMergeReviewData] = useState(null);
|
|
53
|
-
const [isLoadingMergeReview, setIsLoadingMergeReview] = useState(false);
|
|
54
|
-
// Repository drawer state
|
|
29
|
+
// Repository drawer state (independent of feature selection)
|
|
55
30
|
const [selectedRepoNode, setSelectedRepoNode] = useState(null);
|
|
56
|
-
//
|
|
31
|
+
// Close all drawers — used on pane click and canvas drag
|
|
57
32
|
const handleClearDrawers = useCallback(() => {
|
|
58
33
|
clearSelection();
|
|
59
34
|
setSelectedRepoNode(null);
|
|
@@ -67,187 +42,16 @@ export function ControlCenterInner({ initialNodes, initialEdges }) {
|
|
|
67
42
|
setSelectedRepoNode(node.data);
|
|
68
43
|
}
|
|
69
44
|
}, [nodes, clearSelection]);
|
|
70
|
-
|
|
71
|
-
const
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
return;
|
|
81
|
-
let payload;
|
|
82
|
-
if (questionnaireData) {
|
|
83
|
-
const changedSelections = [];
|
|
84
|
-
for (const [questionId, optionId] of Object.entries(prdSelections)) {
|
|
85
|
-
const question = questionnaireData.questions.find((q) => q.id === questionId);
|
|
86
|
-
const option = question?.options.find((o) => o.id === optionId);
|
|
87
|
-
if (question && option) {
|
|
88
|
-
changedSelections.push({
|
|
89
|
-
questionId: question.question,
|
|
90
|
-
selectedOption: option.label,
|
|
91
|
-
});
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
payload = { approved: true, changedSelections };
|
|
95
|
-
}
|
|
96
|
-
const result = await approveFeature(featureId, payload);
|
|
97
|
-
if (!result.approved) {
|
|
98
|
-
toast.error(result.error ?? 'Failed to approve requirements');
|
|
99
|
-
return;
|
|
100
|
-
}
|
|
101
|
-
toast.success('Requirements approved — agent resuming');
|
|
102
|
-
clearSelection();
|
|
103
|
-
setPrdSelections({});
|
|
104
|
-
}, [selectedNode?.featureId, clearSelection, questionnaireData, prdSelections]);
|
|
105
|
-
// Shared reject handler — all drawers use the same rejectFeature flow
|
|
106
|
-
const handleReject = useCallback(async (feedback, label, onDone) => {
|
|
107
|
-
const featureId = selectedNode?.featureId;
|
|
108
|
-
if (!featureId)
|
|
109
|
-
return;
|
|
110
|
-
setIsRejecting(true);
|
|
111
|
-
try {
|
|
112
|
-
const result = await rejectFeature(featureId, feedback);
|
|
113
|
-
if (!result.rejected) {
|
|
114
|
-
toast.error(result.error ?? `Failed to reject ${label.toLowerCase()}`);
|
|
115
|
-
return;
|
|
116
|
-
}
|
|
117
|
-
rejectSound.play();
|
|
118
|
-
toast.success(`${label} rejected — agent re-iterating (iteration ${result.iteration})`);
|
|
119
|
-
if (result.iterationWarning) {
|
|
120
|
-
toast.warning(`Iteration ${result.iteration} — consider approving or adjusting feedback to avoid excessive iterations`);
|
|
121
|
-
}
|
|
122
|
-
clearSelection();
|
|
123
|
-
onDone?.();
|
|
124
|
-
}
|
|
125
|
-
finally {
|
|
126
|
-
setIsRejecting(false);
|
|
127
|
-
}
|
|
128
|
-
}, [selectedNode?.featureId, clearSelection, rejectSound]);
|
|
129
|
-
const handlePrdReject = useCallback((feedback) => handleReject(feedback, 'Requirements', () => setPrdSelections({})), [handleReject]);
|
|
130
|
-
const handleTechDecisionsReject = useCallback((feedback) => handleReject(feedback, 'Plan'), [handleReject]);
|
|
131
|
-
const handleMergeReject = useCallback((feedback) => handleReject(feedback, 'Merge'), [handleReject]);
|
|
132
|
-
// Shared approve handler — tech decisions and merge use identical approve flows
|
|
133
|
-
const handleSimpleApprove = useCallback(async (label) => {
|
|
134
|
-
const featureId = selectedNode?.featureId;
|
|
135
|
-
if (!featureId)
|
|
136
|
-
return;
|
|
137
|
-
const result = await approveFeature(featureId);
|
|
138
|
-
if (!result.approved) {
|
|
139
|
-
toast.error(result.error ?? `Failed to approve ${label.toLowerCase()}`);
|
|
140
|
-
return;
|
|
141
|
-
}
|
|
142
|
-
toast.success(`${label} approved — agent resuming`);
|
|
143
|
-
clearSelection();
|
|
144
|
-
}, [selectedNode?.featureId, clearSelection]);
|
|
145
|
-
const handleTechDecisionsApprove = useCallback(() => handleSimpleApprove('Plan'), [handleSimpleApprove]);
|
|
146
|
-
const handleMergeApprove = useCallback(() => handleSimpleApprove('Merge'), [handleSimpleApprove]);
|
|
147
|
-
// Fetch questionnaire data and reset selections when a different feature is selected
|
|
148
|
-
const prdFeatureId = showPrdDrawer ? selectedNode?.featureId : null;
|
|
149
|
-
useEffect(() => {
|
|
150
|
-
setPrdSelections({});
|
|
151
|
-
setQuestionnaireData(null);
|
|
152
|
-
if (!prdFeatureId)
|
|
153
|
-
return;
|
|
154
|
-
let cancelled = false;
|
|
155
|
-
setIsLoadingQuestionnaire(true);
|
|
156
|
-
getFeatureArtifact(prdFeatureId)
|
|
157
|
-
.then((result) => {
|
|
158
|
-
if (cancelled)
|
|
159
|
-
return;
|
|
160
|
-
if (result.error) {
|
|
161
|
-
toast.error(result.error);
|
|
162
|
-
return;
|
|
163
|
-
}
|
|
164
|
-
if (result.questionnaire) {
|
|
165
|
-
setQuestionnaireData(result.questionnaire);
|
|
166
|
-
// Pre-select AI-recommended answers
|
|
167
|
-
const defaults = {};
|
|
168
|
-
for (const q of result.questionnaire.questions) {
|
|
169
|
-
const recommended = q.options.find((o) => o.recommended);
|
|
170
|
-
if (recommended)
|
|
171
|
-
defaults[q.id] = recommended.id;
|
|
172
|
-
}
|
|
173
|
-
setPrdSelections(defaults);
|
|
174
|
-
}
|
|
175
|
-
})
|
|
176
|
-
.catch(() => {
|
|
177
|
-
if (!cancelled)
|
|
178
|
-
toast.error('Failed to load questionnaire');
|
|
179
|
-
})
|
|
180
|
-
.finally(() => {
|
|
181
|
-
if (!cancelled)
|
|
182
|
-
setIsLoadingQuestionnaire(false);
|
|
183
|
-
});
|
|
184
|
-
return () => {
|
|
185
|
-
cancelled = true;
|
|
186
|
-
};
|
|
187
|
-
}, [prdFeatureId]);
|
|
188
|
-
// Fetch tech decisions data when a feature is in research + action-required
|
|
189
|
-
const techDecisionsFeatureId = showTechDecisionsDrawer ? selectedNode?.featureId : null;
|
|
190
|
-
useEffect(() => {
|
|
191
|
-
setTechDecisionsData(null);
|
|
192
|
-
if (!techDecisionsFeatureId)
|
|
193
|
-
return;
|
|
194
|
-
let cancelled = false;
|
|
195
|
-
setIsLoadingTechDecisions(true);
|
|
196
|
-
getResearchArtifact(techDecisionsFeatureId)
|
|
197
|
-
.then((result) => {
|
|
198
|
-
if (cancelled)
|
|
199
|
-
return;
|
|
200
|
-
if (result.error) {
|
|
201
|
-
toast.error(result.error);
|
|
202
|
-
return;
|
|
203
|
-
}
|
|
204
|
-
if (result.techDecisions) {
|
|
205
|
-
setTechDecisionsData(result.techDecisions);
|
|
206
|
-
}
|
|
207
|
-
})
|
|
208
|
-
.catch(() => {
|
|
209
|
-
if (!cancelled)
|
|
210
|
-
toast.error('Failed to load tech decisions');
|
|
211
|
-
})
|
|
212
|
-
.finally(() => {
|
|
213
|
-
if (!cancelled)
|
|
214
|
-
setIsLoadingTechDecisions(false);
|
|
215
|
-
});
|
|
216
|
-
return () => {
|
|
217
|
-
cancelled = true;
|
|
218
|
-
};
|
|
219
|
-
}, [techDecisionsFeatureId]);
|
|
220
|
-
// Fetch merge review data when a feature is in review + action-required
|
|
221
|
-
const mergeFeatureId = showMergeReviewDrawer ? selectedNode?.featureId : null;
|
|
222
|
-
useEffect(() => {
|
|
223
|
-
setMergeReviewData(null);
|
|
224
|
-
if (!mergeFeatureId)
|
|
225
|
-
return;
|
|
226
|
-
let cancelled = false;
|
|
227
|
-
setIsLoadingMergeReview(true);
|
|
228
|
-
getMergeReviewData(mergeFeatureId)
|
|
229
|
-
.then((result) => {
|
|
230
|
-
if (cancelled)
|
|
231
|
-
return;
|
|
232
|
-
if ('error' in result) {
|
|
233
|
-
toast.error(result.error);
|
|
234
|
-
return;
|
|
235
|
-
}
|
|
236
|
-
setMergeReviewData(result);
|
|
237
|
-
})
|
|
238
|
-
.catch(() => {
|
|
239
|
-
if (!cancelled)
|
|
240
|
-
toast.error('Failed to load merge review data');
|
|
241
|
-
})
|
|
242
|
-
.finally(() => {
|
|
243
|
-
if (!cancelled)
|
|
244
|
-
setIsLoadingMergeReview(false);
|
|
245
|
-
});
|
|
246
|
-
return () => {
|
|
247
|
-
cancelled = true;
|
|
248
|
-
};
|
|
249
|
-
}, [mergeFeatureId]);
|
|
250
|
-
const hasRepositories = nodes.some((n) => n.type === 'repositoryNode');
|
|
45
|
+
// Derive the single active drawer view from all current state
|
|
46
|
+
const drawerView = computeDrawerView({
|
|
47
|
+
selectedNode,
|
|
48
|
+
isCreateDrawerOpen,
|
|
49
|
+
pendingRepositoryPath,
|
|
50
|
+
pendingParentFeatureId,
|
|
51
|
+
selectedRepoNode,
|
|
52
|
+
features: featureOptions,
|
|
53
|
+
workflowDefaults,
|
|
54
|
+
});
|
|
251
55
|
// Listen for global "open create drawer" events from the sidebar
|
|
252
56
|
useEffect(() => {
|
|
253
57
|
const handler = () => handleAddFeature();
|
|
@@ -272,8 +76,9 @@ export function ControlCenterInner({ initialNodes, initialEdges }) {
|
|
|
272
76
|
window.addEventListener('shep:select-feature', handler);
|
|
273
77
|
return () => window.removeEventListener('shep:select-feature', handler);
|
|
274
78
|
}, [selectFeatureById]);
|
|
79
|
+
const hasRepositories = nodes.some((n) => n.type === 'repositoryNode');
|
|
275
80
|
if (!hasRepositories) {
|
|
276
|
-
return (_jsxs(_Fragment, { children: [_jsx(NotificationPermissionBanner, {}), _jsx(ControlCenterEmptyState, { onRepositorySelect: handleAddRepository }), _jsx(
|
|
81
|
+
return (_jsxs(_Fragment, { children: [_jsx(NotificationPermissionBanner, {}), _jsx(ControlCenterEmptyState, { onRepositorySelect: handleAddRepository }), _jsx(ControlCenterDrawer, { view: drawerView, onClose: handleClearDrawers, onDelete: handleDeleteFeature, isDeleting: isDeleting, onCreateSubmit: handleCreateFeatureSubmit })] }));
|
|
277
82
|
}
|
|
278
|
-
return (_jsxs(_Fragment, { children: [_jsx(NotificationPermissionBanner, {}), _jsx(FeaturesCanvas, { nodes: nodes, edges: edges, onNodesChange: onNodesChange, onConnect: handleConnect, onAddFeature: handleAddFeature, onNodeAction: handleAddFeatureToFeature, onNodeClick: handleNodeClick, onPaneClick: handleClearDrawers, onRepositoryAdd: handleAddFeatureToRepo, onRepositoryClick: handleRepositoryClick, onRepositoryDelete: handleDeleteRepository,
|
|
83
|
+
return (_jsxs(_Fragment, { children: [_jsx(NotificationPermissionBanner, {}), _jsx(FeaturesCanvas, { nodes: nodes, edges: edges, onNodesChange: onNodesChange, onConnect: handleConnect, onAddFeature: handleAddFeature, onNodeAction: handleAddFeatureToFeature, onNodeClick: handleNodeClick, onPaneClick: handleClearDrawers, onRepositoryAdd: handleAddFeatureToRepo, onRepositoryClick: handleRepositoryClick, onRepositoryDelete: handleDeleteRepository, onFeatureDelete: handleDeleteFeature, onRepositorySelect: handleAddRepository, emptyState: _jsx(ControlCenterEmptyState, { onRepositorySelect: handleAddRepository }) }), _jsx(ControlCenterDrawer, { view: drawerView, onClose: handleClearDrawers, onDelete: handleDeleteFeature, isDeleting: isDeleting, onCreateSubmit: handleCreateFeatureSubmit })] }));
|
|
279
84
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"use-control-center-state.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/features/control-center/use-control-center-state.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,UAAU,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAClE,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,kCAAkC,CAAC;AACxE,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,2CAA2C,CAAC;AACtF,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAC;AAC5E,OAAO,EAAmB,KAAK,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAYhF,MAAM,WAAW,kBAAkB;IACjC,KAAK,EAAE,cAAc,EAAE,CAAC;IACxB,KAAK,EAAE,IAAI,EAAE,CAAC;IACd,YAAY,EAAE,eAAe,GAAG,IAAI,CAAC;IACrC,kBAAkB,EAAE,OAAO,CAAC;IAC5B,qBAAqB,EAAE,MAAM,CAAC;IAC9B,4EAA4E;IAC5E,sBAAsB,EAAE,MAAM,GAAG,SAAS,CAAC;IAC3C,aAAa,EAAE,CAAC,OAAO,EAAE,UAAU,CAAC,cAAc,CAAC,EAAE,KAAK,IAAI,CAAC;IAC/D,aAAa,EAAE,CAAC,UAAU,EAAE,UAAU,KAAK,IAAI,CAAC;IAChD,cAAc,EAAE,MAAM,IAAI,CAAC;IAC3B,eAAe,EAAE,CAAC,KAAK,EAAE,KAAK,CAAC,UAAU,EAAE,IAAI,EAAE,cAAc,KAAK,IAAI,CAAC;IACzE,gBAAgB,EAAE,MAAM,IAAI,CAAC;IAC7B,sBAAsB,EAAE,CAAC,UAAU,EAAE,MAAM,KAAK,IAAI,CAAC;IACrD,yBAAyB,EAAE,CAAC,aAAa,EAAE,MAAM,KAAK,IAAI,CAAC;IAC3D,mBAAmB,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;IAC5C,YAAY,EAAE,CAAC,SAAS,EAAE,eAAe,KAAK,IAAI,CAAC;IACnD,yBAAyB,EAAE,CAAC,IAAI,EAAE,oBAAoB,KAAK,IAAI,CAAC;IAChE,iBAAiB,EAAE,MAAM,IAAI,CAAC;IAC9B,mBAAmB,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAC1D,sBAAsB,EAAE,CAAC,YAAY,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAChE,UAAU,EAAE,OAAO,CAAC;IACpB,iBAAiB,EAAE,CACjB,YAAY,EAAE,MAAM,GAAG,IAAI,EAC3B,YAAY,CAAC,EAAE,OAAO,CAAC,eAAe,CAAC,KACpC,MAAM,CAAC;IACZ,iBAAiB,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,IAAI,CAAC;CAChD;AAID,wBAAgB,qBAAqB,CACnC,YAAY,EAAE,cAAc,EAAE,EAC9B,YAAY,EAAE,IAAI,EAAE,GACnB,kBAAkB,
|
|
1
|
+
{"version":3,"file":"use-control-center-state.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/features/control-center/use-control-center-state.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,UAAU,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAClE,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,kCAAkC,CAAC;AACxE,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,2CAA2C,CAAC;AACtF,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAC;AAC5E,OAAO,EAAmB,KAAK,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAYhF,MAAM,WAAW,kBAAkB;IACjC,KAAK,EAAE,cAAc,EAAE,CAAC;IACxB,KAAK,EAAE,IAAI,EAAE,CAAC;IACd,YAAY,EAAE,eAAe,GAAG,IAAI,CAAC;IACrC,kBAAkB,EAAE,OAAO,CAAC;IAC5B,qBAAqB,EAAE,MAAM,CAAC;IAC9B,4EAA4E;IAC5E,sBAAsB,EAAE,MAAM,GAAG,SAAS,CAAC;IAC3C,aAAa,EAAE,CAAC,OAAO,EAAE,UAAU,CAAC,cAAc,CAAC,EAAE,KAAK,IAAI,CAAC;IAC/D,aAAa,EAAE,CAAC,UAAU,EAAE,UAAU,KAAK,IAAI,CAAC;IAChD,cAAc,EAAE,MAAM,IAAI,CAAC;IAC3B,eAAe,EAAE,CAAC,KAAK,EAAE,KAAK,CAAC,UAAU,EAAE,IAAI,EAAE,cAAc,KAAK,IAAI,CAAC;IACzE,gBAAgB,EAAE,MAAM,IAAI,CAAC;IAC7B,sBAAsB,EAAE,CAAC,UAAU,EAAE,MAAM,KAAK,IAAI,CAAC;IACrD,yBAAyB,EAAE,CAAC,aAAa,EAAE,MAAM,KAAK,IAAI,CAAC;IAC3D,mBAAmB,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;IAC5C,YAAY,EAAE,CAAC,SAAS,EAAE,eAAe,KAAK,IAAI,CAAC;IACnD,yBAAyB,EAAE,CAAC,IAAI,EAAE,oBAAoB,KAAK,IAAI,CAAC;IAChE,iBAAiB,EAAE,MAAM,IAAI,CAAC;IAC9B,mBAAmB,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAC1D,sBAAsB,EAAE,CAAC,YAAY,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAChE,UAAU,EAAE,OAAO,CAAC;IACpB,iBAAiB,EAAE,CACjB,YAAY,EAAE,MAAM,GAAG,IAAI,EAC3B,YAAY,CAAC,EAAE,OAAO,CAAC,eAAe,CAAC,KACpC,MAAM,CAAC;IACZ,iBAAiB,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,IAAI,CAAC;CAChD;AAID,wBAAgB,qBAAqB,CACnC,YAAY,EAAE,cAAc,EAAE,EAC9B,YAAY,EAAE,IAAI,EAAE,GACnB,kBAAkB,CA4sBpB"}
|
package/dist/src/presentation/web/components/features/control-center/use-control-center-state.js
CHANGED
|
@@ -457,11 +457,12 @@ export function useControlCenterState(initialNodes, initialEdges) {
|
|
|
457
457
|
// Find the repo node that owns this feature
|
|
458
458
|
const repoEdge = edges.find((e) => e.target === featureNodeId);
|
|
459
459
|
const repoNodeId = repoEdge?.source ?? null;
|
|
460
|
+
clickSound.play();
|
|
460
461
|
setSelectedNode(null);
|
|
461
462
|
setPendingRepoNodeId(repoNodeId);
|
|
462
463
|
setPendingParentFeatureId(featureId);
|
|
463
464
|
setIsCreateDrawerOpen(true);
|
|
464
|
-
}, [edges]);
|
|
465
|
+
}, [edges, clickSound]);
|
|
465
466
|
const handleLayout = useCallback((direction) => {
|
|
466
467
|
setNodes((currentNodes) => {
|
|
467
468
|
const currentEdges = edges;
|
|
@@ -15,11 +15,12 @@ export interface FeaturesCanvasProps {
|
|
|
15
15
|
onRepositoryAdd?: (repoNodeId: string) => void;
|
|
16
16
|
onRepositoryClick?: (nodeId: string) => void;
|
|
17
17
|
onRepositoryDelete?: (repositoryId: string) => void;
|
|
18
|
+
onFeatureDelete?: (featureId: string) => void;
|
|
18
19
|
onConnect?: (connection: Connection) => void;
|
|
19
20
|
onRepositorySelect?: (path: string) => void;
|
|
20
21
|
onCanvasDrag?: () => void;
|
|
21
22
|
toolbar?: React.ReactNode;
|
|
22
23
|
emptyState?: React.ReactNode;
|
|
23
24
|
}
|
|
24
|
-
export declare function FeaturesCanvas({ nodes, edges, onNodesChange, onAddFeature, onNodeAction, onNodeSettings, onConnect, onNodeClick, onPaneClick, onRepositoryAdd, onRepositoryClick, onRepositoryDelete, onRepositorySelect, onCanvasDrag, toolbar, emptyState, }: FeaturesCanvasProps): import("react/jsx-runtime").JSX.Element;
|
|
25
|
+
export declare function FeaturesCanvas({ nodes, edges, onNodesChange, onAddFeature, onNodeAction, onNodeSettings, onConnect, onNodeClick, onPaneClick, onRepositoryAdd, onRepositoryClick, onRepositoryDelete, onFeatureDelete, onRepositorySelect, onCanvasDrag, toolbar, emptyState, }: FeaturesCanvasProps): import("react/jsx-runtime").JSX.Element;
|
|
25
26
|
//# sourceMappingURL=features-canvas.d.ts.map
|
package/dist/src/presentation/web/components/features/features-canvas/features-canvas.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"features-canvas.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/features/features-canvas/features-canvas.tsx"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,UAAU,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAKlE,OAAO,KAAK,EAAE,eAAe,EAAmB,MAAM,kCAAkC,CAAC;AAEzF,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,qCAAqC,CAAC;AAE9E,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,yCAAyC,CAAC;AAGrF,MAAM,MAAM,cAAc,GAAG,eAAe,GAAG,kBAAkB,GAAG,qBAAqB,CAAC;AAE1F,MAAM,WAAW,mBAAmB;IAClC,KAAK,EAAE,cAAc,EAAE,CAAC;IACxB,KAAK,EAAE,IAAI,EAAE,CAAC;IACd,aAAa,CAAC,EAAE,CAAC,OAAO,EAAE,UAAU,CAAC,cAAc,CAAC,EAAE,KAAK,IAAI,CAAC;IAChE,YAAY,CAAC,EAAE,MAAM,IAAI,CAAC;IAC1B,YAAY,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,IAAI,CAAC;IACxC,cAAc,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,IAAI,CAAC;IAC1C,WAAW,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,CAAC,UAAU,EAAE,IAAI,EAAE,cAAc,KAAK,IAAI,CAAC;IACtE,WAAW,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,CAAC,UAAU,KAAK,IAAI,CAAC;IAChD,eAAe,CAAC,EAAE,CAAC,UAAU,EAAE,MAAM,KAAK,IAAI,CAAC;IAC/C,iBAAiB,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,IAAI,CAAC;IAC7C,kBAAkB,CAAC,EAAE,CAAC,YAAY,EAAE,MAAM,KAAK,IAAI,CAAC;IACpD,SAAS,CAAC,EAAE,CAAC,UAAU,EAAE,UAAU,KAAK,IAAI,CAAC;IAC7C,kBAAkB,CAAC,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;IAC5C,YAAY,CAAC,EAAE,MAAM,IAAI,CAAC;IAC1B,OAAO,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,UAAU,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;CAC9B;AAED,wBAAgB,cAAc,CAAC,EAC7B,KAAK,EACL,KAAK,EACL,aAAa,EACb,YAAY,EACZ,YAAY,EACZ,cAAc,EACd,SAAS,EACT,WAAW,EACX,WAAW,EACX,eAAe,EACf,iBAAiB,EACjB,kBAAkB,EAClB,kBAAkB,EAClB,YAAY,EACZ,OAAO,EACP,UAAU,GACX,EAAE,mBAAmB,
|
|
1
|
+
{"version":3,"file":"features-canvas.d.ts","sourceRoot":"","sources":["../../../../../../../src/presentation/web/components/features/features-canvas/features-canvas.tsx"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,UAAU,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAKlE,OAAO,KAAK,EAAE,eAAe,EAAmB,MAAM,kCAAkC,CAAC;AAEzF,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,qCAAqC,CAAC;AAE9E,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,yCAAyC,CAAC;AAGrF,MAAM,MAAM,cAAc,GAAG,eAAe,GAAG,kBAAkB,GAAG,qBAAqB,CAAC;AAE1F,MAAM,WAAW,mBAAmB;IAClC,KAAK,EAAE,cAAc,EAAE,CAAC;IACxB,KAAK,EAAE,IAAI,EAAE,CAAC;IACd,aAAa,CAAC,EAAE,CAAC,OAAO,EAAE,UAAU,CAAC,cAAc,CAAC,EAAE,KAAK,IAAI,CAAC;IAChE,YAAY,CAAC,EAAE,MAAM,IAAI,CAAC;IAC1B,YAAY,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,IAAI,CAAC;IACxC,cAAc,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,IAAI,CAAC;IAC1C,WAAW,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,CAAC,UAAU,EAAE,IAAI,EAAE,cAAc,KAAK,IAAI,CAAC;IACtE,WAAW,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,CAAC,UAAU,KAAK,IAAI,CAAC;IAChD,eAAe,CAAC,EAAE,CAAC,UAAU,EAAE,MAAM,KAAK,IAAI,CAAC;IAC/C,iBAAiB,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,IAAI,CAAC;IAC7C,kBAAkB,CAAC,EAAE,CAAC,YAAY,EAAE,MAAM,KAAK,IAAI,CAAC;IACpD,eAAe,CAAC,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,IAAI,CAAC;IAC9C,SAAS,CAAC,EAAE,CAAC,UAAU,EAAE,UAAU,KAAK,IAAI,CAAC;IAC7C,kBAAkB,CAAC,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;IAC5C,YAAY,CAAC,EAAE,MAAM,IAAI,CAAC;IAC1B,OAAO,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,UAAU,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;CAC9B;AAED,wBAAgB,cAAc,CAAC,EAC7B,KAAK,EACL,KAAK,EACL,aAAa,EACb,YAAY,EACZ,YAAY,EACZ,cAAc,EACd,SAAS,EACT,WAAW,EACX,WAAW,EACX,eAAe,EACf,iBAAiB,EACjB,kBAAkB,EAClB,eAAe,EACf,kBAAkB,EAClB,YAAY,EACZ,OAAO,EACP,UAAU,GACX,EAAE,mBAAmB,2CA4HrB"}
|
|
@@ -9,7 +9,7 @@ import { FeatureNode } from '../../common/feature-node/index.js';
|
|
|
9
9
|
import { RepositoryNode } from '../../common/repository-node/index.js';
|
|
10
10
|
import { AddRepositoryNode } from '../../common/add-repository-node/index.js';
|
|
11
11
|
import { DependencyEdge } from './dependency-edge.js';
|
|
12
|
-
export function FeaturesCanvas({ nodes, edges, onNodesChange, onAddFeature, onNodeAction, onNodeSettings, onConnect, onNodeClick, onPaneClick, onRepositoryAdd, onRepositoryClick, onRepositoryDelete, onRepositorySelect, onCanvasDrag, toolbar, emptyState, }) {
|
|
12
|
+
export function FeaturesCanvas({ nodes, edges, onNodesChange, onAddFeature, onNodeAction, onNodeSettings, onConnect, onNodeClick, onPaneClick, onRepositoryAdd, onRepositoryClick, onRepositoryDelete, onFeatureDelete, onRepositorySelect, onCanvasDrag, toolbar, emptyState, }) {
|
|
13
13
|
const nodeTypes = useMemo(() => ({
|
|
14
14
|
featureNode: FeatureNode,
|
|
15
15
|
repositoryNode: RepositoryNode,
|
|
@@ -38,6 +38,7 @@ export function FeaturesCanvas({ nodes, edges, onNodesChange, onAddFeature, onNo
|
|
|
38
38
|
? {
|
|
39
39
|
onAction: onNodeAction ? () => onNodeAction(node.id) : undefined,
|
|
40
40
|
onSettings: onNodeSettings ? () => onNodeSettings(node.id) : undefined,
|
|
41
|
+
onDelete: onFeatureDelete,
|
|
41
42
|
}
|
|
42
43
|
: {}),
|
|
43
44
|
...(node.type === 'repositoryNode' && {
|
|
@@ -54,6 +55,7 @@ export function FeaturesCanvas({ nodes, edges, onNodesChange, onAddFeature, onNo
|
|
|
54
55
|
edges.length,
|
|
55
56
|
onNodeAction,
|
|
56
57
|
onNodeSettings,
|
|
58
|
+
onFeatureDelete,
|
|
57
59
|
onRepositoryAdd,
|
|
58
60
|
onRepositoryClick,
|
|
59
61
|
onRepositoryDelete,
|
|
@@ -65,5 +67,5 @@ export function FeaturesCanvas({ nodes, edges, onNodesChange, onAddFeature, onNo
|
|
|
65
67
|
}
|
|
66
68
|
return (_jsx("div", { "data-testid": "features-canvas-empty", children: _jsx(EmptyState, { title: "No features yet", description: "Get started by creating your first feature.", action: _jsxs(Button, { onClick: onAddFeature, children: [_jsx(Plus, { className: "mr-2 h-4 w-4" }), "New Feature"] }) }) }));
|
|
67
69
|
}
|
|
68
|
-
return (_jsx("div", { "data-testid": "features-canvas", className: "h-full w-full", children: _jsx(ReactFlowProvider, { children: _jsxs(ReactFlow, { nodes: enrichedNodes, edges: edges, nodeTypes: nodeTypes, edgeTypes: edgeTypes, isValidConnection: isValidConnection, onConnect: onConnect, onNodesChange: onNodesChange, onNodeClick: onNodeClick, onPaneClick: onPaneClick, onMoveStart: onCanvasDrag, defaultViewport: { x: 30, y: 30, zoom: 0.85 }, nodesDraggable: false, nodesConnectable: false, elementsSelectable: false, children: [_jsx(Background, {}), _jsx(Controls, {}), toolbar] }) }) }));
|
|
70
|
+
return (_jsx("div", { "data-testid": "features-canvas", "data-no-drawer-close": true, className: "pointer-events-auto h-full w-full", children: _jsx(ReactFlowProvider, { children: _jsxs(ReactFlow, { nodes: enrichedNodes, edges: edges, nodeTypes: nodeTypes, edgeTypes: edgeTypes, isValidConnection: isValidConnection, onConnect: onConnect, onNodesChange: onNodesChange, onNodeClick: onNodeClick, onPaneClick: onPaneClick, onMoveStart: onCanvasDrag, defaultViewport: { x: 30, y: 30, zoom: 0.85 }, nodesDraggable: false, nodesConnectable: false, elementsSelectable: false, children: [_jsx(Background, {}), _jsx(Controls, {}), toolbar] }) }) }));
|
|
69
71
|
}
|