@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,869 @@
1
+ /**
2
+ * Ant Design (antd) Adapter
3
+ *
4
+ * Maps all 49 atomic component types to Ant Design components.
5
+ *
6
+ * @see https://ant.design/components/overview/
7
+ * @see ../../shared/atomic-components-registry.ts
8
+ */
9
+
10
+ import type { ComponentLibraryAdapter, RenderContext } from '../../shared/adapter-types.js';
11
+
12
+ /**
13
+ * Helper to render props object
14
+ */
15
+ function renderProps(properties: Record<string, any>, exclude: string[] = []): string {
16
+ return Object.entries(properties)
17
+ .filter(([key]) => !exclude.includes(key))
18
+ .map(([key, value]) => {
19
+ if (typeof value === 'boolean') return value ? key : '';
20
+ if (typeof value === 'string') return `${key}="${value}"`;
21
+ return `${key}={${JSON.stringify(value)}}`;
22
+ })
23
+ .filter(Boolean)
24
+ .join(' ');
25
+ }
26
+
27
+ /**
28
+ * Ant Design Component Library Adapter
29
+ */
30
+ export const antdAdapter: ComponentLibraryAdapter = {
31
+ name: 'Ant Design',
32
+ version: '5.x',
33
+ description: 'Ant Design (antd) component library adapter',
34
+
35
+ baseDependencies: [
36
+ { name: 'antd', version: '^5.15.0' },
37
+ { name: '@ant-design/icons', version: '^5.2.0' },
38
+ ],
39
+
40
+ config: {
41
+ importPrefix: 'antd',
42
+ importStyle: 'named',
43
+ },
44
+
45
+ components: {
46
+ // ====================================================================
47
+ // DATA DISPLAY (9 types)
48
+ // ====================================================================
49
+
50
+ table: {
51
+ imports: ["import { Table } from 'antd'"],
52
+ render: (ctx: RenderContext) => {
53
+ const { properties, model } = ctx;
54
+ const columns = properties.columns || ['id'];
55
+ const modelVar = model?.name?.toLowerCase() || 'item';
56
+
57
+ return `<Table
58
+ dataSource={${modelVar}s}
59
+ columns={[
60
+ ${columns.map((col: string) => `{ title: '${col}', dataIndex: '${col}', key: '${col}'${properties.sortable !== false ? ", sorter: true" : ''} }`).join(',\n ')}
61
+ ]}
62
+ ${properties.pagination !== false ? `pagination={{ pageSize: ${properties.pageSize || 10} }}` : 'pagination={false}'}
63
+ ${properties.size ? `size="${properties.size}"` : ''}
64
+ ${properties.bordered ? 'bordered' : ''}
65
+ rowKey="id"
66
+ />`;
67
+ },
68
+ },
69
+
70
+ list: {
71
+ imports: ["import { List } from 'antd'"],
72
+ render: (ctx: RenderContext) => {
73
+ const { properties, model } = ctx;
74
+ const modelVar = model?.name?.toLowerCase() || 'item';
75
+
76
+ return `<List
77
+ dataSource={${modelVar}s}
78
+ ${properties.bordered ? 'bordered' : ''}
79
+ ${properties.size ? `size="${properties.size}"` : ''}
80
+ ${properties.grid ? `grid={${JSON.stringify(properties.grid)}}` : ''}
81
+ renderItem={(${modelVar}) => (
82
+ <List.Item>
83
+ <List.Item.Meta
84
+ ${properties.showAvatar ? `avatar={<Avatar src={${modelVar}.avatar} />}` : ''}
85
+ title={${modelVar}.${properties.primaryField || 'name'}}
86
+ ${properties.secondaryField ? `description={${modelVar}.${properties.secondaryField}}` : ''}
87
+ />
88
+ </List.Item>
89
+ )}
90
+ />`;
91
+ },
92
+ },
93
+
94
+ grid: {
95
+ imports: ["import { Row, Col } from 'antd'"],
96
+ render: (ctx: RenderContext) => {
97
+ const { properties, children } = ctx;
98
+ const gutter = properties.gutter || 16;
99
+
100
+ return `<Row gutter={${gutter}}>
101
+ {items?.map((item) => (
102
+ <Col xs={${properties.xs || 24}} sm={${properties.sm || 12}} md={${properties.md || 8}} lg={${properties.lg || 6}} key={item.id}>
103
+ ${children || '{/* Item content */}'}
104
+ </Col>
105
+ ))}
106
+ </Row>`;
107
+ },
108
+ },
109
+
110
+ card: {
111
+ imports: ["import { Card } from 'antd'"],
112
+ render: (ctx: RenderContext) => {
113
+ const { properties, children } = ctx;
114
+
115
+ return `<Card
116
+ ${properties.title ? `title="${properties.title}"` : ''}
117
+ ${properties.bordered !== false ? 'bordered' : 'bordered={false}'}
118
+ ${properties.hoverable ? 'hoverable' : ''}
119
+ ${properties.size ? `size="${properties.size}"` : ''}
120
+ ${properties.image ? `cover={<img alt="${properties.title || 'Card'}" src="${properties.image}" />}` : ''}
121
+ ${properties.actions ? `actions={[${properties.actions.map((a: string) => `<${a} />`).join(', ')}]}` : ''}
122
+ >
123
+ ${children || '{content}'}
124
+ </Card>`;
125
+ },
126
+ },
127
+
128
+ chart: {
129
+ imports: [
130
+ "// Note: Ant Design doesn't include charts. Use @ant-design/charts or recharts",
131
+ "// import { Line, Bar, Pie } from '@ant-design/charts'",
132
+ ],
133
+ render: (ctx: RenderContext) => {
134
+ const { properties } = ctx;
135
+ const chartType = properties.chartType || 'line';
136
+ const ChartComponent = chartType === 'line' ? 'Line' : chartType === 'bar' ? 'Bar' : 'Pie';
137
+
138
+ return `{/* TODO: Integrate @ant-design/charts */}
139
+ {/* <${ChartComponent}
140
+ data={data}
141
+ ${chartType !== 'pie' ? 'xField="name" yField="value"' : 'angleField="value" colorField="name"'}
142
+ ${properties.responsive !== false ? 'responsive' : ''}
143
+ ${properties.showLegend !== false ? '' : 'legend={false}'}
144
+ /> */}`;
145
+ },
146
+ dependencies: [
147
+ { name: '@ant-design/charts', version: '^2.0.0' },
148
+ ],
149
+ },
150
+
151
+ tree: {
152
+ imports: ["import { Tree } from 'antd'"],
153
+ render: (ctx: RenderContext) => {
154
+ const { properties } = ctx;
155
+
156
+ return `<Tree
157
+ treeData={treeData}
158
+ ${properties.checkable ? 'checkable' : ''}
159
+ ${properties.defaultExpanded ? 'defaultExpandAll' : ''}
160
+ ${properties.selectable !== false ? '' : 'selectable={false}'}
161
+ ${properties.showLine ? 'showLine' : ''}
162
+ />`;
163
+ },
164
+ },
165
+
166
+ timeline: {
167
+ imports: ["import { Timeline } from 'antd'"],
168
+ render: (ctx: RenderContext) => {
169
+ const { properties } = ctx;
170
+ const mode = properties.position === 'alternate' ? 'alternate' : properties.position === 'right' ? 'right' : 'left';
171
+
172
+ return `<Timeline mode="${mode}">
173
+ {events?.map((event) => (
174
+ <Timeline.Item key={event.id} ${properties.showDateMarkers ? `label={event.date}` : ''}>
175
+ {event.title}
176
+ </Timeline.Item>
177
+ ))}
178
+ </Timeline>`;
179
+ },
180
+ },
181
+
182
+ avatar: {
183
+ imports: ["import { Avatar } from 'antd'"],
184
+ render: (ctx: RenderContext) => {
185
+ const { properties } = ctx;
186
+ const size = properties.size === 'small' ? 'small' : properties.size === 'large' ? 'large' : 'default';
187
+
188
+ return `<Avatar
189
+ ${properties.src ? `src="${properties.src}"` : ''}
190
+ ${properties.icon ? `icon={<${properties.icon} />}` : ''}
191
+ size={${typeof properties.size === 'number' ? properties.size : `"${size}"`}}
192
+ ${properties.shape ? `shape="${properties.shape}"` : ''}
193
+ >
194
+ ${!properties.src && !properties.icon ? '{initials}' : ''}
195
+ </Avatar>`;
196
+ },
197
+ },
198
+
199
+ image: {
200
+ imports: ["import { Image } from 'antd'"],
201
+ render: (ctx: RenderContext) => {
202
+ const { properties } = ctx;
203
+
204
+ return `<Image
205
+ src="${properties.src}"
206
+ alt="${properties.alt || 'Image'}"
207
+ ${properties.width ? `width={${properties.width}}` : ''}
208
+ ${properties.height ? `height={${properties.height}}` : ''}
209
+ ${properties.preview !== false ? '' : 'preview={false}'}
210
+ ${properties.placeholder ? 'placeholder' : ''}
211
+ />`;
212
+ },
213
+ },
214
+
215
+ // ====================================================================
216
+ // FORMS & INPUTS (11 types)
217
+ // ====================================================================
218
+
219
+ form: {
220
+ imports: ["import { Form } from 'antd'"],
221
+ render: (ctx: RenderContext) => {
222
+ const { properties, children } = ctx;
223
+
224
+ return `<Form
225
+ layout="${properties.layout || 'vertical'}"
226
+ onFinish={handleSubmit}
227
+ ${properties.initialValues ? 'initialValues={initialValues}' : ''}
228
+ >
229
+ ${children || '{/* Form items */}'}
230
+ </Form>`;
231
+ },
232
+ },
233
+
234
+ input: {
235
+ imports: ["import { Input, Form } from 'antd'"],
236
+ render: (ctx: RenderContext) => {
237
+ const { properties } = ctx;
238
+
239
+ return `<Form.Item
240
+ label="${properties.label || ''}"
241
+ name="${properties.name || 'field'}"
242
+ ${properties.required ? 'rules={[{ required: true, message: "Please input!" }]}' : ''}
243
+ >
244
+ <Input
245
+ type="${properties.type || 'text'}"
246
+ placeholder="${properties.placeholder || ''}"
247
+ ${properties.disabled ? 'disabled' : ''}
248
+ ${properties.prefix ? `prefix={<${properties.prefix} />}` : ''}
249
+ ${properties.suffix ? `suffix={<${properties.suffix} />}` : ''}
250
+ />
251
+ </Form.Item>`;
252
+ },
253
+ },
254
+
255
+ textarea: {
256
+ imports: ["import { Input, Form } from 'antd'"],
257
+ render: (ctx: RenderContext) => {
258
+ const { properties } = ctx;
259
+
260
+ return `<Form.Item
261
+ label="${properties.label || ''}"
262
+ name="${properties.name || 'field'}"
263
+ ${properties.required ? 'rules={[{ required: true }]}' : ''}
264
+ >
265
+ <Input.TextArea
266
+ placeholder="${properties.placeholder || ''}"
267
+ rows={${properties.rows || 4}}
268
+ ${properties.maxLength ? `maxLength={${properties.maxLength}}` : ''}
269
+ ${properties.showCount ? 'showCount' : ''}
270
+ />
271
+ </Form.Item>`;
272
+ },
273
+ },
274
+
275
+ select: {
276
+ imports: ["import { Select, Form } from 'antd'"],
277
+ render: (ctx: RenderContext) => {
278
+ const { properties } = ctx;
279
+
280
+ return `<Form.Item
281
+ label="${properties.label || 'Select'}"
282
+ name="${properties.name || 'field'}"
283
+ ${properties.required ? 'rules={[{ required: true }]}' : ''}
284
+ >
285
+ <Select
286
+ placeholder="${properties.placeholder || 'Select...'}"
287
+ ${properties.mode ? `mode="${properties.mode}"` : ''}
288
+ ${properties.allowClear ? 'allowClear' : ''}
289
+ ${properties.showSearch ? 'showSearch' : ''}
290
+ options={${properties.options || 'options'}}
291
+ />
292
+ </Form.Item>`;
293
+ },
294
+ },
295
+
296
+ checkbox: {
297
+ imports: ["import { Checkbox, Form } from 'antd'"],
298
+ render: (ctx: RenderContext) => {
299
+ const { properties } = ctx;
300
+
301
+ return `<Form.Item name="${properties.name || 'field'}" valuePropName="checked">
302
+ <Checkbox ${properties.disabled ? 'disabled' : ''}>
303
+ ${properties.label || ''}
304
+ </Checkbox>
305
+ </Form.Item>`;
306
+ },
307
+ },
308
+
309
+ radio: {
310
+ imports: ["import { Radio, Form } from 'antd'"],
311
+ render: (ctx: RenderContext) => {
312
+ const { properties } = ctx;
313
+
314
+ return `<Form.Item label="${properties.label || 'Options'}" name="${properties.name || 'field'}">
315
+ <Radio.Group ${properties.buttonStyle ? `buttonStyle="${properties.buttonStyle}"` : ''}>
316
+ {${properties.options || 'options'}?.map((option) => (
317
+ <Radio${properties.buttonStyle ? '.Button' : ''} key={option.value} value={option.value}>
318
+ {option.label}
319
+ </Radio${properties.buttonStyle ? '.Button' : ''}>
320
+ ))}
321
+ </Radio.Group>
322
+ </Form.Item>`;
323
+ },
324
+ },
325
+
326
+ slider: {
327
+ imports: ["import { Slider, Form } from 'antd'"],
328
+ render: (ctx: RenderContext) => {
329
+ const { properties } = ctx;
330
+
331
+ return `<Form.Item label="${properties.label || ''}" name="${properties.name || 'field'}">
332
+ <Slider
333
+ min={${properties.min || 0}}
334
+ max={${properties.max || 100}}
335
+ step={${properties.step || 1}}
336
+ ${properties.marks ? 'marks={marks}' : ''}
337
+ ${properties.range ? 'range' : ''}
338
+ ${properties.vertical ? 'vertical' : ''}
339
+ />
340
+ </Form.Item>`;
341
+ },
342
+ },
343
+
344
+ switch: {
345
+ imports: ["import { Switch, Form } from 'antd'"],
346
+ render: (ctx: RenderContext) => {
347
+ const { properties } = ctx;
348
+
349
+ return `<Form.Item label="${properties.label || ''}" name="${properties.name || 'field'}" valuePropName="checked">
350
+ <Switch
351
+ ${properties.disabled ? 'disabled' : ''}
352
+ ${properties.checkedChildren ? `checkedChildren="${properties.checkedChildren}"` : ''}
353
+ ${properties.unCheckedChildren ? `unCheckedChildren="${properties.unCheckedChildren}"` : ''}
354
+ />
355
+ </Form.Item>`;
356
+ },
357
+ },
358
+
359
+ autocomplete: {
360
+ imports: ["import { AutoComplete, Form } from 'antd'"],
361
+ render: (ctx: RenderContext) => {
362
+ const { properties } = ctx;
363
+
364
+ return `<Form.Item label="${properties.label || ''}" name="${properties.name || 'field'}">
365
+ <AutoComplete
366
+ options={${properties.options || 'options'}}
367
+ placeholder="${properties.placeholder || 'Type to search...'}"
368
+ filterOption={(inputValue, option) =>
369
+ option!.value.toUpperCase().indexOf(inputValue.toUpperCase()) !== -1
370
+ }
371
+ ${properties.allowClear ? 'allowClear' : ''}
372
+ />
373
+ </Form.Item>`;
374
+ },
375
+ },
376
+
377
+ datepicker: {
378
+ imports: ["import { DatePicker, Form } from 'antd'"],
379
+ render: (ctx: RenderContext) => {
380
+ const { properties } = ctx;
381
+
382
+ return `<Form.Item label="${properties.label || 'Select Date'}" name="${properties.name || 'field'}">
383
+ <DatePicker
384
+ ${properties.format ? `format="${properties.format}"` : ''}
385
+ ${properties.showTime ? 'showTime' : ''}
386
+ ${properties.picker ? `picker="${properties.picker}"` : ''}
387
+ style={{ width: '100%' }}
388
+ />
389
+ </Form.Item>`;
390
+ },
391
+ },
392
+
393
+ timepicker: {
394
+ imports: ["import { TimePicker, Form } from 'antd'"],
395
+ render: (ctx: RenderContext) => {
396
+ const { properties } = ctx;
397
+
398
+ return `<Form.Item label="${properties.label || 'Select Time'}" name="${properties.name || 'field'}">
399
+ <TimePicker
400
+ ${properties.format ? `format="${properties.format}"` : ''}
401
+ ${properties.use12Hours ? 'use12Hours' : ''}
402
+ style={{ width: '100%' }}
403
+ />
404
+ </Form.Item>`;
405
+ },
406
+ },
407
+
408
+ // ====================================================================
409
+ // ACTIONS (5 types)
410
+ // ====================================================================
411
+
412
+ button: {
413
+ imports: ["import { Button } from 'antd'"],
414
+ render: (ctx: RenderContext) => {
415
+ const { properties } = ctx;
416
+ const type = { primary: 'primary', secondary: 'default', danger: 'primary' }[properties.variant || 'primary'] || 'default';
417
+ const danger = properties.variant === 'danger';
418
+
419
+ return `<Button
420
+ type="${type}"
421
+ ${danger ? 'danger' : ''}
422
+ size="${properties.size || 'middle'}"
423
+ ${properties.disabled ? 'disabled' : ''}
424
+ ${properties.loading ? 'loading' : ''}
425
+ ${properties.block ? 'block' : ''}
426
+ ${properties.icon ? `icon={<${properties.icon} />}` : ''}
427
+ ${properties.shape ? `shape="${properties.shape}"` : ''}
428
+ onClick={handleClick}
429
+ >
430
+ ${properties.label || 'Button'}
431
+ </Button>`;
432
+ },
433
+ },
434
+
435
+ 'button-group': {
436
+ imports: ["import { Button, Space } from 'antd'"],
437
+ render: (ctx: RenderContext) => {
438
+ const { properties, children } = ctx;
439
+
440
+ return `<Space.Compact ${properties.size ? `size="${properties.size}"` : ''}>
441
+ ${children || '{/* Buttons */}'}
442
+ </Space.Compact>`;
443
+ },
444
+ },
445
+
446
+ link: {
447
+ imports: ["import { Typography } from 'antd'"],
448
+ render: (ctx: RenderContext) => {
449
+ const { properties } = ctx;
450
+
451
+ return `<Typography.Link
452
+ href="${properties.href || '#'}"
453
+ ${properties.disabled ? 'disabled' : ''}
454
+ ${properties.underline === false ? 'underline={false}' : ''}
455
+ ${properties.external ? 'target="_blank"' : ''}
456
+ >
457
+ ${properties.label || 'Link'}
458
+ </Typography.Link>`;
459
+ },
460
+ },
461
+
462
+ icon: {
463
+ imports: ["// Import specific icons: import { HomeOutlined, SettingOutlined } from '@ant-design/icons'"],
464
+ render: (ctx: RenderContext) => {
465
+ const { properties } = ctx;
466
+
467
+ return `<${properties.name || 'Icon'}Outlined style={{ fontSize: '${properties.size === 'small' ? '12px' : properties.size === 'large' ? '24px' : '16px'}' }} />`;
468
+ },
469
+ },
470
+
471
+ menu: {
472
+ imports: ["import { Menu, Dropdown, Button } from 'antd'", "import { MoreOutlined } from '@ant-design/icons'"],
473
+ render: (ctx: RenderContext) => {
474
+ const { properties } = ctx;
475
+
476
+ return `<Dropdown
477
+ menu={{
478
+ items: ${properties.items || 'menuItems'},
479
+ onClick: handleMenuClick
480
+ }}
481
+ trigger={['click']}
482
+ >
483
+ <Button icon={<MoreOutlined />} />
484
+ </Dropdown>`;
485
+ },
486
+ },
487
+
488
+ // ====================================================================
489
+ // OVERLAYS & FEEDBACK (9 types)
490
+ // ====================================================================
491
+
492
+ modal: {
493
+ imports: ["import { Modal } from 'antd'"],
494
+ render: (ctx: RenderContext) => {
495
+ const { properties, children } = ctx;
496
+
497
+ return `<Modal
498
+ title="${properties.title || 'Modal'}"
499
+ open={open}
500
+ onOk={handleOk}
501
+ onCancel={handleCancel}
502
+ ${properties.width ? `width={${properties.width}}` : ''}
503
+ ${properties.centered ? 'centered' : ''}
504
+ ${properties.footer === false ? 'footer={null}' : ''}
505
+ >
506
+ ${children || '{/* Content */}'}
507
+ </Modal>`;
508
+ },
509
+ },
510
+
511
+ dialog: {
512
+ imports: ["import { Modal } from 'antd'"],
513
+ render: (ctx: RenderContext) => {
514
+ const { properties, children } = ctx;
515
+
516
+ return `<Modal
517
+ title="${properties.title || 'Dialog'}"
518
+ open={open}
519
+ onOk={handleOk}
520
+ onCancel={handleCancel}
521
+ ${properties.closable !== false ? '' : 'closable={false}'}
522
+ ${properties.maskClosable !== false ? '' : 'maskClosable={false}'}
523
+ >
524
+ ${children || '{/* Content */}'}
525
+ </Modal>`;
526
+ },
527
+ },
528
+
529
+ drawer: {
530
+ imports: ["import { Drawer } from 'antd'"],
531
+ render: (ctx: RenderContext) => {
532
+ const { properties, children } = ctx;
533
+ const placement = properties.position === 'left' ? 'left' : properties.position === 'right' ? 'right' : properties.position === 'top' ? 'top' : 'bottom';
534
+
535
+ return `<Drawer
536
+ title="${properties.title || 'Drawer'}"
537
+ placement="${placement}"
538
+ open={open}
539
+ onClose={handleClose}
540
+ ${properties.width ? `width={${properties.width}}` : ''}
541
+ ${properties.height ? `height={${properties.height}}` : ''}
542
+ >
543
+ ${children || '{/* Content */}'}
544
+ </Drawer>`;
545
+ },
546
+ },
547
+
548
+ popover: {
549
+ imports: ["import { Popover, Button } from 'antd'"],
550
+ render: (ctx: RenderContext) => {
551
+ const { properties, children } = ctx;
552
+
553
+ return `<Popover
554
+ content={${properties.content ? `"${properties.content}"` : 'content'}}
555
+ title="${properties.title || ''}"
556
+ trigger="${properties.trigger || 'click'}"
557
+ placement="${properties.placement || 'top'}"
558
+ >
559
+ ${children || '<Button>Trigger</Button>'}
560
+ </Popover>`;
561
+ },
562
+ },
563
+
564
+ tooltip: {
565
+ imports: ["import { Tooltip } from 'antd'"],
566
+ render: (ctx: RenderContext) => {
567
+ const { properties, children } = ctx;
568
+
569
+ return `<Tooltip
570
+ title="${properties.content || ''}"
571
+ placement="${properties.placement || 'top'}"
572
+ ${properties.color ? `color="${properties.color}"` : ''}
573
+ >
574
+ ${children || '<span>{children}</span>'}
575
+ </Tooltip>`;
576
+ },
577
+ },
578
+
579
+ alert: {
580
+ imports: ["import { Alert } from 'antd'"],
581
+ render: (ctx: RenderContext) => {
582
+ const { properties } = ctx;
583
+ const type = properties.variant === 'error' ? 'error' : properties.variant === 'warning' ? 'warning' : properties.variant === 'success' ? 'success' : 'info';
584
+
585
+ return `<Alert
586
+ message="${properties.title || ''}"
587
+ description="${properties.message || ''}"
588
+ type="${type}"
589
+ ${properties.closable ? 'closable' : ''}
590
+ ${properties.showIcon !== false ? 'showIcon' : ''}
591
+ ${properties.banner ? 'banner' : ''}
592
+ />`;
593
+ },
594
+ },
595
+
596
+ snackbar: {
597
+ imports: ["import { message } from 'antd'"],
598
+ render: (ctx: RenderContext) => {
599
+ const { properties } = ctx;
600
+
601
+ return `{/* Use Ant Design message API */}
602
+ {/* message.${properties.variant || 'info'}('${properties.message || 'Notification'}', ${properties.duration || 3}) */}`;
603
+ },
604
+ },
605
+
606
+ badge: {
607
+ imports: ["import { Badge } from 'antd'"],
608
+ render: (ctx: RenderContext) => {
609
+ const { properties, children } = ctx;
610
+
611
+ return `<Badge
612
+ count={${properties.count || 0}}
613
+ ${properties.dot ? 'dot' : ''}
614
+ ${properties.status ? `status="${properties.status}"` : ''}
615
+ ${properties.color ? `color="${properties.color}"` : ''}
616
+ ${properties.overflowCount ? `overflowCount={${properties.overflowCount}}` : ''}
617
+ >
618
+ ${children || '{children}'}
619
+ </Badge>`;
620
+ },
621
+ },
622
+
623
+ spinner: {
624
+ imports: ["import { Spin } from 'antd'"],
625
+ render: (ctx: RenderContext) => {
626
+ const { properties } = ctx;
627
+ const size = properties.size === 'small' ? 'small' : properties.size === 'large' ? 'large' : 'default';
628
+
629
+ return `<Spin size="${size}" ${properties.tip ? `tip="${properties.tip}"` : ''} />`;
630
+ },
631
+ },
632
+
633
+ // ====================================================================
634
+ // NAVIGATION (5 types)
635
+ // ====================================================================
636
+
637
+ tabs: {
638
+ imports: ["import { Tabs } from 'antd'"],
639
+ render: (ctx: RenderContext) => {
640
+ const { properties } = ctx;
641
+
642
+ return `<Tabs
643
+ activeKey={activeKey}
644
+ onChange={handleChange}
645
+ ${properties.type ? `type="${properties.type}"` : ''}
646
+ ${properties.tabPosition ? `tabPosition="${properties.tabPosition}"` : ''}
647
+ items={${properties.items || 'tabItems'}}
648
+ />`;
649
+ },
650
+ },
651
+
652
+ breadcrumb: {
653
+ imports: ["import { Breadcrumb } from 'antd'"],
654
+ render: (ctx: RenderContext) => {
655
+ const { properties } = ctx;
656
+
657
+ return `<Breadcrumb
658
+ items={${properties.items || 'breadcrumbItems'}}
659
+ ${properties.separator ? `separator="${properties.separator}"` : ''}
660
+ />`;
661
+ },
662
+ },
663
+
664
+ navbar: {
665
+ imports: ["import { Layout, Menu } from 'antd'", "const { Header } = Layout"],
666
+ render: (ctx: RenderContext) => {
667
+ const { properties, children } = ctx;
668
+
669
+ return `<Header ${properties.className ? `className="${properties.className}"` : ''}>
670
+ <div style={{ float: 'left', color: '#fff', fontSize: '18px', fontWeight: 'bold' }}>
671
+ ${properties.brand || 'App'}
672
+ </div>
673
+ ${children || '<Menu theme="dark" mode="horizontal" items={menuItems} />'}
674
+ </Header>`;
675
+ },
676
+ },
677
+
678
+ sidebar: {
679
+ imports: ["import { Layout, Menu } from 'antd'", "const { Sider } = Layout"],
680
+ render: (ctx: RenderContext) => {
681
+ const { properties } = ctx;
682
+
683
+ return `<Sider
684
+ ${properties.collapsible ? 'collapsible' : ''}
685
+ ${properties.collapsed !== undefined ? `collapsed={${properties.collapsed}}` : ''}
686
+ width={${properties.width || 200}}
687
+ ${properties.theme ? `theme="${properties.theme}"` : ''}
688
+ >
689
+ <Menu
690
+ mode="inline"
691
+ ${properties.theme ? `theme="${properties.theme}"` : ''}
692
+ items={${properties.items || 'menuItems'}}
693
+ />
694
+ </Sider>`;
695
+ },
696
+ },
697
+
698
+ pagination: {
699
+ imports: ["import { Pagination } from 'antd'"],
700
+ render: (ctx: RenderContext) => {
701
+ const { properties } = ctx;
702
+
703
+ return `<Pagination
704
+ current={current}
705
+ total={${properties.total || 100}}
706
+ pageSize={${properties.pageSize || 10}}
707
+ onChange={handleChange}
708
+ ${properties.showSizeChanger ? 'showSizeChanger' : ''}
709
+ ${properties.showQuickJumper ? 'showQuickJumper' : ''}
710
+ ${properties.showTotal ? `showTotal={(total) => \`Total \${total} items\`}` : ''}
711
+ ${properties.size ? `size="${properties.size}"` : ''}
712
+ />`;
713
+ },
714
+ },
715
+
716
+ // ====================================================================
717
+ // LAYOUT (6 types)
718
+ // ====================================================================
719
+
720
+ accordion: {
721
+ imports: ["import { Collapse } from 'antd'"],
722
+ render: (ctx: RenderContext) => {
723
+ const { properties } = ctx;
724
+
725
+ return `<Collapse
726
+ ${properties.accordion ? 'accordion' : ''}
727
+ ${properties.bordered !== false ? '' : 'bordered={false}'}
728
+ ${properties.expandIconPosition ? `expandIconPosition="${properties.expandIconPosition}"` : ''}
729
+ items={${properties.items || 'collapseItems'}}
730
+ />`;
731
+ },
732
+ },
733
+
734
+ carousel: {
735
+ imports: ["import { Carousel } from 'antd'"],
736
+ render: (ctx: RenderContext) => {
737
+ const { properties } = ctx;
738
+
739
+ return `<Carousel
740
+ ${properties.autoplay ? 'autoplay' : ''}
741
+ ${properties.autoplaySpeed ? `autoplaySpeed={${properties.autoplaySpeed}}` : ''}
742
+ ${properties.dots !== false ? '' : 'dots={false}'}
743
+ ${properties.effect ? `effect="${properties.effect}"` : ''}
744
+ >
745
+ {items?.map((item) => (
746
+ <div key={item.id}>{item.content}</div>
747
+ ))}
748
+ </Carousel>`;
749
+ },
750
+ },
751
+
752
+ container: {
753
+ imports: ["import { Layout } from 'antd'", "const { Content } = Layout"],
754
+ render: (ctx: RenderContext) => {
755
+ const { properties, children } = ctx;
756
+
757
+ return `<Content style={{ padding: '${properties.padding || '24px'}', ${properties.maxWidth ? `maxWidth: '${properties.maxWidth}'` : ''} }}>
758
+ ${children || '{/* Content */}'}
759
+ </Content>`;
760
+ },
761
+ },
762
+
763
+ divider: {
764
+ imports: ["import { Divider } from 'antd'"],
765
+ render: (ctx: RenderContext) => {
766
+ const { properties } = ctx;
767
+
768
+ return `<Divider
769
+ ${properties.type === 'vertical' ? 'type="vertical"' : ''}
770
+ ${properties.dashed ? 'dashed' : ''}
771
+ ${properties.orientation ? `orientation="${properties.orientation}"` : ''}
772
+ >
773
+ ${properties.text || ''}
774
+ </Divider>`;
775
+ },
776
+ },
777
+
778
+ header: {
779
+ imports: ["import { Layout, Typography } from 'antd'", "const { Header } = Layout", "const { Title } = Typography"],
780
+ render: (ctx: RenderContext) => {
781
+ const { properties, children } = ctx;
782
+
783
+ return `<Header style={{ padding: '16px 24px', background: '#fff', borderBottom: '1px solid #f0f0f0' }}>
784
+ ${properties.title ? `<Title level={4}>${properties.title}</Title>` : ''}
785
+ ${properties.subtitle ? `<Typography.Text type="secondary">${properties.subtitle}</Typography.Text>` : ''}
786
+ ${children || ''}
787
+ </Header>`;
788
+ },
789
+ },
790
+
791
+ footer: {
792
+ imports: ["import { Layout, Typography } from 'antd'", "const { Footer } = Layout"],
793
+ render: (ctx: RenderContext) => {
794
+ const { properties, children } = ctx;
795
+
796
+ return `<Footer style={{ textAlign: 'center', padding: '24px 50px' }}>
797
+ ${properties.copyright ? `<Typography.Text>${properties.copyright}</Typography.Text>` : ''}
798
+ ${children || ''}
799
+ </Footer>`;
800
+ },
801
+ },
802
+
803
+ // ====================================================================
804
+ // PROGRESS (2 types)
805
+ // ====================================================================
806
+
807
+ 'progress-bar': {
808
+ imports: ["import { Progress } from 'antd'"],
809
+ render: (ctx: RenderContext) => {
810
+ const { properties } = ctx;
811
+
812
+ return `<Progress
813
+ percent={${properties.value || 0}}
814
+ ${properties.status ? `status="${properties.status}"` : ''}
815
+ ${properties.showInfo !== false ? '' : 'showInfo={false}'}
816
+ ${properties.strokeColor ? `strokeColor="${properties.strokeColor}"` : ''}
817
+ ${properties.size ? `size="${properties.size}"` : ''}
818
+ />`;
819
+ },
820
+ },
821
+
822
+ 'progress-circle': {
823
+ imports: ["import { Progress } from 'antd'"],
824
+ render: (ctx: RenderContext) => {
825
+ const { properties } = ctx;
826
+
827
+ return `<Progress
828
+ type="circle"
829
+ percent={${properties.value || 0}}
830
+ ${properties.status ? `status="${properties.status}"` : ''}
831
+ ${properties.width ? `width={${properties.width}}` : ''}
832
+ ${properties.strokeColor ? `strokeColor="${properties.strokeColor}"` : ''}
833
+ />`;
834
+ },
835
+ },
836
+
837
+ // ====================================================================
838
+ // SPECIALIZED (2 types)
839
+ // ====================================================================
840
+
841
+ searchBar: {
842
+ imports: ["import { Input } from 'antd'", "import { SearchOutlined } from '@ant-design/icons'"],
843
+ render: (ctx: RenderContext) => {
844
+ const { properties } = ctx;
845
+
846
+ return `<Input.Search
847
+ placeholder="${properties.placeholder || 'Search...'}"
848
+ ${properties.enterButton !== false ? 'enterButton' : ''}
849
+ ${properties.loading ? 'loading' : ''}
850
+ ${properties.size ? `size="${properties.size}"` : ''}
851
+ onSearch={handleSearch}
852
+ />`;
853
+ },
854
+ },
855
+
856
+ filterPanel: {
857
+ imports: ["import { Card, Space } from 'antd'"],
858
+ render: (ctx: RenderContext) => {
859
+ const { properties, children } = ctx;
860
+
861
+ return `<Card title="Filters" ${properties.bordered !== false ? '' : 'bordered={false}'}>
862
+ <Space direction="vertical" style={{ width: '100%' }}>
863
+ ${children || '{/* Filter controls */}'}
864
+ </Space>
865
+ </Card>`;
866
+ },
867
+ },
868
+ },
869
+ };