@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,806 @@
1
+ /**
2
+ * shadcn/ui Adapter
3
+ *
4
+ * Maps all 49 SpecVerse atomic component types to shadcn/ui components.
5
+ * shadcn/ui: https://ui.shadcn.com/
6
+ *
7
+ * Architecture:
8
+ * - Uses @/components/ui/* import pattern
9
+ * - Tailwind CSS for styling
10
+ * - Radix UI primitives underneath
11
+ */
12
+
13
+ import type { ComponentLibraryAdapter, RenderContext } from '../../shared/adapter-types.js';
14
+ import { renderProps } from '../../shared/adapter-types.js';
15
+
16
+ export const shadcnAdapter: ComponentLibraryAdapter = {
17
+ name: 'shadcn/ui',
18
+ version: 'latest',
19
+ description: 'shadcn/ui component library adapter',
20
+
21
+ baseDependencies: [
22
+ { name: 'react', version: '^18.2.0' },
23
+ { name: 'react-dom', version: '^18.2.0' },
24
+ { name: 'tailwindcss', version: '^3.4.0' },
25
+ { name: '@radix-ui/react-icons', version: '^1.3.0' },
26
+ { name: 'class-variance-authority', version: '^0.7.0' },
27
+ { name: 'clsx', version: '^2.0.0' },
28
+ { name: 'tailwind-merge', version: '^2.0.0' },
29
+ ],
30
+
31
+ config: {
32
+ importPrefix: '@/components/ui',
33
+ importStyle: 'named',
34
+ },
35
+
36
+ components: {
37
+ // =====================================================================
38
+ // DATA DISPLAY (9 types)
39
+ // =====================================================================
40
+
41
+ table: {
42
+ imports: [
43
+ "import { Table, TableHeader, TableBody, TableHead, TableRow, TableCell } from '@/components/ui/table'",
44
+ ],
45
+ render: (ctx: RenderContext) => {
46
+ const { properties, model, name } = ctx;
47
+ const columns = properties.columns || ['id'];
48
+ const modelVar = model?.name?.toLowerCase() || 'item';
49
+ const pluralVar = `${modelVar}s`;
50
+
51
+ return `<Table>
52
+ <TableHeader>
53
+ <TableRow>
54
+ ${columns.map((col: string) => `<TableHead>${col}</TableHead>`).join('\n ')}
55
+ </TableRow>
56
+ </TableHeader>
57
+ <TableBody>
58
+ {${pluralVar}?.map((${modelVar}) => (
59
+ <TableRow key={${modelVar}.id}>
60
+ ${columns.map((col: string) => `<TableCell>{${modelVar}.${col}}</TableCell>`).join('\n ')}
61
+ </TableRow>
62
+ ))}
63
+ </TableBody>
64
+ </Table>`;
65
+ },
66
+ dependencies: [{ name: '@/components/ui/table', version: 'latest' }],
67
+ },
68
+
69
+ list: {
70
+ imports: ["import { ScrollArea } from '@/components/ui/scroll-area'"],
71
+ render: (ctx: RenderContext) => {
72
+ const { properties, children } = ctx;
73
+ const className = properties.dense ? 'space-y-1' : 'space-y-4';
74
+
75
+ return `<ScrollArea className="${className}">
76
+ ${children || '/* List items */'}
77
+ </ScrollArea>`;
78
+ },
79
+ },
80
+
81
+ grid: {
82
+ imports: [],
83
+ render: (ctx: RenderContext) => {
84
+ const { properties, children } = ctx;
85
+ const columns = properties.columns || 3;
86
+ const gap = properties.gap === 'small' ? '2' : properties.gap === 'large' ? '8' : '4';
87
+
88
+ return `<div className="grid grid-cols-${columns} gap-${gap}">
89
+ ${children || '/* Grid items */'}
90
+ </div>`;
91
+ },
92
+ },
93
+
94
+ card: {
95
+ imports: [
96
+ "import { Card, CardHeader, CardTitle, CardDescription, CardContent, CardFooter } from '@/components/ui/card'",
97
+ ],
98
+ render: (ctx: RenderContext) => {
99
+ const { properties, children } = ctx;
100
+ const { title, subtitle, variant } = properties;
101
+
102
+ if (variant === 'metric') {
103
+ return `<Card>
104
+ <CardHeader>
105
+ <CardTitle className="text-sm font-medium">${title || properties.metric || 'Metric'}</CardTitle>
106
+ </CardHeader>
107
+ <CardContent>
108
+ <div className="text-2xl font-bold">{/* Value */}</div>
109
+ ${properties.showTrend ? '<p className="text-xs text-muted-foreground">↑ 12% from last month</p>' : ''}
110
+ </CardContent>
111
+ </Card>`;
112
+ }
113
+
114
+ return `<Card>
115
+ ${title ? `<CardHeader>
116
+ <CardTitle>${title}</CardTitle>
117
+ ${subtitle ? `<CardDescription>${subtitle}</CardDescription>` : ''}
118
+ </CardHeader>` : ''}
119
+ <CardContent>
120
+ ${children || '/* Card content */'}
121
+ </CardContent>
122
+ </Card>`;
123
+ },
124
+ },
125
+
126
+ chart: {
127
+ imports: [
128
+ "import { LineChart, Line, BarChart, Bar, PieChart, Pie, XAxis, YAxis, CartesianGrid, Tooltip, Legend, ResponsiveContainer } from 'recharts'",
129
+ ],
130
+ render: (ctx: RenderContext) => {
131
+ const { properties } = ctx;
132
+ const chartType = properties.chartType || 'line';
133
+
134
+ const chartMap: Record<string, string> = {
135
+ line: '<LineChart data={data}><CartesianGrid strokeDasharray="3 3" /><XAxis dataKey="name" /><YAxis /><Tooltip /><Legend /><Line type="monotone" dataKey="value" stroke="#8884d8" /></LineChart>',
136
+ bar: '<BarChart data={data}><CartesianGrid strokeDasharray="3 3" /><XAxis dataKey="name" /><YAxis /><Tooltip /><Legend /><Bar dataKey="value" fill="#8884d8" /></BarChart>',
137
+ pie: '<PieChart><Pie data={data} dataKey="value" nameKey="name" cx="50%" cy="50%" outerRadius={80} fill="#8884d8" label /></PieChart>',
138
+ trend: '<LineChart data={data}><Line type="monotone" dataKey="value" stroke="#8884d8" strokeWidth={2} dot={false} /></LineChart>',
139
+ };
140
+
141
+ const chart = chartMap[chartType] || chartMap.line;
142
+
143
+ return `<ResponsiveContainer width="100%" height={${properties.height || 300}}>
144
+ ${chart}
145
+ </ResponsiveContainer>`;
146
+ },
147
+ dependencies: [{ name: 'recharts', version: '^2.10.0' }],
148
+ },
149
+
150
+ tree: {
151
+ imports: [],
152
+ render: () => `<div className="tree-view">
153
+ {/* TODO: Implement tree component */}
154
+ </div>`,
155
+ },
156
+
157
+ timeline: {
158
+ imports: [],
159
+ render: (ctx: RenderContext) => {
160
+ const { properties, children } = ctx;
161
+ const orientation = properties.orientation || 'vertical';
162
+
163
+ return `<div className="relative ${orientation === 'horizontal' ? 'flex space-x-8' : 'space-y-8'}">
164
+ ${children || '/* Timeline items */'}
165
+ </div>`;
166
+ },
167
+ },
168
+
169
+ avatar: {
170
+ imports: ["import { Avatar, AvatarImage, AvatarFallback } from '@/components/ui/avatar'"],
171
+ render: (ctx: RenderContext) => {
172
+ const { properties } = ctx;
173
+ const size = properties.size === 'large' ? 'h-16 w-16' : properties.size === 'small' ? 'h-8 w-8' : 'h-12 w-12';
174
+
175
+ return `<Avatar className="${size}">
176
+ <AvatarImage src={${properties.src || 'user.avatar'}} alt="${properties.alt || 'Avatar'}" />
177
+ <AvatarFallback>${properties.initials || 'U'}</AvatarFallback>
178
+ </Avatar>`;
179
+ },
180
+ },
181
+
182
+ image: {
183
+ imports: [],
184
+ render: (ctx: RenderContext) => {
185
+ const { properties } = ctx;
186
+ return `<img
187
+ src={${properties.src || 'imageSrc'}}
188
+ alt="${properties.alt || ''}"
189
+ className="${properties.objectFit === 'cover' ? 'object-cover' : 'object-contain'} ${properties.lazy ? 'loading="lazy"' : ''}"
190
+ />`;
191
+ },
192
+ },
193
+
194
+ // =====================================================================
195
+ // FORMS & INPUTS (11 types)
196
+ // =====================================================================
197
+
198
+ form: {
199
+ imports: ["import { Form } from '@/components/ui/form'"],
200
+ render: (ctx: RenderContext) => {
201
+ const { children } = ctx;
202
+ return `<Form {...form}>
203
+ <form onSubmit={form.handleSubmit(onSubmit)} className="space-y-6">
204
+ ${children || '/* Form fields */'}
205
+ </form>
206
+ </Form>`;
207
+ },
208
+ },
209
+
210
+ input: {
211
+ imports: ["import { Input } from '@/components/ui/input'", "import { Label } from '@/components/ui/label'"],
212
+ render: (ctx: RenderContext) => {
213
+ const { properties } = ctx;
214
+ return `<div className="grid w-full items-center gap-1.5">
215
+ ${properties.label ? `<Label htmlFor="${properties.name || 'input'}">${properties.label}${properties.required ? ' *' : ''}</Label>` : ''}
216
+ <Input
217
+ type="${properties.type || 'text'}"
218
+ id="${properties.name || 'input'}"
219
+ placeholder="${properties.placeholder || ''}"
220
+ ${properties.required ? 'required' : ''}
221
+ ${properties.disabled ? 'disabled' : ''}
222
+ />
223
+ ${properties.helperText ? `<p className="text-sm text-muted-foreground">${properties.helperText}</p>` : ''}
224
+ </div>`;
225
+ },
226
+ },
227
+
228
+ textarea: {
229
+ imports: ["import { Textarea } from '@/components/ui/textarea'", "import { Label } from '@/components/ui/label'"],
230
+ render: (ctx: RenderContext) => {
231
+ const { properties } = ctx;
232
+ return `<div className="grid w-full gap-1.5">
233
+ ${properties.label ? `<Label htmlFor="${properties.name || 'textarea'}">${properties.label}</Label>` : ''}
234
+ <Textarea
235
+ id="${properties.name || 'textarea'}"
236
+ placeholder="${properties.placeholder || ''}"
237
+ rows={${properties.rows || 4}}
238
+ ${properties.required ? 'required' : ''}
239
+ />
240
+ </div>`;
241
+ },
242
+ },
243
+
244
+ select: {
245
+ imports: [
246
+ "import { Select, SelectContent, SelectItem, SelectTrigger, SelectValue } from '@/components/ui/select'",
247
+ "import { Label } from '@/components/ui/label'",
248
+ ],
249
+ render: (ctx: RenderContext) => {
250
+ const { properties } = ctx;
251
+ const options = properties.options || [];
252
+
253
+ return `<div className="grid w-full gap-1.5">
254
+ ${properties.label ? `<Label>${properties.label}${properties.required ? ' *' : ''}</Label>` : ''}
255
+ <Select>
256
+ <SelectTrigger>
257
+ <SelectValue placeholder="${properties.placeholder || 'Select option'}" />
258
+ </SelectTrigger>
259
+ <SelectContent>
260
+ ${options.map((opt: string) => `<SelectItem value="${opt}">${opt}</SelectItem>`).join('\n ')}
261
+ </SelectContent>
262
+ </Select>
263
+ </div>`;
264
+ },
265
+ },
266
+
267
+ checkbox: {
268
+ imports: ["import { Checkbox } from '@/components/ui/checkbox'", "import { Label } from '@/components/ui/label'"],
269
+ render: (ctx: RenderContext) => {
270
+ const { properties } = ctx;
271
+ return `<div className="flex items-center space-x-2">
272
+ <Checkbox id="${properties.name || 'checkbox'}" ${properties.checked ? 'checked' : ''} ${properties.disabled ? 'disabled' : ''} />
273
+ ${properties.label ? `<Label htmlFor="${properties.name || 'checkbox'}">${properties.label}</Label>` : ''}
274
+ </div>`;
275
+ },
276
+ },
277
+
278
+ radio: {
279
+ imports: ["import { RadioGroup, RadioGroupItem } from '@/components/ui/radio-group'", "import { Label } from '@/components/ui/label'"],
280
+ render: (ctx: RenderContext) => {
281
+ const { properties } = ctx;
282
+ const options = properties.options || [];
283
+
284
+ return `<div className="grid gap-2">
285
+ ${properties.label ? `<Label>${properties.label}</Label>` : ''}
286
+ <RadioGroup>
287
+ ${options.map((opt: string) => `<div className="flex items-center space-x-2">
288
+ <RadioGroupItem value="${opt}" id="${opt}" />
289
+ <Label htmlFor="${opt}">${opt}</Label>
290
+ </div>`).join('\n ')}
291
+ </RadioGroup>
292
+ </div>`;
293
+ },
294
+ },
295
+
296
+ slider: {
297
+ imports: ["import { Slider } from '@/components/ui/slider'", "import { Label } from '@/components/ui/label'"],
298
+ render: (ctx: RenderContext) => {
299
+ const { properties } = ctx;
300
+ return `<div className="grid gap-2">
301
+ ${properties.label ? `<Label>${properties.label}</Label>` : ''}
302
+ <Slider
303
+ min={${properties.min || 0}}
304
+ max={${properties.max || 100}}
305
+ step={${properties.step || 1}}
306
+ defaultValue={[${properties.value || 50}]}
307
+ />
308
+ ${properties.showValue ? '<span className="text-sm text-muted-foreground">{value}</span>' : ''}
309
+ </div>`;
310
+ },
311
+ },
312
+
313
+ switch: {
314
+ imports: ["import { Switch } from '@/components/ui/switch'", "import { Label } from '@/components/ui/label'"],
315
+ render: (ctx: RenderContext) => {
316
+ const { properties } = ctx;
317
+ return `<div className="flex items-center space-x-2">
318
+ <Switch id="${properties.name || 'switch'}" ${properties.checked ? 'checked' : ''} ${properties.disabled ? 'disabled' : ''} />
319
+ ${properties.label ? `<Label htmlFor="${properties.name || 'switch'}">${properties.label}</Label>` : ''}
320
+ </div>`;
321
+ },
322
+ },
323
+
324
+ autocomplete: {
325
+ imports: [
326
+ "import { Command, CommandEmpty, CommandGroup, CommandInput, CommandItem } from '@/components/ui/command'",
327
+ "import { Popover, PopoverContent, PopoverTrigger } from '@/components/ui/popover'",
328
+ "import { Button } from '@/components/ui/button'",
329
+ ],
330
+ render: (ctx: RenderContext) => {
331
+ const { properties } = ctx;
332
+ return `<Popover>
333
+ <PopoverTrigger asChild>
334
+ <Button variant="outline" role="combobox">
335
+ {selected || "${properties.placeholder || 'Select...'}"}
336
+ </Button>
337
+ </PopoverTrigger>
338
+ <PopoverContent className="w-[200px] p-0">
339
+ <Command>
340
+ <CommandInput placeholder="${properties.label || 'Search...'}" />
341
+ <CommandEmpty>No results found.</CommandEmpty>
342
+ <CommandGroup>
343
+ {/* Options */}
344
+ </CommandGroup>
345
+ </Command>
346
+ </PopoverContent>
347
+ </Popover>`;
348
+ },
349
+ },
350
+
351
+ datepicker: {
352
+ imports: [
353
+ "import { Calendar } from '@/components/ui/calendar'",
354
+ "import { Popover, PopoverContent, PopoverTrigger } from '@/components/ui/popover'",
355
+ "import { Button } from '@/components/ui/button'",
356
+ "import { format } from 'date-fns'",
357
+ ],
358
+ render: (ctx: RenderContext) => {
359
+ const { properties } = ctx;
360
+ return `<Popover>
361
+ <PopoverTrigger asChild>
362
+ <Button variant="outline">
363
+ {date ? format(date, "${properties.format || 'PPP'}") : <span>Pick a date</span>}
364
+ </Button>
365
+ </PopoverTrigger>
366
+ <PopoverContent className="w-auto p-0">
367
+ <Calendar mode="single" selected={date} onSelect={setDate} initialFocus />
368
+ </PopoverContent>
369
+ </Popover>`;
370
+ },
371
+ dependencies: [{ name: 'date-fns', version: '^3.0.0' }],
372
+ },
373
+
374
+ timepicker: {
375
+ imports: ["import { Input } from '@/components/ui/input'", "import { Label } from '@/components/ui/label'"],
376
+ render: (ctx: RenderContext) => {
377
+ const { properties } = ctx;
378
+ return `<div className="grid w-full gap-1.5">
379
+ ${properties.label ? `<Label>${properties.label}</Label>` : ''}
380
+ <Input type="time" ${properties.required ? 'required' : ''} />
381
+ </div>`;
382
+ },
383
+ },
384
+
385
+ // =====================================================================
386
+ // ACTIONS (5 types)
387
+ // =====================================================================
388
+
389
+ button: {
390
+ imports: ["import { Button } from '@/components/ui/button'"],
391
+ render: (ctx: RenderContext) => {
392
+ const { properties } = ctx;
393
+ const variants: Record<string, string> = {
394
+ primary: 'default',
395
+ secondary: 'secondary',
396
+ danger: 'destructive',
397
+ ghost: 'ghost',
398
+ link: 'link',
399
+ };
400
+ const variant = variants[properties.variant || 'primary'] || 'default';
401
+
402
+ return `<Button
403
+ variant="${variant}"
404
+ size="${properties.size || 'default'}"
405
+ ${properties.disabled ? 'disabled' : ''}
406
+ ${properties.type ? `type="${properties.type}"` : ''}
407
+ >
408
+ ${properties.icon ? `<${properties.icon} className="mr-2 h-4 w-4" />` : ''}
409
+ ${properties.label || 'Button'}
410
+ </Button>`;
411
+ },
412
+ },
413
+
414
+ 'button-group': {
415
+ imports: [],
416
+ render: (ctx: RenderContext) => {
417
+ const { properties, children } = ctx;
418
+ const orientation = properties.orientation || 'horizontal';
419
+ return `<div className="flex ${orientation === 'vertical' ? 'flex-col' : 'flex-row'} gap-2">
420
+ ${children || '/* Buttons */'}
421
+ </div>`;
422
+ },
423
+ },
424
+
425
+ link: {
426
+ imports: ["import Link from 'next/link'"],
427
+ render: (ctx: RenderContext) => {
428
+ const { properties } = ctx;
429
+ return `<Link
430
+ href="${properties.href || '#'}"
431
+ className="${properties.underline === false ? 'no-underline' : 'underline'}"
432
+ ${properties.external ? 'target="_blank" rel="noopener noreferrer"' : ''}
433
+ >
434
+ ${properties.label || 'Link'}
435
+ </Link>`;
436
+ },
437
+ },
438
+
439
+ icon: {
440
+ imports: [],
441
+ render: (ctx: RenderContext) => {
442
+ const { properties } = ctx;
443
+ const sizeMap: Record<string, string> = { small: 'h-4 w-4', medium: 'h-6 w-6', large: 'h-8 w-8' };
444
+ const size = sizeMap[properties.size || 'medium'] || 'h-6 w-6';
445
+
446
+ return `<${properties.name || 'Icon'} className="${size} ${properties.color ? `text-${properties.color}` : ''}" />`;
447
+ },
448
+ },
449
+
450
+ menu: {
451
+ imports: [
452
+ "import { DropdownMenu, DropdownMenuContent, DropdownMenuItem, DropdownMenuTrigger } from '@/components/ui/dropdown-menu'",
453
+ ],
454
+ render: (ctx: RenderContext) => {
455
+ const { children } = ctx;
456
+ return `<DropdownMenu>
457
+ <DropdownMenuTrigger>Menu</DropdownMenuTrigger>
458
+ <DropdownMenuContent>
459
+ ${children || '/* Menu items */'}
460
+ </DropdownMenuContent>
461
+ </DropdownMenu>`;
462
+ },
463
+ },
464
+
465
+ // =====================================================================
466
+ // OVERLAYS & FEEDBACK (9 types)
467
+ // =====================================================================
468
+
469
+ modal: {
470
+ imports: [
471
+ "import { Dialog, DialogContent, DialogDescription, DialogHeader, DialogTitle, DialogFooter } from '@/components/ui/dialog'",
472
+ ],
473
+ render: (ctx: RenderContext) => {
474
+ const { properties, children } = ctx;
475
+ return `<Dialog open={isOpen} onOpenChange={setIsOpen}>
476
+ <DialogContent className="${properties.size === 'small' ? 'sm:max-w-[425px]' : properties.size === 'large' ? 'sm:max-w-[725px]' : 'sm:max-w-[525px]'}">
477
+ ${properties.title ? `<DialogHeader>
478
+ <DialogTitle>${properties.title}</DialogTitle>
479
+ </DialogHeader>` : ''}
480
+ <div className="py-4">
481
+ ${children || '/* Modal content */'}
482
+ </div>
483
+ ${properties.footer ? '<DialogFooter>{/* Footer actions */}</DialogFooter>' : ''}
484
+ </DialogContent>
485
+ </Dialog>`;
486
+ },
487
+ },
488
+
489
+ dialog: {
490
+ imports: ["import { AlertDialog, AlertDialogAction, AlertDialogCancel, AlertDialogContent, AlertDialogDescription, AlertDialogFooter, AlertDialogHeader, AlertDialogTitle } from '@/components/ui/alert-dialog'"],
491
+ render: (ctx: RenderContext) => {
492
+ const { properties } = ctx;
493
+ return `<AlertDialog>
494
+ <AlertDialogContent>
495
+ <AlertDialogHeader>
496
+ <AlertDialogTitle>${properties.title || 'Alert'}</AlertDialogTitle>
497
+ <AlertDialogDescription>${properties.message || ''}</AlertDialogDescription>
498
+ </AlertDialogHeader>
499
+ <AlertDialogFooter>
500
+ <AlertDialogCancel>Cancel</AlertDialogCancel>
501
+ <AlertDialogAction>Continue</AlertDialogAction>
502
+ </AlertDialogFooter>
503
+ </AlertDialogContent>
504
+ </AlertDialog>`;
505
+ },
506
+ },
507
+
508
+ drawer: {
509
+ imports: ["import { Sheet, SheetContent, SheetHeader, SheetTitle } from '@/components/ui/sheet'"],
510
+ render: (ctx: RenderContext) => {
511
+ const { properties, children } = ctx;
512
+ return `<Sheet>
513
+ <SheetContent side="${properties.position || 'right'}">
514
+ <SheetHeader>
515
+ <SheetTitle>${properties.title || ''}</SheetTitle>
516
+ </SheetHeader>
517
+ <div className="py-4">
518
+ ${children || '/* Drawer content */'}
519
+ </div>
520
+ </SheetContent>
521
+ </Sheet>`;
522
+ },
523
+ },
524
+
525
+ popover: {
526
+ imports: ["import { Popover, PopoverContent, PopoverTrigger } from '@/components/ui/popover'"],
527
+ render: (ctx: RenderContext) => {
528
+ const { children } = ctx;
529
+ return `<Popover>
530
+ <PopoverTrigger>Trigger</PopoverTrigger>
531
+ <PopoverContent>
532
+ ${children || 'Popover content'}
533
+ </PopoverContent>
534
+ </Popover>`;
535
+ },
536
+ },
537
+
538
+ tooltip: {
539
+ imports: ["import { Tooltip, TooltipContent, TooltipProvider, TooltipTrigger } from '@/components/ui/tooltip'"],
540
+ render: (ctx: RenderContext) => {
541
+ const { properties } = ctx;
542
+ return `<TooltipProvider>
543
+ <Tooltip>
544
+ <TooltipTrigger>Hover</TooltipTrigger>
545
+ <TooltipContent>
546
+ <p>${properties.content || 'Tooltip content'}</p>
547
+ </TooltipContent>
548
+ </Tooltip>
549
+ </TooltipProvider>`;
550
+ },
551
+ },
552
+
553
+ alert: {
554
+ imports: ["import { Alert, AlertDescription, AlertTitle } from '@/components/ui/alert'"],
555
+ render: (ctx: RenderContext) => {
556
+ const { properties } = ctx;
557
+ return `<Alert variant="${properties.variant || 'default'}">
558
+ ${properties.title ? `<AlertTitle>${properties.title}</AlertTitle>` : ''}
559
+ <AlertDescription>${properties.message || ''}</AlertDescription>
560
+ </Alert>`;
561
+ },
562
+ },
563
+
564
+ snackbar: {
565
+ imports: ["import { useToast } from '@/components/ui/use-toast'"],
566
+ render: (ctx: RenderContext) => {
567
+ const { properties } = ctx;
568
+ return `toast({
569
+ title: "${properties.message || 'Notification'}",
570
+ duration: ${properties.duration || 3000},
571
+ })`;
572
+ },
573
+ },
574
+
575
+ badge: {
576
+ imports: ["import { Badge } from '@/components/ui/badge'"],
577
+ render: (ctx: RenderContext) => {
578
+ const { properties } = ctx;
579
+ return `<Badge variant="${properties.variant || 'default'}">${properties.content || ''}</Badge>`;
580
+ },
581
+ },
582
+
583
+ spinner: {
584
+ imports: [],
585
+ render: (ctx: RenderContext) => {
586
+ const { properties } = ctx;
587
+ const sizeMap: Record<string, string> = { small: 'h-4 w-4', medium: 'h-8 w-8', large: 'h-12 w-12' };
588
+ const size = sizeMap[properties.size || 'medium'] || 'h-8 w-8';
589
+ return `<div className="flex items-center justify-center">
590
+ <div className="${size} animate-spin rounded-full border-b-2 border-gray-900"></div>
591
+ </div>`;
592
+ },
593
+ },
594
+
595
+ // =====================================================================
596
+ // NAVIGATION (5 types)
597
+ // =====================================================================
598
+
599
+ tabs: {
600
+ imports: ["import { Tabs, TabsContent, TabsList, TabsTrigger } from '@/components/ui/tabs'"],
601
+ render: (ctx: RenderContext) => {
602
+ const { properties, children } = ctx;
603
+ const sections = properties.sections || ['tab1', 'tab2'];
604
+
605
+ return `<Tabs defaultValue="${sections[0]}">
606
+ <TabsList>
607
+ ${sections.map((section: string) => `<TabsTrigger value="${section}">${section}</TabsTrigger>`).join('\n ')}
608
+ </TabsList>
609
+ ${sections.map((section: string) => `<TabsContent value="${section}">
610
+ {/* ${section} content */}
611
+ </TabsContent>`).join('\n ')}
612
+ </Tabs>`;
613
+ },
614
+ },
615
+
616
+ breadcrumb: {
617
+ imports: [],
618
+ render: (ctx: RenderContext) => {
619
+ return `<nav className="flex" aria-label="Breadcrumb">
620
+ <ol className="inline-flex items-center space-x-1">
621
+ {/* Breadcrumb items */}
622
+ </ol>
623
+ </nav>`;
624
+ },
625
+ },
626
+
627
+ navbar: {
628
+ imports: [],
629
+ render: (ctx: RenderContext) => {
630
+ const { properties, children } = ctx;
631
+ return `<nav className="${properties.sticky ? 'sticky top-0' : ''} bg-background border-b">
632
+ <div className="container flex h-16 items-center justify-between">
633
+ ${children || '/* Navigation items */'}
634
+ </div>
635
+ </nav>`;
636
+ },
637
+ },
638
+
639
+ sidebar: {
640
+ imports: [],
641
+ render: (ctx: RenderContext) => {
642
+ const { properties, children } = ctx;
643
+ return `<aside className="w-${properties.width || 64} border-r ${properties.position === 'right' ? 'order-last' : ''}">
644
+ <div className="h-full px-3 py-4">
645
+ ${children || '/* Sidebar items */'}
646
+ </div>
647
+ </aside>`;
648
+ },
649
+ },
650
+
651
+ pagination: {
652
+ imports: [
653
+ "import { Pagination, PaginationContent, PaginationItem, PaginationLink, PaginationNext, PaginationPrevious } from '@/components/ui/pagination'",
654
+ ],
655
+ render: (ctx: RenderContext) => {
656
+ return `<Pagination>
657
+ <PaginationContent>
658
+ <PaginationItem>
659
+ <PaginationPrevious href="#" />
660
+ </PaginationItem>
661
+ {/* Page numbers */}
662
+ <PaginationItem>
663
+ <PaginationNext href="#" />
664
+ </PaginationItem>
665
+ </PaginationContent>
666
+ </Pagination>`;
667
+ },
668
+ },
669
+
670
+ // =====================================================================
671
+ // LAYOUT (6 types)
672
+ // =====================================================================
673
+
674
+ accordion: {
675
+ imports: ["import { Accordion, AccordionContent, AccordionItem, AccordionTrigger } from '@/components/ui/accordion'"],
676
+ render: (ctx: RenderContext) => {
677
+ const { children } = ctx;
678
+ return `<Accordion type="single" collapsible>
679
+ ${children || '/* Accordion items */'}
680
+ </Accordion>`;
681
+ },
682
+ },
683
+
684
+ carousel: {
685
+ imports: [],
686
+ render: (ctx: RenderContext) => {
687
+ const { children } = ctx;
688
+ return `<div className="relative">
689
+ {/* Carousel implementation */}
690
+ ${children || ''}
691
+ </div>`;
692
+ },
693
+ },
694
+
695
+ container: {
696
+ imports: [],
697
+ render: (ctx: RenderContext) => {
698
+ const { properties, children } = ctx;
699
+ const layout = properties.layout || 'vertical';
700
+ const className = layout === 'horizontal' ? 'flex flex-row' : layout === 'grid' ? 'grid' : 'flex flex-col';
701
+
702
+ return `<div className="${className} ${properties.gap ? `gap-${properties.gap}` : ''} ${properties.scrollable ? 'overflow-auto' : ''}">
703
+ ${children || '/* Container content */'}
704
+ </div>`;
705
+ },
706
+ },
707
+
708
+ divider: {
709
+ imports: ["import { Separator } from '@/components/ui/separator'"],
710
+ render: (ctx: RenderContext) => {
711
+ const { properties } = ctx;
712
+ return `<Separator orientation="${properties.orientation || 'horizontal'}" />`;
713
+ },
714
+ },
715
+
716
+ header: {
717
+ imports: [],
718
+ render: (ctx: RenderContext) => {
719
+ const { properties, children } = ctx;
720
+ return `<header>
721
+ ${properties.title ? `<h1 className="text-3xl font-bold">${properties.title}</h1>` : ''}
722
+ ${properties.subtitle ? `<p className="text-muted-foreground">${properties.subtitle}</p>` : ''}
723
+ ${children || ''}
724
+ </header>`;
725
+ },
726
+ },
727
+
728
+ footer: {
729
+ imports: [],
730
+ render: (ctx: RenderContext) => {
731
+ const { properties, children } = ctx;
732
+ return `<footer className="${properties.sticky ? 'sticky bottom-0' : ''} border-t bg-background">
733
+ <div className="container py-6">
734
+ ${children || '/* Footer content */'}
735
+ ${properties.copyright ? `<p className="text-sm text-muted-foreground">${properties.copyright}</p>` : ''}
736
+ </div>
737
+ </footer>`;
738
+ },
739
+ },
740
+
741
+ // =====================================================================
742
+ // PROGRESS (2 types)
743
+ // =====================================================================
744
+
745
+ 'progress-bar': {
746
+ imports: ["import { Progress } from '@/components/ui/progress'"],
747
+ render: (ctx: RenderContext) => {
748
+ const { properties } = ctx;
749
+ return `<div className="space-y-2">
750
+ ${properties.label ? `<div className="flex justify-between text-sm"><span>Progress</span><span>{${properties.value || 0}}%</span></div>` : ''}
751
+ <Progress value={${properties.value || 0}} max={${properties.max || 100}} />
752
+ </div>`;
753
+ },
754
+ },
755
+
756
+ 'progress-circle': {
757
+ imports: [],
758
+ render: (ctx: RenderContext) => {
759
+ const { properties } = ctx;
760
+ const size = properties.size === 'large' ? 'h-32 w-32' : properties.size === 'small' ? 'h-16 w-16' : 'h-24 w-24';
761
+ return `<div className="${size} relative">
762
+ <svg className="rotate-[-90deg]" viewBox="0 0 100 100">
763
+ <circle cx="50" cy="50" r="40" stroke="currentColor" strokeWidth="${properties.thickness || 4}" fill="none" className="text-muted" />
764
+ <circle cx="50" cy="50" r="40" stroke="currentColor" strokeWidth="${properties.thickness || 4}" fill="none" strokeDasharray="251.2" strokeDashoffset={251.2 - (251.2 * ${properties.value || 0}) / 100} className="text-primary transition-all" />
765
+ </svg>
766
+ ${properties.label ? '<div className="absolute inset-0 flex items-center justify-center text-lg font-bold">{value}%</div>' : ''}
767
+ </div>`;
768
+ },
769
+ },
770
+
771
+ // =====================================================================
772
+ // SPECIALIZED (2 types)
773
+ // =====================================================================
774
+
775
+ searchBar: {
776
+ imports: ["import { Input } from '@/components/ui/input'", "import { Search } from 'lucide-react'"],
777
+ render: (ctx: RenderContext) => {
778
+ const { properties } = ctx;
779
+ return `<div className="relative">
780
+ <Search className="absolute left-2 top-2.5 h-4 w-4 text-muted-foreground" />
781
+ <Input
782
+ type="search"
783
+ placeholder="${properties.placeholder || 'Search...'}"
784
+ className="pl-8"
785
+ ${properties.autofocus ? 'autoFocus' : ''}
786
+ />
787
+ </div>`;
788
+ },
789
+ },
790
+
791
+ filterPanel: {
792
+ imports: ["import { Card } from '@/components/ui/card'"],
793
+ render: (ctx: RenderContext) => {
794
+ const { properties, children } = ctx;
795
+ return `<Card className="${properties.position === 'sidebar' ? 'w-64' : 'w-full'} ${properties.collapsible ? 'collapsible' : ''}">
796
+ <div className="p-4 space-y-4">
797
+ <h3 className="font-semibold">Filters</h3>
798
+ ${children || '/* Filter controls */'}
799
+ </div>
800
+ </Card>`;
801
+ },
802
+ },
803
+ },
804
+ };
805
+
806
+ export default shadcnAdapter;