@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.
Files changed (420) hide show
  1. package/assets/examples/09-api/ai-spec.yaml +194 -0
  2. package/assets/examples/09-api/converted.yaml +95 -0
  3. package/assets/examples/09-api/diagram-architecture.mmd +10 -0
  4. package/assets/examples/09-api/diagram-er.mmd +10 -0
  5. package/assets/examples/09-api/documentation.html +104 -0
  6. package/assets/examples/09-api/documentation.md +95 -0
  7. package/assets/examples/09-api/inferred-spec.yaml +420 -0
  8. package/assets/examples/09-api/openapi.json +61 -0
  9. package/assets/examples/10-api/README.md +216 -0
  10. package/assets/examples/10-api/ai-spec.yaml +194 -0
  11. package/assets/examples/10-api/converted.yaml +96 -0
  12. package/assets/examples/10-api/diagram-architecture.mmd +10 -0
  13. package/assets/examples/10-api/diagram-er.mmd +10 -0
  14. package/assets/examples/10-api/documentation.html +104 -0
  15. package/assets/examples/10-api/documentation.md +95 -0
  16. package/assets/examples/10-api/inferred-spec.yaml +7 -0
  17. package/assets/examples/10-api/metadata.yaml +89 -0
  18. package/assets/examples/10-api/openapi.json +61 -0
  19. package/assets/examples/10-api/package-integration-test.js +177 -0
  20. package/assets/examples/10-api/usage-example.js +323 -0
  21. package/assets/examples/10-api/usage-example.ts +363 -0
  22. package/assets/examples/10-api/workflow-test.js +113 -0
  23. package/assets/examples/manifests/01-simple-default-mappings.yaml +36 -0
  24. package/assets/examples/manifests/02-capability-mappings.yaml +55 -0
  25. package/assets/examples/manifests/03-hybrid-mappings.yaml +109 -0
  26. package/assets/examples/manifests/README.md +245 -0
  27. package/assets/examples/manifests/backend-only.yaml +43 -0
  28. package/assets/examples/manifests/blog-api.md +78 -0
  29. package/assets/examples/manifests/blog-api.specly +79 -0
  30. package/assets/examples/manifests/frontend-only.yaml +27 -0
  31. package/assets/examples/manifests/fullstack-app.yaml +44 -0
  32. package/assets/examples/manifests/fullstack-monorepo.yaml +62 -0
  33. package/assets/examples/validate-examples-with-expected-failures.cjs +328 -0
  34. package/assets/examples/validate-examples.cjs +225 -0
  35. package/assets/examples-decomposed/cloud-native-manifest.example.yaml +8 -0
  36. package/assets/examples-decomposed/cloud-native-manifest.md +379 -0
  37. package/assets/examples-decomposed/cloud-native-manifest.specly +60 -0
  38. package/assets/examples-decomposed/docker-compose-manifest.example.yaml +8 -0
  39. package/assets/examples-decomposed/docker-compose-manifest.md +326 -0
  40. package/assets/examples-decomposed/docker-compose-manifest.specly +40 -0
  41. package/assets/examples-decomposed/kubernetes-deployment-manifest.example.yaml +8 -0
  42. package/assets/examples-decomposed/kubernetes-deployment-manifest.md +237 -0
  43. package/assets/examples-decomposed/kubernetes-deployment-manifest.specly +41 -0
  44. package/assets/templates/README.md +559 -0
  45. package/assets/templates/TEMPLATE-ENHANCEMENTS-V33.md +462 -0
  46. package/assets/templates/backend-only/CLAUDE.md +73 -0
  47. package/assets/templates/backend-only/README.md +197 -0
  48. package/assets/templates/backend-only/deployments/README.md +149 -0
  49. package/assets/templates/backend-only/deployments/development.specly +53 -0
  50. package/assets/templates/backend-only/deployments/production.specly +87 -0
  51. package/assets/templates/backend-only/docs/README.md +50 -0
  52. package/assets/templates/backend-only/docs/api/README.md +7 -0
  53. package/assets/templates/backend-only/docs/diagrams/README.md +85 -0
  54. package/assets/templates/backend-only/docs/example-documentation-template.md +269 -0
  55. package/assets/templates/backend-only/docs/guides/README.md +15 -0
  56. package/assets/templates/backend-only/dot.env.example +18 -0
  57. package/assets/templates/backend-only/generated/README.md +56 -0
  58. package/assets/templates/backend-only/generated/code/integration-test.template.js +320 -0
  59. package/assets/templates/backend-only/generated/code/package.json.template +34 -0
  60. package/assets/templates/backend-only/generated/docs/README.md +49 -0
  61. package/assets/templates/backend-only/gitignore +54 -0
  62. package/assets/templates/backend-only/manifests/README.md +72 -0
  63. package/assets/templates/backend-only/manifests/docker-compose.specly +91 -0
  64. package/assets/templates/backend-only/manifests/implementation.yaml +100 -0
  65. package/assets/templates/backend-only/manifests/kubernetes.specly +140 -0
  66. package/assets/templates/backend-only/package.json +59 -0
  67. package/assets/templates/backend-only/scripts/test-all.sh +160 -0
  68. package/assets/templates/backend-only/scripts/test-generated-code.sh +165 -0
  69. package/assets/templates/backend-only/specs/main.specly +67 -0
  70. package/assets/templates/default/CLAUDE.md +141 -0
  71. package/assets/templates/default/README.md +404 -0
  72. package/assets/templates/default/deployments/README.md +149 -0
  73. package/assets/templates/default/deployments/development.specly +53 -0
  74. package/assets/templates/default/deployments/production.specly +87 -0
  75. package/assets/templates/default/docs/README.md +50 -0
  76. package/assets/templates/default/docs/api/README.md +7 -0
  77. package/assets/templates/default/docs/diagrams/README.md +85 -0
  78. package/assets/templates/default/docs/example-documentation-template.md +269 -0
  79. package/assets/templates/default/docs/guides/README.md +15 -0
  80. package/assets/templates/default/dot.env.example +18 -0
  81. package/assets/templates/default/generated/README.md +56 -0
  82. package/assets/templates/default/generated/code/integration-test.template.js +320 -0
  83. package/assets/templates/default/generated/code/package.json.template +34 -0
  84. package/assets/templates/default/generated/docs/README.md +49 -0
  85. package/assets/templates/default/gitignore +54 -0
  86. package/assets/templates/default/manifests/README.md +72 -0
  87. package/assets/templates/default/manifests/docker-compose.specly +91 -0
  88. package/assets/templates/default/manifests/implementation.yaml +176 -0
  89. package/assets/templates/default/manifests/kubernetes.specly +140 -0
  90. package/assets/templates/default/package.json +61 -0
  91. package/assets/templates/default/scripts/test-all.sh +160 -0
  92. package/assets/templates/default/scripts/test-generated-code.sh +165 -0
  93. package/assets/templates/default/specs/main.specly +67 -0
  94. package/assets/templates/frontend-only/CLAUDE.md +75 -0
  95. package/assets/templates/frontend-only/README.md +231 -0
  96. package/assets/templates/frontend-only/deployments/README.md +149 -0
  97. package/assets/templates/frontend-only/deployments/development.specly +53 -0
  98. package/assets/templates/frontend-only/deployments/production.specly +87 -0
  99. package/assets/templates/frontend-only/docs/README.md +50 -0
  100. package/assets/templates/frontend-only/docs/api/README.md +7 -0
  101. package/assets/templates/frontend-only/docs/diagrams/README.md +85 -0
  102. package/assets/templates/frontend-only/docs/example-documentation-template.md +269 -0
  103. package/assets/templates/frontend-only/docs/guides/README.md +15 -0
  104. package/assets/templates/frontend-only/dot.env.example +18 -0
  105. package/assets/templates/frontend-only/generated/README.md +56 -0
  106. package/assets/templates/frontend-only/generated/code/integration-test.template.js +320 -0
  107. package/assets/templates/frontend-only/generated/code/package.json.template +34 -0
  108. package/assets/templates/frontend-only/generated/docs/README.md +49 -0
  109. package/assets/templates/frontend-only/gitignore +54 -0
  110. package/assets/templates/frontend-only/manifests/README.md +72 -0
  111. package/assets/templates/frontend-only/manifests/docker-compose.specly +91 -0
  112. package/assets/templates/frontend-only/manifests/implementation.yaml +58 -0
  113. package/assets/templates/frontend-only/manifests/kubernetes.specly +140 -0
  114. package/assets/templates/frontend-only/package.json +59 -0
  115. package/assets/templates/frontend-only/scripts/test-all.sh +160 -0
  116. package/assets/templates/frontend-only/scripts/test-generated-code.sh +165 -0
  117. package/assets/templates/frontend-only/specs/main.specly +57 -0
  118. package/assets/templates/full-stack/AI-GUIDE.md +60 -0
  119. package/assets/templates/full-stack/CLAUDE.md +141 -0
  120. package/assets/templates/full-stack/README.md +382 -0
  121. package/assets/templates/full-stack/archive/AI-GUIDE-legacy.md +392 -0
  122. package/assets/templates/full-stack/deployments/README.md +149 -0
  123. package/assets/templates/full-stack/deployments/development.specly +53 -0
  124. package/assets/templates/full-stack/deployments/production.specly +87 -0
  125. package/assets/templates/full-stack/docs/README.md +51 -0
  126. package/assets/templates/full-stack/docs/api/README.md +7 -0
  127. package/assets/templates/full-stack/docs/diagrams/README.md +85 -0
  128. package/assets/templates/full-stack/docs/example-documentation-template.md +269 -0
  129. package/assets/templates/full-stack/docs/guides/README.md +15 -0
  130. package/assets/templates/full-stack/generated/README.md +56 -0
  131. package/assets/templates/full-stack/generated/code/integration-test.template.js +320 -0
  132. package/assets/templates/full-stack/generated/code/package.json.template +34 -0
  133. package/assets/templates/full-stack/generated/docs/README.md +49 -0
  134. package/assets/templates/full-stack/gitignore +54 -0
  135. package/assets/templates/full-stack/manifests/README.md +72 -0
  136. package/assets/templates/full-stack/manifests/docker-compose.specly +91 -0
  137. package/assets/templates/full-stack/manifests/implementation.yaml +155 -0
  138. package/assets/templates/full-stack/manifests/kubernetes.specly +140 -0
  139. package/assets/templates/full-stack/package.json +45 -0
  140. package/assets/templates/full-stack/scripts/test-all.sh +160 -0
  141. package/assets/templates/full-stack/scripts/test-generated-code.sh +165 -0
  142. package/assets/templates/full-stack/specs/example-v33.specly +297 -0
  143. package/assets/templates/full-stack/specs/main-simple.specly +73 -0
  144. package/assets/templates/full-stack/specs/main.specly +408 -0
  145. package/dist/engines/code-generator.d.ts +86 -0
  146. package/dist/engines/code-generator.d.ts.map +1 -0
  147. package/dist/engines/code-generator.js +159 -0
  148. package/dist/engines/code-generator.js.map +1 -0
  149. package/dist/engines/engine-registry.d.ts +94 -0
  150. package/dist/engines/engine-registry.d.ts.map +1 -0
  151. package/dist/engines/engine-registry.js +163 -0
  152. package/dist/engines/engine-registry.js.map +1 -0
  153. package/dist/engines/index.d.ts +10 -0
  154. package/dist/engines/index.d.ts.map +1 -0
  155. package/dist/engines/index.js +12 -0
  156. package/dist/engines/index.js.map +1 -0
  157. package/dist/engines/typescript-engine.d.ts +74 -0
  158. package/dist/engines/typescript-engine.d.ts.map +1 -0
  159. package/dist/engines/typescript-engine.js +288 -0
  160. package/dist/engines/typescript-engine.js.map +1 -0
  161. package/dist/generators/index.d.ts +11 -0
  162. package/dist/generators/index.d.ts.map +1 -0
  163. package/dist/generators/index.js +11 -0
  164. package/dist/generators/index.js.map +1 -0
  165. package/dist/index.d.ts +48 -0
  166. package/dist/index.d.ts.map +1 -0
  167. package/dist/index.js +434 -0
  168. package/dist/index.js.map +1 -0
  169. package/dist/library/index.d.ts +12 -0
  170. package/dist/library/index.d.ts.map +1 -0
  171. package/dist/library/index.js +15 -0
  172. package/dist/library/index.js.map +1 -0
  173. package/dist/library/library.d.ts +132 -0
  174. package/dist/library/library.d.ts.map +1 -0
  175. package/dist/library/library.js +343 -0
  176. package/dist/library/library.js.map +1 -0
  177. package/dist/library/loader.d.ts +73 -0
  178. package/dist/library/loader.d.ts.map +1 -0
  179. package/dist/library/loader.js +150 -0
  180. package/dist/library/loader.js.map +1 -0
  181. package/dist/library/resolver.d.ts +104 -0
  182. package/dist/library/resolver.d.ts.map +1 -0
  183. package/dist/library/resolver.js +299 -0
  184. package/dist/library/resolver.js.map +1 -0
  185. package/dist/library/validator.d.ts +65 -0
  186. package/dist/library/validator.d.ts.map +1 -0
  187. package/dist/library/validator.js +203 -0
  188. package/dist/library/validator.js.map +1 -0
  189. package/dist/types/index.d.ts +7 -0
  190. package/dist/types/index.d.ts.map +1 -0
  191. package/dist/types/index.js +7 -0
  192. package/dist/types/index.js.map +1 -0
  193. package/dist/types/instance-factory.d.ts +289 -0
  194. package/dist/types/instance-factory.d.ts.map +1 -0
  195. package/dist/types/instance-factory.js +8 -0
  196. package/dist/types/instance-factory.js.map +1 -0
  197. package/dist/types/unified-mappings.d.ts +163 -0
  198. package/dist/types/unified-mappings.d.ts.map +1 -0
  199. package/dist/types/unified-mappings.js +110 -0
  200. package/dist/types/unified-mappings.js.map +1 -0
  201. package/dist/utils/ai-spec-loader.d.ts +77 -0
  202. package/dist/utils/ai-spec-loader.d.ts.map +1 -0
  203. package/dist/utils/ai-spec-loader.js +138 -0
  204. package/dist/utils/ai-spec-loader.js.map +1 -0
  205. package/dist/utils/index.d.ts +9 -0
  206. package/dist/utils/index.d.ts.map +1 -0
  207. package/dist/utils/index.js +9 -0
  208. package/dist/utils/index.js.map +1 -0
  209. package/dist/utils/manifest-loader.d.ts +107 -0
  210. package/dist/utils/manifest-loader.d.ts.map +1 -0
  211. package/dist/utils/manifest-loader.js +168 -0
  212. package/dist/utils/manifest-loader.js.map +1 -0
  213. package/dist/utils/mapping-migration.d.ts +53 -0
  214. package/dist/utils/mapping-migration.d.ts.map +1 -0
  215. package/dist/utils/mapping-migration.js +194 -0
  216. package/dist/utils/mapping-migration.js.map +1 -0
  217. package/libs/instance-factories/CURVED-INTERFACE.md +278 -0
  218. package/libs/instance-factories/README.md +433 -0
  219. package/libs/instance-factories/applications/generic-app.yaml +52 -0
  220. package/libs/instance-factories/applications/react-app.yaml +186 -0
  221. package/libs/instance-factories/applications/templates/generic/backend-env-generator.ts +31 -0
  222. package/libs/instance-factories/applications/templates/generic/backend-package-json-generator.ts +80 -0
  223. package/libs/instance-factories/applications/templates/generic/backend-tsconfig-generator.ts +69 -0
  224. package/libs/instance-factories/applications/templates/generic/main-generator.ts +308 -0
  225. package/libs/instance-factories/applications/templates/react/_view-components-source.ts +555 -0
  226. package/libs/instance-factories/applications/templates/react/api-client-generator.ts +436 -0
  227. package/libs/instance-factories/applications/templates/react/api-types-generator.ts +153 -0
  228. package/libs/instance-factories/applications/templates/react/app-tsx-generator.ts +94 -0
  229. package/libs/instance-factories/applications/templates/react/env-example-generator.ts +24 -0
  230. package/libs/instance-factories/applications/templates/react/field-helpers-generator.ts +106 -0
  231. package/libs/instance-factories/applications/templates/react/gitignore-generator.ts +38 -0
  232. package/libs/instance-factories/applications/templates/react/index-css-generator.ts +85 -0
  233. package/libs/instance-factories/applications/templates/react/index-html-generator.ts +30 -0
  234. package/libs/instance-factories/applications/templates/react/main-tsx-generator.ts +34 -0
  235. package/libs/instance-factories/applications/templates/react/package-json-generator.ts +54 -0
  236. package/libs/instance-factories/applications/templates/react/pattern-adapter-generator.ts +179 -0
  237. package/libs/instance-factories/applications/templates/react/react-pattern-adapter.tsx +1347 -0
  238. package/libs/instance-factories/applications/templates/react/relationship-field-generator.ts +150 -0
  239. package/libs/instance-factories/applications/templates/react/tailwind-adapter-generator.ts +704 -0
  240. package/libs/instance-factories/applications/templates/react/tailwind-adapter-wrapper-generator.ts +84 -0
  241. package/libs/instance-factories/applications/templates/react/tsconfig-generator.ts +35 -0
  242. package/libs/instance-factories/applications/templates/react/use-api-hooks-generator.ts +121 -0
  243. package/libs/instance-factories/applications/templates/react/view-dashboard-generator.ts +150 -0
  244. package/libs/instance-factories/applications/templates/react/view-detail-generator.ts +150 -0
  245. package/libs/instance-factories/applications/templates/react/view-form-generator.ts +362 -0
  246. package/libs/instance-factories/applications/templates/react/view-list-generator.ts +98 -0
  247. package/libs/instance-factories/applications/templates/react/view-router-generator.ts +89 -0
  248. package/libs/instance-factories/applications/templates/react/vite-config-generator.ts +49 -0
  249. package/libs/instance-factories/archived/fastify-prisma.yaml +104 -0
  250. package/libs/instance-factories/cli/commander-js.yaml +55 -0
  251. package/libs/instance-factories/cli/templates/commander/cli-entry-generator.d.ts +12 -0
  252. package/libs/instance-factories/cli/templates/commander/cli-entry-generator.d.ts.map +1 -0
  253. package/libs/instance-factories/cli/templates/commander/cli-entry-generator.js +115 -0
  254. package/libs/instance-factories/cli/templates/commander/cli-entry-generator.js.map +1 -0
  255. package/libs/instance-factories/cli/templates/commander/cli-entry-generator.ts +145 -0
  256. package/libs/instance-factories/cli/templates/commander/command-generator.d.ts +14 -0
  257. package/libs/instance-factories/cli/templates/commander/command-generator.d.ts.map +1 -0
  258. package/libs/instance-factories/cli/templates/commander/command-generator.js +182 -0
  259. package/libs/instance-factories/cli/templates/commander/command-generator.js.map +1 -0
  260. package/libs/instance-factories/cli/templates/commander/command-generator.ts +992 -0
  261. package/libs/instance-factories/communication/event-emitter.yaml +56 -0
  262. package/libs/instance-factories/communication/rabbitmq-events.yaml +87 -0
  263. package/libs/instance-factories/communication/templates/eventemitter/bus-generator.ts +93 -0
  264. package/libs/instance-factories/communication/templates/eventemitter/publisher-generator.ts +117 -0
  265. package/libs/instance-factories/communication/templates/eventemitter/subscriber-generator.ts +101 -0
  266. package/libs/instance-factories/controllers/fastify.yaml +127 -0
  267. package/libs/instance-factories/controllers/templates/fastify/meta-routes-generator.ts +103 -0
  268. package/libs/instance-factories/controllers/templates/fastify/routes-generator.ts +389 -0
  269. package/libs/instance-factories/controllers/templates/fastify/server-generator.ts +76 -0
  270. package/libs/instance-factories/infrastructure/docker-k8s.yaml +61 -0
  271. package/libs/instance-factories/infrastructure/templates/docker-k8s/infrastructure-generator.ts +46 -0
  272. package/libs/instance-factories/orms/prisma.yaml +89 -0
  273. package/libs/instance-factories/orms/templates/prisma/schema-generator.ts +563 -0
  274. package/libs/instance-factories/orms/templates/prisma/services-generator.ts +408 -0
  275. package/libs/instance-factories/scaffolding/generic-scaffold.yaml +65 -0
  276. package/libs/instance-factories/scaffolding/templates/generic/env-example-generator.ts +73 -0
  277. package/libs/instance-factories/scaffolding/templates/generic/env-generator.ts +85 -0
  278. package/libs/instance-factories/scaffolding/templates/generic/gitignore-generator.ts +69 -0
  279. package/libs/instance-factories/scaffolding/templates/generic/package-json-generator.ts +176 -0
  280. package/libs/instance-factories/scaffolding/templates/generic/readme-generator.ts +207 -0
  281. package/libs/instance-factories/scaffolding/templates/generic/tsconfig-generator.ts +78 -0
  282. package/libs/instance-factories/scaffolding/templates/generic/tsconfig-react-generator.ts +41 -0
  283. package/libs/instance-factories/sdks/python-sdk.yaml +66 -0
  284. package/libs/instance-factories/sdks/templates/python/sdk-generator.ts +50 -0
  285. package/libs/instance-factories/sdks/templates/typescript/sdk-generator.ts +49 -0
  286. package/libs/instance-factories/sdks/typescript-sdk.yaml +59 -0
  287. package/libs/instance-factories/services/prisma-services.yaml +71 -0
  288. package/libs/instance-factories/services/templates/prisma/behavior-generator.ts +303 -0
  289. package/libs/instance-factories/services/templates/prisma/controller-generator.ts +532 -0
  290. package/libs/instance-factories/services/templates/prisma/service-generator.ts +315 -0
  291. package/libs/instance-factories/shared/path-resolver.ts +111 -0
  292. package/libs/instance-factories/storage/mongodb.yaml +79 -0
  293. package/libs/instance-factories/storage/postgresql.yaml +75 -0
  294. package/libs/instance-factories/storage/redis.yaml +79 -0
  295. package/libs/instance-factories/storage/templates/mongodb/config-generator.ts +15 -0
  296. package/libs/instance-factories/storage/templates/mongodb/docker-generator.ts +18 -0
  297. package/libs/instance-factories/storage/templates/postgresql/config-generator.ts +54 -0
  298. package/libs/instance-factories/storage/templates/postgresql/docker-generator.ts +55 -0
  299. package/libs/instance-factories/storage/templates/redis/config-generator.ts +16 -0
  300. package/libs/instance-factories/storage/templates/redis/docker-generator.ts +18 -0
  301. package/libs/instance-factories/test-generation.ts +192 -0
  302. package/libs/instance-factories/testing/templates/vitest/tests-generator.ts +51 -0
  303. package/libs/instance-factories/testing/vitest-tests.yaml +63 -0
  304. package/libs/instance-factories/tools/templates/mcp/mcp-server-generator.ts +136 -0
  305. package/libs/instance-factories/tools/templates/mcp/static/docs/DEPLOYMENT_GUIDE.md +630 -0
  306. package/libs/instance-factories/tools/templates/mcp/static/docs/HYBRID_RESOURCE_SYSTEM.md +330 -0
  307. package/libs/instance-factories/tools/templates/mcp/static/docs/deployments/EXTENSION_DEPLOYMENT.md +552 -0
  308. package/libs/instance-factories/tools/templates/mcp/static/docs/deployments/LOCAL_DEPLOYMENT.md +164 -0
  309. package/libs/instance-factories/tools/templates/mcp/static/docs/deployments/WEB_DEPLOYMENT.md +247 -0
  310. package/libs/instance-factories/tools/templates/mcp/static/package.json +92 -0
  311. package/libs/instance-factories/tools/templates/mcp/static/scripts/build-enterprise.js +284 -0
  312. package/libs/instance-factories/tools/templates/mcp/static/scripts/build-extension.js +139 -0
  313. package/libs/instance-factories/tools/templates/mcp/static/scripts/build-local.js +74 -0
  314. package/libs/instance-factories/tools/templates/mcp/static/scripts/build-web.js +156 -0
  315. package/libs/instance-factories/tools/templates/mcp/static/scripts/copy-canonical-files.js +41 -0
  316. package/libs/instance-factories/tools/templates/mcp/static/scripts/test-deployments.js +259 -0
  317. package/libs/instance-factories/tools/templates/mcp/static/scripts/test-hybrid-resources.js +231 -0
  318. package/libs/instance-factories/tools/templates/mcp/static/scripts/test-hybrid-simple.js +196 -0
  319. package/libs/instance-factories/tools/templates/mcp/static/src/controllers/MCPServerController.ts +293 -0
  320. package/libs/instance-factories/tools/templates/mcp/static/src/events/EventEmitter.ts +90 -0
  321. package/libs/instance-factories/tools/templates/mcp/static/src/index.ts +24 -0
  322. package/libs/instance-factories/tools/templates/mcp/static/src/interfaces/ResourceProvider.ts +15 -0
  323. package/libs/instance-factories/tools/templates/mcp/static/src/models/LibrarySuggestion.ts +106 -0
  324. package/libs/instance-factories/tools/templates/mcp/static/src/models/SpecVerseResource.ts +75 -0
  325. package/libs/instance-factories/tools/templates/mcp/static/src/server/mcp-server.ts +239 -0
  326. package/libs/instance-factories/tools/templates/mcp/static/src/services/CLIProxyService.ts +1501 -0
  327. package/libs/instance-factories/tools/templates/mcp/static/src/services/EmbeddedResourcesAdapter.ts +211 -0
  328. package/libs/instance-factories/tools/templates/mcp/static/src/services/EntityModuleService.ts +308 -0
  329. package/libs/instance-factories/tools/templates/mcp/static/src/services/HybridResourcesProvider.ts +210 -0
  330. package/libs/instance-factories/tools/templates/mcp/static/src/services/LibraryToolsService.ts +356 -0
  331. package/libs/instance-factories/tools/templates/mcp/static/src/services/OrchestratorBridge.ts +524 -0
  332. package/libs/instance-factories/tools/templates/mcp/static/src/services/OrchestratorToolsService.ts +530 -0
  333. package/libs/instance-factories/tools/templates/mcp/static/src/services/PromptToolsService.ts +594 -0
  334. package/libs/instance-factories/tools/templates/mcp/static/src/services/ResourcesProviderService.ts +170 -0
  335. package/libs/instance-factories/tools/templates/mcp/static/src/tests/unit/CLIProxyService.init.test.ts +544 -0
  336. package/libs/instance-factories/tools/templates/mcp/static/src/tests/unit/CLIProxyService.test.ts +189 -0
  337. package/libs/instance-factories/tools/templates/mcp/static/src/tests/unit/ResourcesProviderService.test.ts +89 -0
  338. package/libs/instance-factories/tools/templates/mcp/static/src/types/index.ts +110 -0
  339. package/libs/instance-factories/tools/templates/mcp/static/tsconfig.json +28 -0
  340. package/libs/instance-factories/tools/templates/vscode/static/extension.ts +1195 -0
  341. package/libs/instance-factories/tools/templates/vscode/static/language-configuration.json +34 -0
  342. package/libs/instance-factories/tools/templates/vscode/static/schemas/specverse-v3-schema.json +4279 -0
  343. package/libs/instance-factories/tools/templates/vscode/static/syntaxes/specverse.tmLanguage.json +138 -0
  344. package/libs/instance-factories/tools/templates/vscode/static/themes/README.md +74 -0
  345. package/libs/instance-factories/tools/templates/vscode/static/themes/complete-specverse-colors.json +122 -0
  346. package/libs/instance-factories/tools/templates/vscode/static/themes/specverse-basic-theme.json +65 -0
  347. package/libs/instance-factories/tools/templates/vscode/static/themes/specverse-complete-theme.json +123 -0
  348. package/libs/instance-factories/tools/templates/vscode/static/themes/specverse-theme-colors.json +64 -0
  349. package/libs/instance-factories/tools/templates/vscode/vscode-extension-generator.ts +214 -0
  350. package/libs/instance-factories/validation/templates/zod/validation-generator.ts +46 -0
  351. package/libs/instance-factories/validation/zod.yaml +56 -0
  352. package/libs/instance-factories/views/index.d.ts +13 -0
  353. package/libs/instance-factories/views/index.d.ts.map +1 -0
  354. package/libs/instance-factories/views/index.js +18 -0
  355. package/libs/instance-factories/views/index.js.map +1 -0
  356. package/libs/instance-factories/views/index.ts +45 -0
  357. package/libs/instance-factories/views/react-components.yaml +129 -0
  358. package/libs/instance-factories/views/templates/ARCHITECTURE.md +198 -0
  359. package/libs/instance-factories/views/templates/react/adapters/antd-adapter.ts +869 -0
  360. package/libs/instance-factories/views/templates/react/adapters/mui-adapter.ts +953 -0
  361. package/libs/instance-factories/views/templates/react/adapters/shadcn-adapter.ts +806 -0
  362. package/libs/instance-factories/views/templates/react/app-generator.ts +55 -0
  363. package/libs/instance-factories/views/templates/react/components-generator.ts +391 -0
  364. package/libs/instance-factories/views/templates/react/forms-generator.ts +343 -0
  365. package/libs/instance-factories/views/templates/react/frontend-package-json-generator.ts +54 -0
  366. package/libs/instance-factories/views/templates/react/hooks-generator.ts +122 -0
  367. package/libs/instance-factories/views/templates/react/index-css-generator.ts +209 -0
  368. package/libs/instance-factories/views/templates/react/index-html-generator.ts +34 -0
  369. package/libs/instance-factories/views/templates/react/main-tsx-generator.ts +29 -0
  370. package/libs/instance-factories/views/templates/react/react-component-generator.d.ts +152 -0
  371. package/libs/instance-factories/views/templates/react/react-component-generator.d.ts.map +1 -0
  372. package/libs/instance-factories/views/templates/react/react-component-generator.js +398 -0
  373. package/libs/instance-factories/views/templates/react/react-component-generator.js.map +1 -0
  374. package/libs/instance-factories/views/templates/react/react-component-generator.ts +533 -0
  375. package/libs/instance-factories/views/templates/react/router-generator.ts +197 -0
  376. package/libs/instance-factories/views/templates/react/router-generic-generator.ts +103 -0
  377. package/libs/instance-factories/views/templates/react/spec-json-generator.ts +17 -0
  378. package/libs/instance-factories/views/templates/react/types-generator.ts +76 -0
  379. package/libs/instance-factories/views/templates/react/views-metadata-generator.ts +42 -0
  380. package/libs/instance-factories/views/templates/react/vite-config-generator.ts +38 -0
  381. package/libs/instance-factories/views/templates/runtime/runtime-view-renderer.d.ts.map +1 -0
  382. package/libs/instance-factories/views/templates/runtime/runtime-view-renderer.js.map +1 -0
  383. package/libs/instance-factories/views/templates/runtime/runtime-view-renderer.ts +474 -0
  384. package/libs/instance-factories/views/templates/shared/__tests__/composite-patterns.test.ts +242 -0
  385. package/libs/instance-factories/views/templates/shared/adapter-types.d.ts +77 -0
  386. package/libs/instance-factories/views/templates/shared/adapter-types.d.ts.map +1 -0
  387. package/libs/instance-factories/views/templates/shared/adapter-types.js +47 -0
  388. package/libs/instance-factories/views/templates/shared/adapter-types.js.map +1 -0
  389. package/libs/instance-factories/views/templates/shared/adapter-types.ts +142 -0
  390. package/libs/instance-factories/views/templates/shared/atomic-components-registry.d.ts +63 -0
  391. package/libs/instance-factories/views/templates/shared/atomic-components-registry.d.ts.map +1 -0
  392. package/libs/instance-factories/views/templates/shared/atomic-components-registry.js +822 -0
  393. package/libs/instance-factories/views/templates/shared/atomic-components-registry.js.map +1 -0
  394. package/libs/instance-factories/views/templates/shared/atomic-components-registry.ts +908 -0
  395. package/libs/instance-factories/views/templates/shared/base-generator.d.ts +247 -0
  396. package/libs/instance-factories/views/templates/shared/base-generator.d.ts.map +1 -0
  397. package/libs/instance-factories/views/templates/shared/base-generator.js +363 -0
  398. package/libs/instance-factories/views/templates/shared/base-generator.js.map +1 -0
  399. package/libs/instance-factories/views/templates/shared/base-generator.ts +608 -0
  400. package/libs/instance-factories/views/templates/shared/component-metadata.d.ts +254 -0
  401. package/libs/instance-factories/views/templates/shared/component-metadata.d.ts.map +1 -0
  402. package/libs/instance-factories/views/templates/shared/component-metadata.js +602 -0
  403. package/libs/instance-factories/views/templates/shared/component-metadata.js.map +1 -0
  404. package/libs/instance-factories/views/templates/shared/component-metadata.ts +803 -0
  405. package/libs/instance-factories/views/templates/shared/composite-pattern-types.ts +250 -0
  406. package/libs/instance-factories/views/templates/shared/composite-patterns.ts +535 -0
  407. package/libs/instance-factories/views/templates/shared/index.ts +68 -0
  408. package/libs/instance-factories/views/templates/shared/pattern-validator.ts +279 -0
  409. package/libs/instance-factories/views/templates/shared/property-mapper.d.ts +149 -0
  410. package/libs/instance-factories/views/templates/shared/property-mapper.d.ts.map +1 -0
  411. package/libs/instance-factories/views/templates/shared/property-mapper.js +580 -0
  412. package/libs/instance-factories/views/templates/shared/property-mapper.js.map +1 -0
  413. package/libs/instance-factories/views/templates/shared/property-mapper.ts +700 -0
  414. package/libs/instance-factories/views/templates/shared/syntax-mapper.d.ts +143 -0
  415. package/libs/instance-factories/views/templates/shared/syntax-mapper.d.ts.map +1 -0
  416. package/libs/instance-factories/views/templates/shared/syntax-mapper.js +420 -0
  417. package/libs/instance-factories/views/templates/shared/syntax-mapper.js.map +1 -0
  418. package/libs/instance-factories/views/templates/shared/syntax-mapper.ts +539 -0
  419. package/package.json +42 -0
  420. package/schema/SPECVERSE-SCHEMA.json +4274 -0
@@ -0,0 +1,343 @@
1
+ /**
2
+ * React Forms Generator
3
+ *
4
+ * Generates React forms with react-hook-form and Zod validation
5
+ */
6
+
7
+ import type { TemplateContext } from '@specverse/engine-realize';
8
+
9
+ /**
10
+ * Generate React form component for a model
11
+ */
12
+ export default function generateReactForm(context: TemplateContext): string {
13
+ const { model, spec } = context;
14
+
15
+ if (!model) {
16
+ throw new Error('Model is required in template context');
17
+ }
18
+
19
+ const modelName = model.name;
20
+ const formName = `${modelName}Form`;
21
+
22
+ return `/**
23
+ * ${formName}
24
+ * Form component for creating/editing ${modelName}
25
+ */
26
+
27
+ import { useForm } from 'react-hook-form';
28
+ import { zodResolver } from '@hookform/resolvers/zod';
29
+ import { z } from 'zod';
30
+ import { useEffect } from 'react';
31
+ import type { ${modelName} } from '../../types/${modelName}';
32
+
33
+ // Zod schema for form validation
34
+ const ${modelName.toLowerCase()}Schema = z.object({
35
+ ${generateSchemaFields(model)}
36
+ });
37
+
38
+ type ${modelName}FormData = z.infer<typeof ${modelName.toLowerCase()}Schema>;
39
+
40
+ interface ${formName}Props {
41
+ ${modelName.toLowerCase()}?: ${modelName};
42
+ onSubmit: (data: ${modelName}FormData) => void;
43
+ onValidate?: (data: ${modelName}FormData) => void;
44
+ onDelete?: () => void;
45
+ onCancel?: () => void;
46
+ isDeleting?: boolean;
47
+ isValidating?: boolean;
48
+ }
49
+
50
+ /**
51
+ * ${formName} Component
52
+ */
53
+ export function ${formName}({ ${modelName.toLowerCase()}, onSubmit, onValidate, onDelete, onCancel, isDeleting, isValidating }: ${formName}Props) {
54
+ const {
55
+ register,
56
+ handleSubmit,
57
+ getValues,
58
+ reset,
59
+ formState: { errors, isSubmitting },
60
+ } = useForm<${modelName}FormData>({
61
+ resolver: zodResolver(${modelName.toLowerCase()}Schema),
62
+ defaultValues: ${modelName.toLowerCase()} || {},
63
+ });
64
+
65
+ // Reset form when ${modelName.toLowerCase()} changes
66
+ useEffect(() => {
67
+ if (${modelName.toLowerCase()}) {
68
+ reset(${modelName.toLowerCase()});
69
+ } else {
70
+ reset({});
71
+ }
72
+ }, [${modelName.toLowerCase()}, reset]);
73
+
74
+ const handleValidateClick = () => {
75
+ if (onValidate) {
76
+ const data = getValues();
77
+ onValidate(data);
78
+ }
79
+ };
80
+
81
+ return (
82
+ <form onSubmit={handleSubmit(onSubmit)} className="${modelName.toLowerCase()}-form space-y-4" autoComplete="off" data-lpignore="true" data-form-type="other">
83
+ {/* Hidden fake fields to trick password managers */}
84
+ <input type="text" name="fake-username" style={{ display: 'none' }} tabIndex={-1} autoComplete="off" aria-hidden="true" />
85
+ <input type="password" name="fake-password" style={{ display: 'none' }} tabIndex={-1} autoComplete="new-password" aria-hidden="true" />
86
+
87
+ ${generateFormFields(model)}
88
+
89
+ <div className="form-actions flex flex-wrap gap-2 pt-4">
90
+ <button
91
+ type="submit"
92
+ disabled={isSubmitting}
93
+ className="px-6 py-2 bg-blue-600 text-white font-medium rounded hover:bg-blue-700 disabled:bg-slate-600 disabled:cursor-not-allowed transition-colors"
94
+ >
95
+ {isSubmitting ? 'Saving...' : 'Save'}
96
+ </button>
97
+
98
+ {onValidate && (
99
+ <button
100
+ type="button"
101
+ onClick={handleValidateClick}
102
+ disabled={isValidating}
103
+ className="px-6 py-2 bg-green-600 text-white font-medium rounded hover:bg-green-700 disabled:bg-slate-600 disabled:cursor-not-allowed transition-colors"
104
+ >
105
+ {isValidating ? 'Validating...' : 'Validate'}
106
+ </button>
107
+ )}
108
+
109
+ {onDelete && (
110
+ <button
111
+ type="button"
112
+ onClick={onDelete}
113
+ disabled={isDeleting}
114
+ className="px-6 py-2 bg-red-600 text-white font-medium rounded hover:bg-red-700 disabled:bg-slate-600 disabled:cursor-not-allowed transition-colors"
115
+ >
116
+ {isDeleting ? 'Deleting...' : 'Delete'}
117
+ </button>
118
+ )}
119
+
120
+ {onCancel && (
121
+ <button
122
+ type="button"
123
+ onClick={onCancel}
124
+ className="px-6 py-2 bg-slate-600 text-gray-200 font-medium rounded hover:bg-slate-500 transition-colors"
125
+ >
126
+ Cancel
127
+ </button>
128
+ )}
129
+ </div>
130
+ </form>
131
+ );
132
+ }
133
+ `;
134
+ }
135
+
136
+ /**
137
+ * Generate Zod schema fields from model attributes
138
+ */
139
+ function generateSchemaFields(model: any): string {
140
+ let attributes = model.attributes || {};
141
+
142
+ // If attributes is an array (from Object.entries), convert back to object
143
+ if (Array.isArray(attributes)) {
144
+ const obj: Record<string, any> = {};
145
+ attributes.forEach((attr: any, index: number) => {
146
+ if (attr && typeof attr === 'object' && attr.name) {
147
+ obj[attr.name] = attr;
148
+ } else if (Array.isArray(attr) && attr.length >= 2) {
149
+ // Handle [name, config] tuple format
150
+ obj[attr[0]] = attr[1];
151
+ } else {
152
+ obj[index.toString()] = attr;
153
+ }
154
+ });
155
+ attributes = obj;
156
+ }
157
+
158
+ const fields: string[] = [];
159
+
160
+ for (const [name, config] of Object.entries(attributes)) {
161
+ // Skip standard auto-generated fields
162
+ if (name === 'id' || name === 'createdAt' || name === 'updatedAt') continue;
163
+
164
+ const attr: any = config;
165
+
166
+ // Skip fields with auto directive (auto=uuid4, auto=now, etc.)
167
+ if (attr.auto || attr.autoGenerate) continue;
168
+
169
+ // Skip common auto-timestamp fields (workaround for parser not preserving auto directive)
170
+ const autoTimestampFields = ['joinedAt', 'registeredAt', 'enrolledAt', 'startedAt', 'completedAt', 'verifiedAt'];
171
+ if (autoTimestampFields.includes(name) && (attr.type === 'DateTime' || attr.type === 'Timestamp')) {
172
+ continue;
173
+ }
174
+
175
+ const type = attr.type || 'String';
176
+ let zodType = 'z.string()';
177
+
178
+ // Map SpecVerse types to Zod types
179
+ if (type === 'Integer' || type === 'Number') zodType = 'z.number()';
180
+ if (type === 'Boolean') zodType = 'z.boolean()';
181
+ if (type === 'Email') zodType = 'z.string().email()';
182
+ if (type === 'DateTime') zodType = 'z.string()'; // datetime-local input gives string, not ISO datetime
183
+ if (type === 'UUID') zodType = 'z.string().uuid()';
184
+
185
+ // Add constraints
186
+ if (attr.required) {
187
+ // Already required by default
188
+ } else {
189
+ zodType += '.optional()';
190
+ }
191
+
192
+ if (attr.min && type === 'String') {
193
+ zodType = zodType.replace(')', `.min(${attr.min})`);
194
+ }
195
+ if (attr.max && type === 'String') {
196
+ zodType = zodType.replace(')', `.max(${attr.max})`);
197
+ }
198
+
199
+ fields.push(` ${name}: ${zodType},`);
200
+ }
201
+
202
+ return fields.join('\n');
203
+ }
204
+
205
+ /**
206
+ * Generate form fields from model attributes
207
+ */
208
+ function generateFormFields(model: any): string {
209
+ let attributes = model.attributes || {};
210
+
211
+ // If attributes is an array (from Object.entries), convert back to object
212
+ if (Array.isArray(attributes)) {
213
+ const obj: Record<string, any> = {};
214
+ attributes.forEach((attr: any, index: number) => {
215
+ if (attr && typeof attr === 'object' && attr.name) {
216
+ obj[attr.name] = attr;
217
+ } else if (Array.isArray(attr) && attr.length >= 2) {
218
+ // Handle [name, config] tuple format
219
+ obj[attr[0]] = attr[1];
220
+ } else {
221
+ obj[index.toString()] = attr;
222
+ }
223
+ });
224
+ attributes = obj;
225
+ }
226
+
227
+ const fields: string[] = [];
228
+ const regularFields: string[] = [];
229
+ const textAreaFields: string[] = [];
230
+
231
+ for (const [name, config] of Object.entries(attributes)) {
232
+ // Skip standard auto-generated fields
233
+ if (name === 'id' || name === 'createdAt' || name === 'updatedAt') continue;
234
+
235
+ const attr: any = config;
236
+
237
+ // Skip fields with auto directive (auto=uuid4, auto=now, etc.)
238
+ if (attr.auto || attr.autoGenerate) continue;
239
+
240
+ // Skip common auto-timestamp fields (workaround for parser not preserving auto directive)
241
+ const autoTimestampFields = ['joinedAt', 'registeredAt', 'enrolledAt', 'startedAt', 'completedAt', 'verifiedAt'];
242
+ if (autoTimestampFields.includes(name) && (attr.type === 'DateTime' || attr.type === 'Timestamp')) {
243
+ continue;
244
+ }
245
+
246
+ const type = attr.type || 'String';
247
+ const label = name.charAt(0).toUpperCase() + name.slice(1);
248
+ const isRequired = attr.required;
249
+
250
+ let inputType = 'text';
251
+ if (type === 'Email') inputType = 'email';
252
+ if (type === 'Number' || type === 'Integer') inputType = 'number';
253
+ if (type === 'Boolean') inputType = 'checkbox';
254
+ if (type === 'DateTime') inputType = 'datetime-local';
255
+ if (type === 'Text') inputType = 'textarea';
256
+
257
+ const field = inputType === 'textarea' ? ` <div className="form-field">
258
+ <label htmlFor="${name}" className="block text-sm font-medium text-gray-300 mb-1">
259
+ ${name}${isRequired ? ' <span className="text-red-400">*</span>' : ''}
260
+ </label>
261
+ <textarea
262
+ id="${name}"
263
+ {...register('${name}')}
264
+ rows={2}
265
+ className={\`w-full px-3 py-2 rounded bg-slate-700 border transition-colors text-gray-200
266
+ \${errors['${name}']
267
+ ? 'border-red-500 focus:border-red-400'
268
+ : 'border-slate-600 focus:border-blue-500'
269
+ } focus:outline-none focus:ring-0 resize-none\`}
270
+ placeholder="Enter ${name}"
271
+ autoComplete="off"
272
+ data-lpignore="true"
273
+ data-form-type="other"
274
+ readOnly
275
+ onFocus={(e) => e.target.removeAttribute('readonly')}
276
+ />
277
+ {errors['${name}'] && (
278
+ <p className="mt-1 text-xs text-red-400">{errors['${name}']?.message}</p>
279
+ )}
280
+ </div>` : inputType === 'checkbox' ? ` <div className="form-field">
281
+ <label htmlFor="${name}" className="flex items-center text-sm font-medium text-gray-300">
282
+ <input
283
+ id="${name}"
284
+ type="checkbox"
285
+ {...register('${name}')}
286
+ className="mr-2"
287
+ autoComplete="off"
288
+ data-lpignore="true"
289
+ />
290
+ ${name}${isRequired ? ' <span className="ml-1 text-red-400">*</span>' : ''}
291
+ </label>
292
+ {errors['${name}'] && (
293
+ <p className="mt-1 text-xs text-red-400">{errors['${name}']?.message}</p>
294
+ )}
295
+ </div>` : ` <div className="form-field">
296
+ <label htmlFor="${name}" className="block text-sm font-medium text-gray-300 mb-1">
297
+ ${name}${isRequired ? ' <span className="text-red-400">*</span>' : ''}
298
+ </label>
299
+ <input
300
+ id="${name}"
301
+ type="${inputType}"
302
+ {...register('${name}')}
303
+ className={\`w-full px-3 py-2 rounded bg-slate-700 border transition-colors text-gray-200
304
+ \${errors['${name}']
305
+ ? 'border-red-500 focus:border-red-400'
306
+ : 'border-slate-600 focus:border-blue-500'
307
+ } focus:outline-none focus:ring-0\`}
308
+ placeholder="Enter ${name}"
309
+ autoComplete="off"
310
+ data-lpignore="true"
311
+ data-form-type="other"
312
+ readOnly
313
+ onFocus={(e) => e.target.removeAttribute('readonly')}
314
+ />
315
+ {errors['${name}'] && (
316
+ <p className="mt-1 text-xs text-red-400">{errors['${name}']?.message}</p>
317
+ )}
318
+ </div>`;
319
+
320
+ // Separate textarea fields from regular fields
321
+ if (inputType === 'textarea') {
322
+ textAreaFields.push(field);
323
+ } else {
324
+ regularFields.push(field);
325
+ }
326
+ }
327
+
328
+ // Build final output with grid layout for regular fields
329
+ let output = '';
330
+
331
+ if (regularFields.length > 0) {
332
+ output += ` <div className="grid grid-cols-1 md:grid-cols-2 gap-4">\n`;
333
+ output += regularFields.join('\n\n');
334
+ output += `\n </div>`;
335
+ }
336
+
337
+ if (textAreaFields.length > 0) {
338
+ if (output) output += '\n\n';
339
+ output += textAreaFields.join('\n\n');
340
+ }
341
+
342
+ return output;
343
+ }
@@ -0,0 +1,54 @@
1
+ /**
2
+ * Frontend Package JSON Generator
3
+ *
4
+ * Generates package.json for the frontend workspace with React dependencies
5
+ */
6
+
7
+ import type { TemplateContext } from '@specverse/engine-realize';
8
+
9
+ /**
10
+ * Generate frontend workspace package.json
11
+ */
12
+ export default function generateFrontendPackageJson(context: TemplateContext): string {
13
+ const { spec } = context;
14
+
15
+ const componentName = spec?.name || 'app';
16
+ const packageName = `${componentName.toLowerCase()}-frontend`;
17
+
18
+ const packageJson = {
19
+ name: packageName,
20
+ version: '1.0.0',
21
+ description: `Frontend for ${spec?.description || componentName}`,
22
+ private: true,
23
+ type: 'module',
24
+ scripts: {
25
+ dev: 'vite',
26
+ build: 'tsc && vite build',
27
+ preview: 'vite preview',
28
+ lint: 'eslint . --ext ts,tsx --report-unused-disable-directives --max-warnings 0',
29
+ 'type-check': 'tsc --noEmit'
30
+ },
31
+ dependencies: {
32
+ 'react': '^18.3.1',
33
+ 'react-dom': '^18.3.1',
34
+ 'react-router-dom': '^6.26.2',
35
+ '@tanstack/react-query': '^5.56.2',
36
+ 'zustand': '^4.5.5',
37
+ 'axios': '^1.7.7'
38
+ },
39
+ devDependencies: {
40
+ '@types/react': '^18.3.9',
41
+ '@types/react-dom': '^18.3.0',
42
+ '@typescript-eslint/eslint-plugin': '^8.7.0',
43
+ '@typescript-eslint/parser': '^8.7.0',
44
+ '@vitejs/plugin-react': '^4.3.1',
45
+ 'eslint': '^9.11.1',
46
+ 'eslint-plugin-react-hooks': '^5.1.0-rc.0',
47
+ 'eslint-plugin-react-refresh': '^0.4.12',
48
+ 'typescript': '^5.6.2',
49
+ 'vite': '^5.4.8'
50
+ }
51
+ };
52
+
53
+ return JSON.stringify(packageJson, null, 2);
54
+ }
@@ -0,0 +1,122 @@
1
+ /**
2
+ * React Hooks Generator
3
+ *
4
+ * Generates React custom hooks for data fetching and mutations
5
+ */
6
+
7
+ import type { TemplateContext } from '@specverse/engine-realize';
8
+
9
+ /**
10
+ * Generate React custom hook for a model
11
+ */
12
+ export default function generateReactHook(context: TemplateContext): string {
13
+ const { model, controller, spec } = context;
14
+
15
+ if (!model) {
16
+ throw new Error('Model is required in template context');
17
+ }
18
+
19
+ const modelName = model.name;
20
+ const hookName = `use${modelName}`;
21
+ const controllerName = `${modelName}Controller`;
22
+
23
+ return `/**
24
+ * ${hookName}
25
+ * Custom React hook for ${modelName} data fetching and mutations
26
+ */
27
+
28
+ import { useQuery, useMutation, useQueryClient } from '@tanstack/react-query';
29
+ import { executeOperation } from '../lib/apiClient';
30
+ import type { ${modelName} } from '../types/${modelName}';
31
+
32
+ interface Use${modelName}Options {
33
+ id?: string;
34
+ list?: boolean;
35
+ filters?: Record<string, any>;
36
+ }
37
+
38
+ /**
39
+ * ${hookName} - Fetch and mutate ${modelName} data
40
+ */
41
+ export function ${hookName}(options: Use${modelName}Options = {}) {
42
+ const queryClient = useQueryClient();
43
+ const { id, list, filters } = options;
44
+
45
+ // Fetch single ${modelName}
46
+ const { data: ${modelName.toLowerCase()}, isLoading: singleLoading, error: singleError } = useQuery({
47
+ queryKey: ['${modelName.toLowerCase()}', id],
48
+ queryFn: async () => {
49
+ if (!id) return null;
50
+ return await executeOperation('${controllerName}', 'retrieve', { id });
51
+ },
52
+ enabled: !!id && !list,
53
+ });
54
+
55
+ // Fetch list of ${modelName}s
56
+ const { data: ${modelName.toLowerCase()}s, isLoading: listLoading, error: listError } = useQuery({
57
+ queryKey: ['${modelName.toLowerCase()}s', filters],
58
+ queryFn: async () => {
59
+ return await executeOperation('${controllerName}', 'list', filters || {});
60
+ },
61
+ enabled: list,
62
+ });
63
+
64
+ const isLoading = list ? listLoading : singleLoading;
65
+ const error = list ? listError : singleError;
66
+
67
+ // Create mutation
68
+ const createMutation = useMutation({
69
+ mutationFn: async (data: Partial<${modelName}>) => {
70
+ return await executeOperation('${controllerName}', 'create', data);
71
+ },
72
+ onSuccess: () => {
73
+ queryClient.invalidateQueries({ queryKey: ['${modelName.toLowerCase()}s'] });
74
+ },
75
+ });
76
+
77
+ // Update mutation
78
+ const updateMutation = useMutation({
79
+ mutationFn: async ({ id, data }: { id: string; data: Partial<${modelName}> }) => {
80
+ return await executeOperation('${controllerName}', 'update', { id, ...data });
81
+ },
82
+ onSuccess: (_, variables) => {
83
+ queryClient.invalidateQueries({ queryKey: ['${modelName.toLowerCase()}', variables.id] });
84
+ queryClient.invalidateQueries({ queryKey: ['${modelName.toLowerCase()}s'] });
85
+ },
86
+ });
87
+
88
+ // Delete mutation
89
+ const deleteMutation = useMutation({
90
+ mutationFn: async (id: string) => {
91
+ return await executeOperation('${controllerName}', 'delete', { id });
92
+ },
93
+ onSuccess: () => {
94
+ queryClient.invalidateQueries({ queryKey: ['${modelName.toLowerCase()}s'] });
95
+ },
96
+ });
97
+
98
+ // Refetch functions
99
+ const refetch = () => {
100
+ if (list) {
101
+ queryClient.invalidateQueries({ queryKey: ['${modelName.toLowerCase()}s'] });
102
+ } else if (id) {
103
+ queryClient.invalidateQueries({ queryKey: ['${modelName.toLowerCase()}', id] });
104
+ }
105
+ };
106
+
107
+ return {
108
+ ${modelName.toLowerCase()},
109
+ ${modelName.toLowerCase()}s,
110
+ isLoading,
111
+ error,
112
+ refetch,
113
+ create: createMutation.mutateAsync,
114
+ update: updateMutation.mutateAsync,
115
+ delete: deleteMutation.mutateAsync,
116
+ isCreating: createMutation.isPending,
117
+ isUpdating: updateMutation.isPending,
118
+ isDeleting: deleteMutation.isPending,
119
+ };
120
+ }
121
+ `;
122
+ }