@specverse/engine-realize 3.5.3
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/assets/examples/09-api/ai-spec.yaml +194 -0
- package/assets/examples/09-api/converted.yaml +95 -0
- package/assets/examples/09-api/diagram-architecture.mmd +10 -0
- package/assets/examples/09-api/diagram-er.mmd +10 -0
- package/assets/examples/09-api/documentation.html +104 -0
- package/assets/examples/09-api/documentation.md +95 -0
- package/assets/examples/09-api/inferred-spec.yaml +420 -0
- package/assets/examples/09-api/openapi.json +61 -0
- package/assets/examples/10-api/README.md +216 -0
- package/assets/examples/10-api/ai-spec.yaml +194 -0
- package/assets/examples/10-api/converted.yaml +96 -0
- package/assets/examples/10-api/diagram-architecture.mmd +10 -0
- package/assets/examples/10-api/diagram-er.mmd +10 -0
- package/assets/examples/10-api/documentation.html +104 -0
- package/assets/examples/10-api/documentation.md +95 -0
- package/assets/examples/10-api/inferred-spec.yaml +7 -0
- package/assets/examples/10-api/metadata.yaml +89 -0
- package/assets/examples/10-api/openapi.json +61 -0
- package/assets/examples/10-api/package-integration-test.js +177 -0
- package/assets/examples/10-api/usage-example.js +323 -0
- package/assets/examples/10-api/usage-example.ts +363 -0
- package/assets/examples/10-api/workflow-test.js +113 -0
- package/assets/examples/manifests/01-simple-default-mappings.yaml +36 -0
- package/assets/examples/manifests/02-capability-mappings.yaml +55 -0
- package/assets/examples/manifests/03-hybrid-mappings.yaml +109 -0
- package/assets/examples/manifests/README.md +245 -0
- package/assets/examples/manifests/backend-only.yaml +43 -0
- package/assets/examples/manifests/blog-api.md +78 -0
- package/assets/examples/manifests/blog-api.specly +79 -0
- package/assets/examples/manifests/frontend-only.yaml +27 -0
- package/assets/examples/manifests/fullstack-app.yaml +44 -0
- package/assets/examples/manifests/fullstack-monorepo.yaml +62 -0
- package/assets/examples/validate-examples-with-expected-failures.cjs +328 -0
- package/assets/examples/validate-examples.cjs +225 -0
- package/assets/examples-decomposed/cloud-native-manifest.example.yaml +8 -0
- package/assets/examples-decomposed/cloud-native-manifest.md +379 -0
- package/assets/examples-decomposed/cloud-native-manifest.specly +60 -0
- package/assets/examples-decomposed/docker-compose-manifest.example.yaml +8 -0
- package/assets/examples-decomposed/docker-compose-manifest.md +326 -0
- package/assets/examples-decomposed/docker-compose-manifest.specly +40 -0
- package/assets/examples-decomposed/kubernetes-deployment-manifest.example.yaml +8 -0
- package/assets/examples-decomposed/kubernetes-deployment-manifest.md +237 -0
- package/assets/examples-decomposed/kubernetes-deployment-manifest.specly +41 -0
- package/assets/templates/README.md +559 -0
- package/assets/templates/TEMPLATE-ENHANCEMENTS-V33.md +462 -0
- package/assets/templates/backend-only/CLAUDE.md +73 -0
- package/assets/templates/backend-only/README.md +197 -0
- package/assets/templates/backend-only/deployments/README.md +149 -0
- package/assets/templates/backend-only/deployments/development.specly +53 -0
- package/assets/templates/backend-only/deployments/production.specly +87 -0
- package/assets/templates/backend-only/docs/README.md +50 -0
- package/assets/templates/backend-only/docs/api/README.md +7 -0
- package/assets/templates/backend-only/docs/diagrams/README.md +85 -0
- package/assets/templates/backend-only/docs/example-documentation-template.md +269 -0
- package/assets/templates/backend-only/docs/guides/README.md +15 -0
- package/assets/templates/backend-only/dot.env.example +18 -0
- package/assets/templates/backend-only/generated/README.md +56 -0
- package/assets/templates/backend-only/generated/code/integration-test.template.js +320 -0
- package/assets/templates/backend-only/generated/code/package.json.template +34 -0
- package/assets/templates/backend-only/generated/docs/README.md +49 -0
- package/assets/templates/backend-only/gitignore +54 -0
- package/assets/templates/backend-only/manifests/README.md +72 -0
- package/assets/templates/backend-only/manifests/docker-compose.specly +91 -0
- package/assets/templates/backend-only/manifests/implementation.yaml +100 -0
- package/assets/templates/backend-only/manifests/kubernetes.specly +140 -0
- package/assets/templates/backend-only/package.json +59 -0
- package/assets/templates/backend-only/scripts/test-all.sh +160 -0
- package/assets/templates/backend-only/scripts/test-generated-code.sh +165 -0
- package/assets/templates/backend-only/specs/main.specly +67 -0
- package/assets/templates/default/CLAUDE.md +141 -0
- package/assets/templates/default/README.md +404 -0
- package/assets/templates/default/deployments/README.md +149 -0
- package/assets/templates/default/deployments/development.specly +53 -0
- package/assets/templates/default/deployments/production.specly +87 -0
- package/assets/templates/default/docs/README.md +50 -0
- package/assets/templates/default/docs/api/README.md +7 -0
- package/assets/templates/default/docs/diagrams/README.md +85 -0
- package/assets/templates/default/docs/example-documentation-template.md +269 -0
- package/assets/templates/default/docs/guides/README.md +15 -0
- package/assets/templates/default/dot.env.example +18 -0
- package/assets/templates/default/generated/README.md +56 -0
- package/assets/templates/default/generated/code/integration-test.template.js +320 -0
- package/assets/templates/default/generated/code/package.json.template +34 -0
- package/assets/templates/default/generated/docs/README.md +49 -0
- package/assets/templates/default/gitignore +54 -0
- package/assets/templates/default/manifests/README.md +72 -0
- package/assets/templates/default/manifests/docker-compose.specly +91 -0
- package/assets/templates/default/manifests/implementation.yaml +176 -0
- package/assets/templates/default/manifests/kubernetes.specly +140 -0
- package/assets/templates/default/package.json +61 -0
- package/assets/templates/default/scripts/test-all.sh +160 -0
- package/assets/templates/default/scripts/test-generated-code.sh +165 -0
- package/assets/templates/default/specs/main.specly +67 -0
- package/assets/templates/frontend-only/CLAUDE.md +75 -0
- package/assets/templates/frontend-only/README.md +231 -0
- package/assets/templates/frontend-only/deployments/README.md +149 -0
- package/assets/templates/frontend-only/deployments/development.specly +53 -0
- package/assets/templates/frontend-only/deployments/production.specly +87 -0
- package/assets/templates/frontend-only/docs/README.md +50 -0
- package/assets/templates/frontend-only/docs/api/README.md +7 -0
- package/assets/templates/frontend-only/docs/diagrams/README.md +85 -0
- package/assets/templates/frontend-only/docs/example-documentation-template.md +269 -0
- package/assets/templates/frontend-only/docs/guides/README.md +15 -0
- package/assets/templates/frontend-only/dot.env.example +18 -0
- package/assets/templates/frontend-only/generated/README.md +56 -0
- package/assets/templates/frontend-only/generated/code/integration-test.template.js +320 -0
- package/assets/templates/frontend-only/generated/code/package.json.template +34 -0
- package/assets/templates/frontend-only/generated/docs/README.md +49 -0
- package/assets/templates/frontend-only/gitignore +54 -0
- package/assets/templates/frontend-only/manifests/README.md +72 -0
- package/assets/templates/frontend-only/manifests/docker-compose.specly +91 -0
- package/assets/templates/frontend-only/manifests/implementation.yaml +58 -0
- package/assets/templates/frontend-only/manifests/kubernetes.specly +140 -0
- package/assets/templates/frontend-only/package.json +59 -0
- package/assets/templates/frontend-only/scripts/test-all.sh +160 -0
- package/assets/templates/frontend-only/scripts/test-generated-code.sh +165 -0
- package/assets/templates/frontend-only/specs/main.specly +57 -0
- package/assets/templates/full-stack/AI-GUIDE.md +60 -0
- package/assets/templates/full-stack/CLAUDE.md +141 -0
- package/assets/templates/full-stack/README.md +382 -0
- package/assets/templates/full-stack/archive/AI-GUIDE-legacy.md +392 -0
- package/assets/templates/full-stack/deployments/README.md +149 -0
- package/assets/templates/full-stack/deployments/development.specly +53 -0
- package/assets/templates/full-stack/deployments/production.specly +87 -0
- package/assets/templates/full-stack/docs/README.md +51 -0
- package/assets/templates/full-stack/docs/api/README.md +7 -0
- package/assets/templates/full-stack/docs/diagrams/README.md +85 -0
- package/assets/templates/full-stack/docs/example-documentation-template.md +269 -0
- package/assets/templates/full-stack/docs/guides/README.md +15 -0
- package/assets/templates/full-stack/generated/README.md +56 -0
- package/assets/templates/full-stack/generated/code/integration-test.template.js +320 -0
- package/assets/templates/full-stack/generated/code/package.json.template +34 -0
- package/assets/templates/full-stack/generated/docs/README.md +49 -0
- package/assets/templates/full-stack/gitignore +54 -0
- package/assets/templates/full-stack/manifests/README.md +72 -0
- package/assets/templates/full-stack/manifests/docker-compose.specly +91 -0
- package/assets/templates/full-stack/manifests/implementation.yaml +155 -0
- package/assets/templates/full-stack/manifests/kubernetes.specly +140 -0
- package/assets/templates/full-stack/package.json +45 -0
- package/assets/templates/full-stack/scripts/test-all.sh +160 -0
- package/assets/templates/full-stack/scripts/test-generated-code.sh +165 -0
- package/assets/templates/full-stack/specs/example-v33.specly +297 -0
- package/assets/templates/full-stack/specs/main-simple.specly +73 -0
- package/assets/templates/full-stack/specs/main.specly +408 -0
- package/dist/engines/code-generator.d.ts +86 -0
- package/dist/engines/code-generator.d.ts.map +1 -0
- package/dist/engines/code-generator.js +159 -0
- package/dist/engines/code-generator.js.map +1 -0
- package/dist/engines/engine-registry.d.ts +94 -0
- package/dist/engines/engine-registry.d.ts.map +1 -0
- package/dist/engines/engine-registry.js +163 -0
- package/dist/engines/engine-registry.js.map +1 -0
- package/dist/engines/index.d.ts +10 -0
- package/dist/engines/index.d.ts.map +1 -0
- package/dist/engines/index.js +12 -0
- package/dist/engines/index.js.map +1 -0
- package/dist/engines/typescript-engine.d.ts +74 -0
- package/dist/engines/typescript-engine.d.ts.map +1 -0
- package/dist/engines/typescript-engine.js +288 -0
- package/dist/engines/typescript-engine.js.map +1 -0
- package/dist/generators/index.d.ts +11 -0
- package/dist/generators/index.d.ts.map +1 -0
- package/dist/generators/index.js +11 -0
- package/dist/generators/index.js.map +1 -0
- package/dist/index.d.ts +48 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +434 -0
- package/dist/index.js.map +1 -0
- package/dist/library/index.d.ts +12 -0
- package/dist/library/index.d.ts.map +1 -0
- package/dist/library/index.js +15 -0
- package/dist/library/index.js.map +1 -0
- package/dist/library/library.d.ts +132 -0
- package/dist/library/library.d.ts.map +1 -0
- package/dist/library/library.js +343 -0
- package/dist/library/library.js.map +1 -0
- package/dist/library/loader.d.ts +73 -0
- package/dist/library/loader.d.ts.map +1 -0
- package/dist/library/loader.js +150 -0
- package/dist/library/loader.js.map +1 -0
- package/dist/library/resolver.d.ts +104 -0
- package/dist/library/resolver.d.ts.map +1 -0
- package/dist/library/resolver.js +299 -0
- package/dist/library/resolver.js.map +1 -0
- package/dist/library/validator.d.ts +65 -0
- package/dist/library/validator.d.ts.map +1 -0
- package/dist/library/validator.js +203 -0
- package/dist/library/validator.js.map +1 -0
- package/dist/types/index.d.ts +7 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +7 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/instance-factory.d.ts +289 -0
- package/dist/types/instance-factory.d.ts.map +1 -0
- package/dist/types/instance-factory.js +8 -0
- package/dist/types/instance-factory.js.map +1 -0
- package/dist/types/unified-mappings.d.ts +163 -0
- package/dist/types/unified-mappings.d.ts.map +1 -0
- package/dist/types/unified-mappings.js +110 -0
- package/dist/types/unified-mappings.js.map +1 -0
- package/dist/utils/ai-spec-loader.d.ts +77 -0
- package/dist/utils/ai-spec-loader.d.ts.map +1 -0
- package/dist/utils/ai-spec-loader.js +138 -0
- package/dist/utils/ai-spec-loader.js.map +1 -0
- package/dist/utils/index.d.ts +9 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +9 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/manifest-loader.d.ts +107 -0
- package/dist/utils/manifest-loader.d.ts.map +1 -0
- package/dist/utils/manifest-loader.js +168 -0
- package/dist/utils/manifest-loader.js.map +1 -0
- package/dist/utils/mapping-migration.d.ts +53 -0
- package/dist/utils/mapping-migration.d.ts.map +1 -0
- package/dist/utils/mapping-migration.js +194 -0
- package/dist/utils/mapping-migration.js.map +1 -0
- package/libs/instance-factories/CURVED-INTERFACE.md +278 -0
- package/libs/instance-factories/README.md +433 -0
- package/libs/instance-factories/applications/generic-app.yaml +52 -0
- package/libs/instance-factories/applications/react-app.yaml +186 -0
- package/libs/instance-factories/applications/templates/generic/backend-env-generator.ts +31 -0
- package/libs/instance-factories/applications/templates/generic/backend-package-json-generator.ts +80 -0
- package/libs/instance-factories/applications/templates/generic/backend-tsconfig-generator.ts +69 -0
- package/libs/instance-factories/applications/templates/generic/main-generator.ts +308 -0
- package/libs/instance-factories/applications/templates/react/_view-components-source.ts +555 -0
- package/libs/instance-factories/applications/templates/react/api-client-generator.ts +436 -0
- package/libs/instance-factories/applications/templates/react/api-types-generator.ts +153 -0
- package/libs/instance-factories/applications/templates/react/app-tsx-generator.ts +94 -0
- package/libs/instance-factories/applications/templates/react/env-example-generator.ts +24 -0
- package/libs/instance-factories/applications/templates/react/field-helpers-generator.ts +106 -0
- package/libs/instance-factories/applications/templates/react/gitignore-generator.ts +38 -0
- package/libs/instance-factories/applications/templates/react/index-css-generator.ts +85 -0
- package/libs/instance-factories/applications/templates/react/index-html-generator.ts +30 -0
- package/libs/instance-factories/applications/templates/react/main-tsx-generator.ts +34 -0
- package/libs/instance-factories/applications/templates/react/package-json-generator.ts +54 -0
- package/libs/instance-factories/applications/templates/react/pattern-adapter-generator.ts +179 -0
- package/libs/instance-factories/applications/templates/react/react-pattern-adapter.tsx +1347 -0
- package/libs/instance-factories/applications/templates/react/relationship-field-generator.ts +150 -0
- package/libs/instance-factories/applications/templates/react/tailwind-adapter-generator.ts +704 -0
- package/libs/instance-factories/applications/templates/react/tailwind-adapter-wrapper-generator.ts +84 -0
- package/libs/instance-factories/applications/templates/react/tsconfig-generator.ts +35 -0
- package/libs/instance-factories/applications/templates/react/use-api-hooks-generator.ts +121 -0
- package/libs/instance-factories/applications/templates/react/view-dashboard-generator.ts +150 -0
- package/libs/instance-factories/applications/templates/react/view-detail-generator.ts +150 -0
- package/libs/instance-factories/applications/templates/react/view-form-generator.ts +362 -0
- package/libs/instance-factories/applications/templates/react/view-list-generator.ts +98 -0
- package/libs/instance-factories/applications/templates/react/view-router-generator.ts +89 -0
- package/libs/instance-factories/applications/templates/react/vite-config-generator.ts +49 -0
- package/libs/instance-factories/archived/fastify-prisma.yaml +104 -0
- package/libs/instance-factories/cli/commander-js.yaml +55 -0
- package/libs/instance-factories/cli/templates/commander/cli-entry-generator.d.ts +12 -0
- package/libs/instance-factories/cli/templates/commander/cli-entry-generator.d.ts.map +1 -0
- package/libs/instance-factories/cli/templates/commander/cli-entry-generator.js +115 -0
- package/libs/instance-factories/cli/templates/commander/cli-entry-generator.js.map +1 -0
- package/libs/instance-factories/cli/templates/commander/cli-entry-generator.ts +145 -0
- package/libs/instance-factories/cli/templates/commander/command-generator.d.ts +14 -0
- package/libs/instance-factories/cli/templates/commander/command-generator.d.ts.map +1 -0
- package/libs/instance-factories/cli/templates/commander/command-generator.js +182 -0
- package/libs/instance-factories/cli/templates/commander/command-generator.js.map +1 -0
- package/libs/instance-factories/cli/templates/commander/command-generator.ts +992 -0
- package/libs/instance-factories/communication/event-emitter.yaml +56 -0
- package/libs/instance-factories/communication/rabbitmq-events.yaml +87 -0
- package/libs/instance-factories/communication/templates/eventemitter/bus-generator.ts +93 -0
- package/libs/instance-factories/communication/templates/eventemitter/publisher-generator.ts +117 -0
- package/libs/instance-factories/communication/templates/eventemitter/subscriber-generator.ts +101 -0
- package/libs/instance-factories/controllers/fastify.yaml +127 -0
- package/libs/instance-factories/controllers/templates/fastify/meta-routes-generator.ts +103 -0
- package/libs/instance-factories/controllers/templates/fastify/routes-generator.ts +389 -0
- package/libs/instance-factories/controllers/templates/fastify/server-generator.ts +76 -0
- package/libs/instance-factories/infrastructure/docker-k8s.yaml +61 -0
- package/libs/instance-factories/infrastructure/templates/docker-k8s/infrastructure-generator.ts +46 -0
- package/libs/instance-factories/orms/prisma.yaml +89 -0
- package/libs/instance-factories/orms/templates/prisma/schema-generator.ts +563 -0
- package/libs/instance-factories/orms/templates/prisma/services-generator.ts +408 -0
- package/libs/instance-factories/scaffolding/generic-scaffold.yaml +65 -0
- package/libs/instance-factories/scaffolding/templates/generic/env-example-generator.ts +73 -0
- package/libs/instance-factories/scaffolding/templates/generic/env-generator.ts +85 -0
- package/libs/instance-factories/scaffolding/templates/generic/gitignore-generator.ts +69 -0
- package/libs/instance-factories/scaffolding/templates/generic/package-json-generator.ts +176 -0
- package/libs/instance-factories/scaffolding/templates/generic/readme-generator.ts +207 -0
- package/libs/instance-factories/scaffolding/templates/generic/tsconfig-generator.ts +78 -0
- package/libs/instance-factories/scaffolding/templates/generic/tsconfig-react-generator.ts +41 -0
- package/libs/instance-factories/sdks/python-sdk.yaml +66 -0
- package/libs/instance-factories/sdks/templates/python/sdk-generator.ts +50 -0
- package/libs/instance-factories/sdks/templates/typescript/sdk-generator.ts +49 -0
- package/libs/instance-factories/sdks/typescript-sdk.yaml +59 -0
- package/libs/instance-factories/services/prisma-services.yaml +71 -0
- package/libs/instance-factories/services/templates/prisma/behavior-generator.ts +303 -0
- package/libs/instance-factories/services/templates/prisma/controller-generator.ts +532 -0
- package/libs/instance-factories/services/templates/prisma/service-generator.ts +315 -0
- package/libs/instance-factories/shared/path-resolver.ts +111 -0
- package/libs/instance-factories/storage/mongodb.yaml +79 -0
- package/libs/instance-factories/storage/postgresql.yaml +75 -0
- package/libs/instance-factories/storage/redis.yaml +79 -0
- package/libs/instance-factories/storage/templates/mongodb/config-generator.ts +15 -0
- package/libs/instance-factories/storage/templates/mongodb/docker-generator.ts +18 -0
- package/libs/instance-factories/storage/templates/postgresql/config-generator.ts +54 -0
- package/libs/instance-factories/storage/templates/postgresql/docker-generator.ts +55 -0
- package/libs/instance-factories/storage/templates/redis/config-generator.ts +16 -0
- package/libs/instance-factories/storage/templates/redis/docker-generator.ts +18 -0
- package/libs/instance-factories/test-generation.ts +192 -0
- package/libs/instance-factories/testing/templates/vitest/tests-generator.ts +51 -0
- package/libs/instance-factories/testing/vitest-tests.yaml +63 -0
- package/libs/instance-factories/tools/templates/mcp/mcp-server-generator.ts +136 -0
- package/libs/instance-factories/tools/templates/mcp/static/docs/DEPLOYMENT_GUIDE.md +630 -0
- package/libs/instance-factories/tools/templates/mcp/static/docs/HYBRID_RESOURCE_SYSTEM.md +330 -0
- package/libs/instance-factories/tools/templates/mcp/static/docs/deployments/EXTENSION_DEPLOYMENT.md +552 -0
- package/libs/instance-factories/tools/templates/mcp/static/docs/deployments/LOCAL_DEPLOYMENT.md +164 -0
- package/libs/instance-factories/tools/templates/mcp/static/docs/deployments/WEB_DEPLOYMENT.md +247 -0
- package/libs/instance-factories/tools/templates/mcp/static/package.json +92 -0
- package/libs/instance-factories/tools/templates/mcp/static/scripts/build-enterprise.js +284 -0
- package/libs/instance-factories/tools/templates/mcp/static/scripts/build-extension.js +139 -0
- package/libs/instance-factories/tools/templates/mcp/static/scripts/build-local.js +74 -0
- package/libs/instance-factories/tools/templates/mcp/static/scripts/build-web.js +156 -0
- package/libs/instance-factories/tools/templates/mcp/static/scripts/copy-canonical-files.js +41 -0
- package/libs/instance-factories/tools/templates/mcp/static/scripts/test-deployments.js +259 -0
- package/libs/instance-factories/tools/templates/mcp/static/scripts/test-hybrid-resources.js +231 -0
- package/libs/instance-factories/tools/templates/mcp/static/scripts/test-hybrid-simple.js +196 -0
- package/libs/instance-factories/tools/templates/mcp/static/src/controllers/MCPServerController.ts +293 -0
- package/libs/instance-factories/tools/templates/mcp/static/src/events/EventEmitter.ts +90 -0
- package/libs/instance-factories/tools/templates/mcp/static/src/index.ts +24 -0
- package/libs/instance-factories/tools/templates/mcp/static/src/interfaces/ResourceProvider.ts +15 -0
- package/libs/instance-factories/tools/templates/mcp/static/src/models/LibrarySuggestion.ts +106 -0
- package/libs/instance-factories/tools/templates/mcp/static/src/models/SpecVerseResource.ts +75 -0
- package/libs/instance-factories/tools/templates/mcp/static/src/server/mcp-server.ts +239 -0
- package/libs/instance-factories/tools/templates/mcp/static/src/services/CLIProxyService.ts +1501 -0
- package/libs/instance-factories/tools/templates/mcp/static/src/services/EmbeddedResourcesAdapter.ts +211 -0
- package/libs/instance-factories/tools/templates/mcp/static/src/services/EntityModuleService.ts +308 -0
- package/libs/instance-factories/tools/templates/mcp/static/src/services/HybridResourcesProvider.ts +210 -0
- package/libs/instance-factories/tools/templates/mcp/static/src/services/LibraryToolsService.ts +356 -0
- package/libs/instance-factories/tools/templates/mcp/static/src/services/OrchestratorBridge.ts +524 -0
- package/libs/instance-factories/tools/templates/mcp/static/src/services/OrchestratorToolsService.ts +530 -0
- package/libs/instance-factories/tools/templates/mcp/static/src/services/PromptToolsService.ts +594 -0
- package/libs/instance-factories/tools/templates/mcp/static/src/services/ResourcesProviderService.ts +170 -0
- package/libs/instance-factories/tools/templates/mcp/static/src/tests/unit/CLIProxyService.init.test.ts +544 -0
- package/libs/instance-factories/tools/templates/mcp/static/src/tests/unit/CLIProxyService.test.ts +189 -0
- package/libs/instance-factories/tools/templates/mcp/static/src/tests/unit/ResourcesProviderService.test.ts +89 -0
- package/libs/instance-factories/tools/templates/mcp/static/src/types/index.ts +110 -0
- package/libs/instance-factories/tools/templates/mcp/static/tsconfig.json +28 -0
- package/libs/instance-factories/tools/templates/vscode/static/extension.ts +1195 -0
- package/libs/instance-factories/tools/templates/vscode/static/language-configuration.json +34 -0
- package/libs/instance-factories/tools/templates/vscode/static/schemas/specverse-v3-schema.json +4279 -0
- package/libs/instance-factories/tools/templates/vscode/static/syntaxes/specverse.tmLanguage.json +138 -0
- package/libs/instance-factories/tools/templates/vscode/static/themes/README.md +74 -0
- package/libs/instance-factories/tools/templates/vscode/static/themes/complete-specverse-colors.json +122 -0
- package/libs/instance-factories/tools/templates/vscode/static/themes/specverse-basic-theme.json +65 -0
- package/libs/instance-factories/tools/templates/vscode/static/themes/specverse-complete-theme.json +123 -0
- package/libs/instance-factories/tools/templates/vscode/static/themes/specverse-theme-colors.json +64 -0
- package/libs/instance-factories/tools/templates/vscode/vscode-extension-generator.ts +214 -0
- package/libs/instance-factories/validation/templates/zod/validation-generator.ts +46 -0
- package/libs/instance-factories/validation/zod.yaml +56 -0
- package/libs/instance-factories/views/index.d.ts +13 -0
- package/libs/instance-factories/views/index.d.ts.map +1 -0
- package/libs/instance-factories/views/index.js +18 -0
- package/libs/instance-factories/views/index.js.map +1 -0
- package/libs/instance-factories/views/index.ts +45 -0
- package/libs/instance-factories/views/react-components.yaml +129 -0
- package/libs/instance-factories/views/templates/ARCHITECTURE.md +198 -0
- package/libs/instance-factories/views/templates/react/adapters/antd-adapter.ts +869 -0
- package/libs/instance-factories/views/templates/react/adapters/mui-adapter.ts +953 -0
- package/libs/instance-factories/views/templates/react/adapters/shadcn-adapter.ts +806 -0
- package/libs/instance-factories/views/templates/react/app-generator.ts +55 -0
- package/libs/instance-factories/views/templates/react/components-generator.ts +391 -0
- package/libs/instance-factories/views/templates/react/forms-generator.ts +343 -0
- package/libs/instance-factories/views/templates/react/frontend-package-json-generator.ts +54 -0
- package/libs/instance-factories/views/templates/react/hooks-generator.ts +122 -0
- package/libs/instance-factories/views/templates/react/index-css-generator.ts +209 -0
- package/libs/instance-factories/views/templates/react/index-html-generator.ts +34 -0
- package/libs/instance-factories/views/templates/react/main-tsx-generator.ts +29 -0
- package/libs/instance-factories/views/templates/react/react-component-generator.d.ts +152 -0
- package/libs/instance-factories/views/templates/react/react-component-generator.d.ts.map +1 -0
- package/libs/instance-factories/views/templates/react/react-component-generator.js +398 -0
- package/libs/instance-factories/views/templates/react/react-component-generator.js.map +1 -0
- package/libs/instance-factories/views/templates/react/react-component-generator.ts +533 -0
- package/libs/instance-factories/views/templates/react/router-generator.ts +197 -0
- package/libs/instance-factories/views/templates/react/router-generic-generator.ts +103 -0
- package/libs/instance-factories/views/templates/react/spec-json-generator.ts +17 -0
- package/libs/instance-factories/views/templates/react/types-generator.ts +76 -0
- package/libs/instance-factories/views/templates/react/views-metadata-generator.ts +42 -0
- package/libs/instance-factories/views/templates/react/vite-config-generator.ts +38 -0
- package/libs/instance-factories/views/templates/runtime/runtime-view-renderer.d.ts.map +1 -0
- package/libs/instance-factories/views/templates/runtime/runtime-view-renderer.js.map +1 -0
- package/libs/instance-factories/views/templates/runtime/runtime-view-renderer.ts +474 -0
- package/libs/instance-factories/views/templates/shared/__tests__/composite-patterns.test.ts +242 -0
- package/libs/instance-factories/views/templates/shared/adapter-types.d.ts +77 -0
- package/libs/instance-factories/views/templates/shared/adapter-types.d.ts.map +1 -0
- package/libs/instance-factories/views/templates/shared/adapter-types.js +47 -0
- package/libs/instance-factories/views/templates/shared/adapter-types.js.map +1 -0
- package/libs/instance-factories/views/templates/shared/adapter-types.ts +142 -0
- package/libs/instance-factories/views/templates/shared/atomic-components-registry.d.ts +63 -0
- package/libs/instance-factories/views/templates/shared/atomic-components-registry.d.ts.map +1 -0
- package/libs/instance-factories/views/templates/shared/atomic-components-registry.js +822 -0
- package/libs/instance-factories/views/templates/shared/atomic-components-registry.js.map +1 -0
- package/libs/instance-factories/views/templates/shared/atomic-components-registry.ts +908 -0
- package/libs/instance-factories/views/templates/shared/base-generator.d.ts +247 -0
- package/libs/instance-factories/views/templates/shared/base-generator.d.ts.map +1 -0
- package/libs/instance-factories/views/templates/shared/base-generator.js +363 -0
- package/libs/instance-factories/views/templates/shared/base-generator.js.map +1 -0
- package/libs/instance-factories/views/templates/shared/base-generator.ts +608 -0
- package/libs/instance-factories/views/templates/shared/component-metadata.d.ts +254 -0
- package/libs/instance-factories/views/templates/shared/component-metadata.d.ts.map +1 -0
- package/libs/instance-factories/views/templates/shared/component-metadata.js +602 -0
- package/libs/instance-factories/views/templates/shared/component-metadata.js.map +1 -0
- package/libs/instance-factories/views/templates/shared/component-metadata.ts +803 -0
- package/libs/instance-factories/views/templates/shared/composite-pattern-types.ts +250 -0
- package/libs/instance-factories/views/templates/shared/composite-patterns.ts +535 -0
- package/libs/instance-factories/views/templates/shared/index.ts +68 -0
- package/libs/instance-factories/views/templates/shared/pattern-validator.ts +279 -0
- package/libs/instance-factories/views/templates/shared/property-mapper.d.ts +149 -0
- package/libs/instance-factories/views/templates/shared/property-mapper.d.ts.map +1 -0
- package/libs/instance-factories/views/templates/shared/property-mapper.js +580 -0
- package/libs/instance-factories/views/templates/shared/property-mapper.js.map +1 -0
- package/libs/instance-factories/views/templates/shared/property-mapper.ts +700 -0
- package/libs/instance-factories/views/templates/shared/syntax-mapper.d.ts +143 -0
- package/libs/instance-factories/views/templates/shared/syntax-mapper.d.ts.map +1 -0
- package/libs/instance-factories/views/templates/shared/syntax-mapper.js +420 -0
- package/libs/instance-factories/views/templates/shared/syntax-mapper.js.map +1 -0
- package/libs/instance-factories/views/templates/shared/syntax-mapper.ts +539 -0
- package/package.json +42 -0
- package/schema/SPECVERSE-SCHEMA.json +4274 -0
|
@@ -0,0 +1,362 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* FormView Generator
|
|
3
|
+
* Generates local FormView component that uses local hooks with instance-factory-specific API client
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
export interface ViewFormGeneratorContext {
|
|
7
|
+
spec: any;
|
|
8
|
+
manifest: any;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
export async function generate(context: ViewFormGeneratorContext): Promise<string> {
|
|
12
|
+
return `/**
|
|
13
|
+
* StandardFormView - Controller-Based Form View Component
|
|
14
|
+
*
|
|
15
|
+
* LOCAL VERSION - Uses local hooks with instance-factory-specific API client
|
|
16
|
+
*
|
|
17
|
+
* Supports both Create and Edit modes with:
|
|
18
|
+
* - Controller-driven form generation
|
|
19
|
+
* - Smart input types (text, number, boolean, relationship selectors)
|
|
20
|
+
* - Auto-generated field detection
|
|
21
|
+
* - Validation and error handling
|
|
22
|
+
* - Lifecycle management (Edit/Evolve tabs)
|
|
23
|
+
* - Foreign key relationship fields
|
|
24
|
+
* - Two-panel layout (form + entity list)
|
|
25
|
+
*/
|
|
26
|
+
|
|
27
|
+
import { useState, useEffect } from 'react';
|
|
28
|
+
import { useEntitiesQuery, useModelSchemaQuery, useExecuteOperationMutation, useTransitionStateMutation } from '../../hooks/useApi';
|
|
29
|
+
import { isAutoGeneratedField, isFieldRequired, initializeFormData } from '../../utils/field-helpers';
|
|
30
|
+
import { RelationshipField } from '../../components/fields/RelationshipField';
|
|
31
|
+
import type { View, Entity } from '../../types/api';
|
|
32
|
+
|
|
33
|
+
type FormMode = 'create' | 'update';
|
|
34
|
+
type ActiveTab = 'edit' | 'evolve';
|
|
35
|
+
|
|
36
|
+
interface StandardFormViewProps {
|
|
37
|
+
view: View;
|
|
38
|
+
spec?: any; // Full spec for controller access
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
export function FormView({ view, spec }: StandardFormViewProps) {
|
|
42
|
+
// Determine controller and model
|
|
43
|
+
let controllerName: string;
|
|
44
|
+
let modelName: string;
|
|
45
|
+
|
|
46
|
+
if (view.controller && spec) {
|
|
47
|
+
// New: Controller-based
|
|
48
|
+
controllerName = view.controller;
|
|
49
|
+
const controller = spec.controllers[view.controller];
|
|
50
|
+
modelName = controller.model;
|
|
51
|
+
} else {
|
|
52
|
+
// Legacy: Model-based
|
|
53
|
+
modelName = view.model as string;
|
|
54
|
+
controllerName = \`\${modelName}Controller\`;
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
const [selectedEntity, setSelectedEntity] = useState<Entity | null>(null);
|
|
58
|
+
const [formMode, setFormMode] = useState<FormMode>('create');
|
|
59
|
+
const [activeTab, setActiveTab] = useState<ActiveTab>('edit');
|
|
60
|
+
const [formData, setFormData] = useState<Record<string, any>>({});
|
|
61
|
+
const [errors, setErrors] = useState<Record<string, string>>({});
|
|
62
|
+
const [selectedLifecycleStates, setSelectedLifecycleStates] = useState<Record<string, string>>({});
|
|
63
|
+
|
|
64
|
+
// Fetch entities and schema - USES LOCAL HOOKS
|
|
65
|
+
const { data: entities = [], isLoading: entitiesLoading } = useEntitiesQuery(controllerName, modelName);
|
|
66
|
+
const { data: schema } = useModelSchemaQuery(modelName);
|
|
67
|
+
const { mutate: executeOperation, isPending } = useExecuteOperationMutation();
|
|
68
|
+
const { mutate: transitionState, isPending: isTransitioning } = useTransitionStateMutation();
|
|
69
|
+
|
|
70
|
+
const attributes = schema?.attributes || {};
|
|
71
|
+
const relationships = schema?.relationships || {};
|
|
72
|
+
const lifecycles = schema?.lifecycles || {};
|
|
73
|
+
|
|
74
|
+
// Sync selected entity with updated entities list
|
|
75
|
+
useEffect(() => {
|
|
76
|
+
if (selectedEntity && entities.length > 0) {
|
|
77
|
+
const updatedEntity = entities.find((e) => e.id === selectedEntity.id);
|
|
78
|
+
if (updatedEntity) {
|
|
79
|
+
const oldStates = JSON.stringify(selectedEntity.metadata?.lifecycleStates || {});
|
|
80
|
+
const newStates = JSON.stringify(updatedEntity.metadata?.lifecycleStates || {});
|
|
81
|
+
|
|
82
|
+
if (oldStates !== newStates) {
|
|
83
|
+
setSelectedEntity(updatedEntity);
|
|
84
|
+
setSelectedLifecycleStates({ ...(updatedEntity.metadata?.lifecycleStates || {}) });
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
}, [entities, selectedEntity?.id]);
|
|
89
|
+
|
|
90
|
+
// Initialize form data when schema changes or when switching modes
|
|
91
|
+
useEffect(() => {
|
|
92
|
+
if (selectedEntity && formMode === 'update') {
|
|
93
|
+
setFormData({ ...selectedEntity.data });
|
|
94
|
+
const currentStates = selectedEntity.metadata?.lifecycleStates || {};
|
|
95
|
+
setSelectedLifecycleStates({ ...currentStates });
|
|
96
|
+
} else if (schema?.attributes) {
|
|
97
|
+
setFormData(initializeFormData(schema.attributes, { includeAutoGenerated: false }));
|
|
98
|
+
setSelectedLifecycleStates({});
|
|
99
|
+
}
|
|
100
|
+
}, [selectedEntity, formMode, schema]);
|
|
101
|
+
|
|
102
|
+
// Check if field should be shown
|
|
103
|
+
const shouldShowField = (attrName: string, attrDef: any): boolean => {
|
|
104
|
+
const isAuto = isAutoGeneratedField(attrName, attrDef);
|
|
105
|
+
// In create mode, hide auto-generated fields
|
|
106
|
+
if (formMode === 'create' && isAuto) {
|
|
107
|
+
return false;
|
|
108
|
+
}
|
|
109
|
+
// In update mode, show all fields
|
|
110
|
+
return true;
|
|
111
|
+
};
|
|
112
|
+
|
|
113
|
+
// Handle form submission
|
|
114
|
+
const handleSubmit = async (e: React.FormEvent) => {
|
|
115
|
+
e.preventDefault();
|
|
116
|
+
setErrors({});
|
|
117
|
+
|
|
118
|
+
const operation = formMode === 'create' ? 'create' : 'update';
|
|
119
|
+
const params = formMode === 'update' && selectedEntity
|
|
120
|
+
? { ...formData, id: selectedEntity.id }
|
|
121
|
+
: formData;
|
|
122
|
+
|
|
123
|
+
executeOperation(
|
|
124
|
+
{ controllerName, operationName: operation, params },
|
|
125
|
+
{
|
|
126
|
+
onSuccess: () => {
|
|
127
|
+
if (formMode === 'create' && schema?.attributes) {
|
|
128
|
+
setFormData(initializeFormData(schema.attributes, { includeAutoGenerated: false }));
|
|
129
|
+
}
|
|
130
|
+
setFormMode('create');
|
|
131
|
+
setSelectedEntity(null);
|
|
132
|
+
},
|
|
133
|
+
onError: (error: any) => {
|
|
134
|
+
setErrors({ _form: error.message || 'Operation failed' });
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
);
|
|
138
|
+
};
|
|
139
|
+
|
|
140
|
+
// Handle entity selection for editing
|
|
141
|
+
const handleEntitySelect = (entity: Entity) => {
|
|
142
|
+
setSelectedEntity(entity);
|
|
143
|
+
setFormMode('update');
|
|
144
|
+
setActiveTab('edit');
|
|
145
|
+
};
|
|
146
|
+
|
|
147
|
+
// Handle lifecycle state transition
|
|
148
|
+
const handleLifecycleTransition = (lifecycleName: string, toState: string) => {
|
|
149
|
+
if (!selectedEntity) return;
|
|
150
|
+
|
|
151
|
+
transitionState(
|
|
152
|
+
{ modelName, entityId: selectedEntity.id, toState, lifecycleName },
|
|
153
|
+
{
|
|
154
|
+
onSuccess: () => {
|
|
155
|
+
setSelectedLifecycleStates((prev) => ({ ...prev, [lifecycleName]: toState }));
|
|
156
|
+
},
|
|
157
|
+
onError: (error: any) => {
|
|
158
|
+
setErrors({ _lifecycle: error.message || 'Transition failed' });
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
);
|
|
162
|
+
};
|
|
163
|
+
|
|
164
|
+
// Render field input
|
|
165
|
+
const renderFieldInput = (attrName: string, attrDef: any) => {
|
|
166
|
+
const value = formData[attrName] ?? '';
|
|
167
|
+
const isRequired = isFieldRequired(attrDef);
|
|
168
|
+
|
|
169
|
+
const handleChange = (newValue: any) => {
|
|
170
|
+
setFormData((prev) => ({ ...prev, [attrName]: newValue }));
|
|
171
|
+
};
|
|
172
|
+
|
|
173
|
+
// Boolean field
|
|
174
|
+
if (attrDef.type === 'Boolean') {
|
|
175
|
+
return (
|
|
176
|
+
<input
|
|
177
|
+
type="checkbox"
|
|
178
|
+
checked={!!value}
|
|
179
|
+
onChange={(e) => handleChange(e.target.checked)}
|
|
180
|
+
className="h-4 w-4 rounded border-gray-300"
|
|
181
|
+
/>
|
|
182
|
+
);
|
|
183
|
+
}
|
|
184
|
+
|
|
185
|
+
// Number field
|
|
186
|
+
if (attrDef.type === 'Integer' || attrDef.type === 'Float' || attrDef.type === 'Decimal') {
|
|
187
|
+
return (
|
|
188
|
+
<input
|
|
189
|
+
type="number"
|
|
190
|
+
value={value}
|
|
191
|
+
onChange={(e) => handleChange(e.target.value ? Number(e.target.value) : '')}
|
|
192
|
+
required={isRequired}
|
|
193
|
+
className="block w-full rounded-md border-gray-300 shadow-sm focus:border-blue-500 focus:ring-blue-500"
|
|
194
|
+
/>
|
|
195
|
+
);
|
|
196
|
+
}
|
|
197
|
+
|
|
198
|
+
// Text field (default)
|
|
199
|
+
return (
|
|
200
|
+
<input
|
|
201
|
+
type="text"
|
|
202
|
+
value={value}
|
|
203
|
+
onChange={(e) => handleChange(e.target.value)}
|
|
204
|
+
required={isRequired}
|
|
205
|
+
className="block w-full rounded-md border-gray-300 shadow-sm focus:border-blue-500 focus:ring-blue-500"
|
|
206
|
+
/>
|
|
207
|
+
);
|
|
208
|
+
};
|
|
209
|
+
|
|
210
|
+
return (
|
|
211
|
+
<div className="flex gap-4 h-full">
|
|
212
|
+
{/* Form Panel */}
|
|
213
|
+
<div className="flex-1 bg-white dark:bg-gray-800 rounded-lg shadow p-6">
|
|
214
|
+
<h2 className="text-2xl font-bold mb-4 text-gray-800 dark:text-white">
|
|
215
|
+
{formMode === 'create' ? \`Create \${modelName}\` : \`Edit \${modelName}\`}
|
|
216
|
+
</h2>
|
|
217
|
+
|
|
218
|
+
{/* Tabs for Edit/Evolve modes */}
|
|
219
|
+
{formMode === 'update' && Object.keys(lifecycles).length > 0 && (
|
|
220
|
+
<div className="flex gap-2 mb-4 border-b border-gray-200">
|
|
221
|
+
<button
|
|
222
|
+
onClick={() => setActiveTab('edit')}
|
|
223
|
+
className={\`px-4 py-2 font-medium \${activeTab === 'edit' ? 'border-b-2 border-blue-500 text-blue-600' : 'text-gray-500'}\`}
|
|
224
|
+
>
|
|
225
|
+
Edit Data
|
|
226
|
+
</button>
|
|
227
|
+
<button
|
|
228
|
+
onClick={() => setActiveTab('evolve')}
|
|
229
|
+
className={\`px-4 py-2 font-medium \${activeTab === 'evolve' ? 'border-b-2 border-blue-500 text-blue-600' : 'text-gray-500'}\`}
|
|
230
|
+
>
|
|
231
|
+
Lifecycle
|
|
232
|
+
</button>
|
|
233
|
+
</div>
|
|
234
|
+
)}
|
|
235
|
+
|
|
236
|
+
{activeTab === 'edit' ? (
|
|
237
|
+
<form onSubmit={handleSubmit} className="space-y-4">
|
|
238
|
+
{errors._form && (
|
|
239
|
+
<div className="p-3 bg-red-100 text-red-700 rounded-md">{errors._form}</div>
|
|
240
|
+
)}
|
|
241
|
+
|
|
242
|
+
{/* Attributes */}
|
|
243
|
+
{Object.entries(attributes).map(([attrName, attrDef]: [string, any]) => {
|
|
244
|
+
if (!shouldShowField(attrName, attrDef)) return null;
|
|
245
|
+
|
|
246
|
+
return (
|
|
247
|
+
<div key={attrName}>
|
|
248
|
+
<label className="block text-sm font-medium text-gray-700 dark:text-gray-300 mb-1">
|
|
249
|
+
{attrName}
|
|
250
|
+
{isFieldRequired(attrDef) && <span className="text-red-500">*</span>}
|
|
251
|
+
</label>
|
|
252
|
+
{renderFieldInput(attrName, attrDef)}
|
|
253
|
+
</div>
|
|
254
|
+
);
|
|
255
|
+
})}
|
|
256
|
+
|
|
257
|
+
{/* Relationships */}
|
|
258
|
+
{Object.entries(relationships).map(([relName, relDef]: [string, any]) => (
|
|
259
|
+
<RelationshipField
|
|
260
|
+
key={relName}
|
|
261
|
+
name={relName}
|
|
262
|
+
relationship={relDef}
|
|
263
|
+
value={formData[relName]}
|
|
264
|
+
onChange={(value) => setFormData((prev) => ({ ...prev, [relName]: value }))}
|
|
265
|
+
/>
|
|
266
|
+
))}
|
|
267
|
+
|
|
268
|
+
<div className="flex gap-2 pt-4">
|
|
269
|
+
<button
|
|
270
|
+
type="submit"
|
|
271
|
+
disabled={isPending}
|
|
272
|
+
className="px-4 py-2 bg-blue-600 text-white rounded-md hover:bg-blue-700 disabled:opacity-50"
|
|
273
|
+
>
|
|
274
|
+
{isPending ? 'Saving...' : formMode === 'create' ? 'Create' : 'Update'}
|
|
275
|
+
</button>
|
|
276
|
+
{formMode === 'update' && (
|
|
277
|
+
<button
|
|
278
|
+
type="button"
|
|
279
|
+
onClick={() => {
|
|
280
|
+
setFormMode('create');
|
|
281
|
+
setSelectedEntity(null);
|
|
282
|
+
if (schema?.attributes) {
|
|
283
|
+
setFormData(initializeFormData(schema.attributes, { includeAutoGenerated: false }));
|
|
284
|
+
}
|
|
285
|
+
}}
|
|
286
|
+
className="px-4 py-2 bg-gray-500 text-white rounded-md hover:bg-gray-600"
|
|
287
|
+
>
|
|
288
|
+
Cancel
|
|
289
|
+
</button>
|
|
290
|
+
)}
|
|
291
|
+
</div>
|
|
292
|
+
</form>
|
|
293
|
+
) : (
|
|
294
|
+
/* Lifecycle Tab */
|
|
295
|
+
<div className="space-y-4">
|
|
296
|
+
{errors._lifecycle && (
|
|
297
|
+
<div className="p-3 bg-red-100 text-red-700 rounded-md">{errors._lifecycle}</div>
|
|
298
|
+
)}
|
|
299
|
+
|
|
300
|
+
{Object.entries(lifecycles).map(([lifecycleName, lifecycle]: [string, any]) => {
|
|
301
|
+
const currentState = selectedLifecycleStates[lifecycleName] || lifecycle.initial;
|
|
302
|
+
|
|
303
|
+
return (
|
|
304
|
+
<div key={lifecycleName} className="border border-gray-200 rounded-lg p-4">
|
|
305
|
+
<h3 className="font-semibold text-lg mb-2">{lifecycleName}</h3>
|
|
306
|
+
<p className="text-sm text-gray-600 mb-3">Current: {currentState}</p>
|
|
307
|
+
|
|
308
|
+
<div className="flex flex-wrap gap-2">
|
|
309
|
+
{Object.keys(lifecycle.states || {}).map((state) => (
|
|
310
|
+
<button
|
|
311
|
+
key={state}
|
|
312
|
+
onClick={() => handleLifecycleTransition(lifecycleName, state)}
|
|
313
|
+
disabled={isTransitioning || state === currentState}
|
|
314
|
+
className={\`px-3 py-1 rounded-md \${state === currentState ? 'bg-blue-600 text-white' : 'bg-gray-200 text-gray-700 hover:bg-gray-300'} disabled:opacity-50\`}
|
|
315
|
+
>
|
|
316
|
+
{state}
|
|
317
|
+
</button>
|
|
318
|
+
))}
|
|
319
|
+
</div>
|
|
320
|
+
</div>
|
|
321
|
+
);
|
|
322
|
+
})}
|
|
323
|
+
</div>
|
|
324
|
+
)}
|
|
325
|
+
</div>
|
|
326
|
+
|
|
327
|
+
{/* Entity List Panel */}
|
|
328
|
+
<div className="w-80 bg-white dark:bg-gray-800 rounded-lg shadow p-4">
|
|
329
|
+
<h3 className="text-lg font-semibold mb-3 text-gray-800 dark:text-white">
|
|
330
|
+
{modelName} List
|
|
331
|
+
</h3>
|
|
332
|
+
|
|
333
|
+
{entitiesLoading ? (
|
|
334
|
+
<p className="text-gray-500">Loading...</p>
|
|
335
|
+
) : entities.length === 0 ? (
|
|
336
|
+
<p className="text-gray-500 italic">No entities yet</p>
|
|
337
|
+
) : (
|
|
338
|
+
<div className="space-y-2">
|
|
339
|
+
{entities.map((entity) => (
|
|
340
|
+
<div
|
|
341
|
+
key={entity.id}
|
|
342
|
+
onClick={() => handleEntitySelect(entity)}
|
|
343
|
+
className={\`p-3 rounded-md cursor-pointer \${selectedEntity?.id === entity.id ? 'bg-blue-100 border-blue-500' : 'bg-gray-50 hover:bg-gray-100'} border\`}
|
|
344
|
+
>
|
|
345
|
+
<p className="font-medium text-sm">{entity.id}</p>
|
|
346
|
+
{Object.entries(entity.data).slice(0, 2).map(([key, value]) => (
|
|
347
|
+
<p key={key} className="text-xs text-gray-600">
|
|
348
|
+
{key}: {String(value)}
|
|
349
|
+
</p>
|
|
350
|
+
))}
|
|
351
|
+
</div>
|
|
352
|
+
))}
|
|
353
|
+
</div>
|
|
354
|
+
)}
|
|
355
|
+
</div>
|
|
356
|
+
</div>
|
|
357
|
+
);
|
|
358
|
+
}
|
|
359
|
+
|
|
360
|
+
export default FormView;
|
|
361
|
+
`;
|
|
362
|
+
}
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ListView Generator (Pattern-Based v0.9.0)
|
|
3
|
+
* Generates pattern-based ListView using RuntimeView architecture
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
export interface ViewListGeneratorContext {
|
|
7
|
+
spec: any;
|
|
8
|
+
manifest: any;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
export async function generate(context: ViewListGeneratorContext): Promise<string> {
|
|
12
|
+
return `/**
|
|
13
|
+
* ListView - Pattern-Based List View Component
|
|
14
|
+
*
|
|
15
|
+
* Uses pattern-based rendering with ReactPatternAdapter.
|
|
16
|
+
* Reads from modelSchemas for schema-driven field generation.
|
|
17
|
+
*/
|
|
18
|
+
|
|
19
|
+
import { useMemo } from 'react';
|
|
20
|
+
import { useEntitiesQuery, useModelSchemaQuery } from '../../hooks/useApi';
|
|
21
|
+
import { usePatternAdapter, REACT_PROTOCOL_MAPPING } from '../../lib/react-pattern-adapter';
|
|
22
|
+
import type { View } from '../../types/api';
|
|
23
|
+
|
|
24
|
+
interface ListViewProps {
|
|
25
|
+
view: View;
|
|
26
|
+
spec?: any;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
export function ListView({ view, spec }: ListViewProps) {
|
|
30
|
+
const patternAdapter = usePatternAdapter();
|
|
31
|
+
|
|
32
|
+
// Determine controller and model
|
|
33
|
+
let controllerName: string;
|
|
34
|
+
let modelName: string;
|
|
35
|
+
|
|
36
|
+
if (view.controller && spec) {
|
|
37
|
+
controllerName = view.controller;
|
|
38
|
+
const controller = spec.controllers[view.controller];
|
|
39
|
+
modelName = controller.model;
|
|
40
|
+
} else {
|
|
41
|
+
modelName = view.model as string;
|
|
42
|
+
controllerName = \`\${modelName}Controller\`;
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
// Fetch data and schema
|
|
46
|
+
const { data: entities = [], isLoading } = useEntitiesQuery(controllerName, modelName);
|
|
47
|
+
const { data: schema } = useModelSchemaQuery(modelName);
|
|
48
|
+
|
|
49
|
+
// Build model data and schemas
|
|
50
|
+
const modelData = useMemo(() => ({
|
|
51
|
+
[modelName]: entities
|
|
52
|
+
}), [modelName, entities]);
|
|
53
|
+
|
|
54
|
+
const modelSchemas = useMemo(() =>
|
|
55
|
+
schema ? { [modelName]: schema } : {}
|
|
56
|
+
, [modelName, schema]);
|
|
57
|
+
|
|
58
|
+
if (isLoading) {
|
|
59
|
+
return <div className="p-4">Loading...</div>;
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
// Detect pattern
|
|
63
|
+
const pattern = patternAdapter.detectPattern({ ...view, type: 'list' });
|
|
64
|
+
|
|
65
|
+
if (!pattern) {
|
|
66
|
+
return (
|
|
67
|
+
<div className="p-4 text-red-600">
|
|
68
|
+
Pattern not found for list view
|
|
69
|
+
</div>
|
|
70
|
+
);
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
// Build render context
|
|
74
|
+
const context = {
|
|
75
|
+
pattern,
|
|
76
|
+
viewSpec: { ...view, type: 'list', model: modelName },
|
|
77
|
+
modelData,
|
|
78
|
+
modelSchemas,
|
|
79
|
+
primaryModel: modelName,
|
|
80
|
+
selectedEntity: null,
|
|
81
|
+
primaryEntities: entities,
|
|
82
|
+
protocolMapping: REACT_PROTOCOL_MAPPING,
|
|
83
|
+
tailwindAdapter: patternAdapter['tailwindAdapter']
|
|
84
|
+
};
|
|
85
|
+
|
|
86
|
+
// Render pattern
|
|
87
|
+
const html = patternAdapter.renderPattern(context);
|
|
88
|
+
|
|
89
|
+
return (
|
|
90
|
+
<div className="runtime-view-container p-4 h-full overflow-auto">
|
|
91
|
+
<div dangerouslySetInnerHTML={{ __html: html }} />
|
|
92
|
+
</div>
|
|
93
|
+
);
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
export default ListView;
|
|
97
|
+
`;
|
|
98
|
+
}
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* View Router Generator (Hybrid v0.9.0)
|
|
3
|
+
*
|
|
4
|
+
* Generates ViewRouter with hybrid routing:
|
|
5
|
+
* - Forms → FormView (controller-based with React hooks)
|
|
6
|
+
* - Display views → Pattern-based rendering
|
|
7
|
+
*/
|
|
8
|
+
|
|
9
|
+
export interface ViewRouterGeneratorContext {
|
|
10
|
+
spec: any;
|
|
11
|
+
manifest: any;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export async function generate(context: ViewRouterGeneratorContext): Promise<string> {
|
|
15
|
+
return `/**
|
|
16
|
+
* ViewRouter - Hybrid View Router
|
|
17
|
+
*
|
|
18
|
+
* Pattern-Based Rendering Architecture:
|
|
19
|
+
* - Forms (interactive) → FormView (controller-based with React hooks)
|
|
20
|
+
* - Display views → Pattern-based rendering (list, detail, dashboard)
|
|
21
|
+
*
|
|
22
|
+
* Benefits:
|
|
23
|
+
* - Forms get React hooks, state management, UUID handling
|
|
24
|
+
* - Display views get schema-driven pattern rendering
|
|
25
|
+
* - Both approaches coexist seamlessly
|
|
26
|
+
*/
|
|
27
|
+
|
|
28
|
+
import type { View } from '../../types/api';
|
|
29
|
+
import { FormView } from './FormView';
|
|
30
|
+
import { ListView } from './ListView';
|
|
31
|
+
import { DetailView } from './DetailView';
|
|
32
|
+
import { DashboardView } from './DashboardView';
|
|
33
|
+
|
|
34
|
+
interface ViewRouterProps {
|
|
35
|
+
view: View;
|
|
36
|
+
spec?: any; // Full spec for controller access
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
export function ViewRouter({ view, spec }: ViewRouterProps) {
|
|
40
|
+
const viewType = view.type?.toLowerCase();
|
|
41
|
+
|
|
42
|
+
// Determine rendering strategy
|
|
43
|
+
const useFormRenderer = (type: string): boolean => {
|
|
44
|
+
// Forms require React hooks and state - use FormView (controller-based)
|
|
45
|
+
const interactiveTypes = ['form', 'create', 'edit', 'create-form', 'edit-form'];
|
|
46
|
+
return interactiveTypes.includes(type);
|
|
47
|
+
};
|
|
48
|
+
|
|
49
|
+
// Route to appropriate renderer
|
|
50
|
+
if (useFormRenderer(viewType)) {
|
|
51
|
+
// Controller-based form with React hooks
|
|
52
|
+
return <FormView view={view} spec={spec} />;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
// Pattern-based rendering for display views
|
|
56
|
+
switch (viewType) {
|
|
57
|
+
case 'list':
|
|
58
|
+
case 'table':
|
|
59
|
+
return <ListView view={view} spec={spec} />;
|
|
60
|
+
|
|
61
|
+
case 'detail':
|
|
62
|
+
case 'master-detail':
|
|
63
|
+
return <DetailView view={view} spec={spec} />;
|
|
64
|
+
|
|
65
|
+
case 'dashboard':
|
|
66
|
+
return <DashboardView view={view} spec={spec} />;
|
|
67
|
+
|
|
68
|
+
default:
|
|
69
|
+
return (
|
|
70
|
+
<div className="flex items-center justify-center h-full p-8">
|
|
71
|
+
<div className="text-center">
|
|
72
|
+
<h3 className="text-lg font-semibold text-gray-800 dark:text-gray-100 mb-2">
|
|
73
|
+
Unknown View Type: {view.type}
|
|
74
|
+
</h3>
|
|
75
|
+
<p className="text-gray-500 dark:text-gray-400">
|
|
76
|
+
View "{view.name}" has an unsupported type.
|
|
77
|
+
</p>
|
|
78
|
+
<p className="text-sm text-gray-400 dark:text-gray-500 mt-2">
|
|
79
|
+
Supported types: list, detail, dashboard, form
|
|
80
|
+
</p>
|
|
81
|
+
</div>
|
|
82
|
+
</div>
|
|
83
|
+
);
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
export default ViewRouter;
|
|
88
|
+
`;
|
|
89
|
+
}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Vite Config Generator for React App
|
|
3
|
+
*
|
|
4
|
+
* Generates Vite configuration with React plugin and proxy
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
import type { TemplateContext } from '@specverse/engine-realize';
|
|
8
|
+
import { getApiBaseUrl, getPathConfig } from '../../../shared/path-resolver.js';
|
|
9
|
+
|
|
10
|
+
export default function generateViteConfig(context: TemplateContext): string {
|
|
11
|
+
const { configuration } = context;
|
|
12
|
+
const pathConfig = getPathConfig(context);
|
|
13
|
+
|
|
14
|
+
const vitePort = configuration?.vite?.port || 5173;
|
|
15
|
+
const viteHost = configuration?.vite?.host || 'localhost';
|
|
16
|
+
const apiBaseUrl = getApiBaseUrl(pathConfig);
|
|
17
|
+
const apiProxy = configuration?.vite?.proxy?.['/api'] || apiBaseUrl;
|
|
18
|
+
|
|
19
|
+
return `import { defineConfig } from 'vite';
|
|
20
|
+
import react from '@vitejs/plugin-react';
|
|
21
|
+
import path from 'path';
|
|
22
|
+
|
|
23
|
+
// https://vitejs.dev/config/
|
|
24
|
+
export default defineConfig({
|
|
25
|
+
plugins: [react()],
|
|
26
|
+
server: {
|
|
27
|
+
port: ${vitePort},
|
|
28
|
+
host: '${viteHost}',
|
|
29
|
+
proxy: {
|
|
30
|
+
'/api': {
|
|
31
|
+
target: '${apiProxy}',
|
|
32
|
+
changeOrigin: true,
|
|
33
|
+
},
|
|
34
|
+
},
|
|
35
|
+
},
|
|
36
|
+
build: {
|
|
37
|
+
outDir: 'dist',
|
|
38
|
+
sourcemap: true,
|
|
39
|
+
},
|
|
40
|
+
resolve: {
|
|
41
|
+
alias: {
|
|
42
|
+
'@': path.resolve(__dirname, './src'),
|
|
43
|
+
},
|
|
44
|
+
// Prevent React duplication when using local packages
|
|
45
|
+
dedupe: ['react', 'react-dom'],
|
|
46
|
+
},
|
|
47
|
+
});
|
|
48
|
+
`;
|
|
49
|
+
}
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
name: FastifyPrismaAPI
|
|
2
|
+
version: "1.0.0"
|
|
3
|
+
category: controller
|
|
4
|
+
description: "Fastify server with Prisma ORM, Zod validation, and JWT authentication"
|
|
5
|
+
|
|
6
|
+
metadata:
|
|
7
|
+
author: "SpecVerse Team"
|
|
8
|
+
license: "MIT"
|
|
9
|
+
tags: [fastify, prisma, typescript, rest-api]
|
|
10
|
+
|
|
11
|
+
compatibility:
|
|
12
|
+
specverse: "^3.3.0"
|
|
13
|
+
node: ">=18.0.0"
|
|
14
|
+
|
|
15
|
+
capabilities:
|
|
16
|
+
provides:
|
|
17
|
+
- "api.rest"
|
|
18
|
+
- "api.rest.crud"
|
|
19
|
+
- "api.websocket"
|
|
20
|
+
requires: []
|
|
21
|
+
|
|
22
|
+
technology:
|
|
23
|
+
runtime: "node"
|
|
24
|
+
language: "typescript"
|
|
25
|
+
framework: "fastify"
|
|
26
|
+
orm: "prisma"
|
|
27
|
+
validation: "zod"
|
|
28
|
+
authentication: "jwt"
|
|
29
|
+
|
|
30
|
+
dependencies:
|
|
31
|
+
runtime:
|
|
32
|
+
- name: "fastify"
|
|
33
|
+
version: "^4.24.0"
|
|
34
|
+
- name: "@fastify/cors"
|
|
35
|
+
version: "^8.4.0"
|
|
36
|
+
- name: "@fastify/jwt"
|
|
37
|
+
version: "^7.2.0"
|
|
38
|
+
- name: "@fastify/helmet"
|
|
39
|
+
version: "^11.1.0"
|
|
40
|
+
- name: "@fastify/rate-limit"
|
|
41
|
+
version: "^9.0.0"
|
|
42
|
+
- name: "@prisma/client"
|
|
43
|
+
version: "^5.5.0"
|
|
44
|
+
- name: "zod"
|
|
45
|
+
version: "^3.22.0"
|
|
46
|
+
|
|
47
|
+
dev:
|
|
48
|
+
- name: "prisma"
|
|
49
|
+
version: "^5.5.0"
|
|
50
|
+
- name: "@types/node"
|
|
51
|
+
version: "^20.8.0"
|
|
52
|
+
- name: "typescript"
|
|
53
|
+
version: "^5.2.0"
|
|
54
|
+
- name: "tsx"
|
|
55
|
+
version: "^4.0.0"
|
|
56
|
+
|
|
57
|
+
codeTemplates:
|
|
58
|
+
routes:
|
|
59
|
+
engine: typescript
|
|
60
|
+
generator: "libs/instance-factories/backend/templates/fastify/routes-generator.ts"
|
|
61
|
+
outputPattern: "routes/{controller}.ts"
|
|
62
|
+
|
|
63
|
+
services:
|
|
64
|
+
engine: typescript
|
|
65
|
+
generator: "libs/instance-factories/backend/templates/prisma/services-generator.ts"
|
|
66
|
+
outputPattern: "services/{model}.service.ts"
|
|
67
|
+
|
|
68
|
+
schema:
|
|
69
|
+
engine: typescript
|
|
70
|
+
generator: "libs/instance-factories/backend/templates/prisma/schema-generator.ts"
|
|
71
|
+
outputPattern: "prisma/schema.prisma"
|
|
72
|
+
|
|
73
|
+
configuration:
|
|
74
|
+
server:
|
|
75
|
+
port: 3000
|
|
76
|
+
host: "0.0.0.0"
|
|
77
|
+
trustProxy: true
|
|
78
|
+
requestIdLogLabel: "reqId"
|
|
79
|
+
logger:
|
|
80
|
+
level: "info"
|
|
81
|
+
prettyPrint: true
|
|
82
|
+
|
|
83
|
+
orm:
|
|
84
|
+
provider: "postgresql"
|
|
85
|
+
relationMode: "foreignKeys"
|
|
86
|
+
log: ["query", "error", "warn"]
|
|
87
|
+
|
|
88
|
+
middleware:
|
|
89
|
+
cors:
|
|
90
|
+
origin: true
|
|
91
|
+
credentials: true
|
|
92
|
+
helmet:
|
|
93
|
+
enabled: true
|
|
94
|
+
rateLimit:
|
|
95
|
+
max: 100
|
|
96
|
+
timeWindow: "1 minute"
|
|
97
|
+
jwt:
|
|
98
|
+
secret: "${JWT_SECRET}"
|
|
99
|
+
sign:
|
|
100
|
+
expiresIn: "7d"
|
|
101
|
+
|
|
102
|
+
validation:
|
|
103
|
+
stripUnknown: true
|
|
104
|
+
abortEarly: false
|