@specverse/engines 4.1.30 → 4.2.1

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 (285) hide show
  1. package/assets/examples/manifests/frontend-only.yaml +3 -6
  2. package/assets/examples/manifests/fullstack-app.yaml +5 -7
  3. package/assets/examples/manifests/fullstack-monorepo.yaml +3 -6
  4. package/assets/templates/default/specs/main.specly +65 -0
  5. package/dist/inference/comprehensive-engine.d.ts.map +1 -1
  6. package/dist/inference/comprehensive-engine.js +3 -19
  7. package/dist/inference/comprehensive-engine.js.map +1 -1
  8. package/dist/inference/core/rule-engine.d.ts +31 -0
  9. package/dist/inference/core/rule-engine.d.ts.map +1 -1
  10. package/dist/inference/core/rule-engine.js +117 -33
  11. package/dist/inference/core/rule-engine.js.map +1 -1
  12. package/dist/inference/core/rule-file-types.d.ts +0 -2
  13. package/dist/inference/core/rule-file-types.d.ts.map +1 -1
  14. package/dist/inference/core/rule-file-types.js +3 -6
  15. package/dist/inference/core/rule-file-types.js.map +1 -1
  16. package/dist/inference/core/rule-loader.d.ts +5 -15
  17. package/dist/inference/core/rule-loader.d.ts.map +1 -1
  18. package/dist/inference/core/rule-loader.js +43 -132
  19. package/dist/inference/core/rule-loader.js.map +1 -1
  20. package/dist/inference/core/types.d.ts +0 -6
  21. package/dist/inference/core/types.d.ts.map +1 -1
  22. package/dist/inference/core/types.js +0 -4
  23. package/dist/inference/core/types.js.map +1 -1
  24. package/dist/inference/logical/generators/component-type-resolver.d.ts +0 -26
  25. package/dist/inference/logical/generators/component-type-resolver.d.ts.map +1 -1
  26. package/dist/inference/logical/generators/component-type-resolver.js +0 -19
  27. package/dist/inference/logical/generators/component-type-resolver.js.map +1 -1
  28. package/dist/inference/logical/generators/specialist-view-expander.d.ts +1 -17
  29. package/dist/inference/logical/generators/specialist-view-expander.d.ts.map +1 -1
  30. package/dist/inference/logical/generators/specialist-view-expander.js +0 -15
  31. package/dist/inference/logical/generators/specialist-view-expander.js.map +1 -1
  32. package/dist/inference/logical/generators/view-generator.d.ts +4 -14
  33. package/dist/inference/logical/generators/view-generator.d.ts.map +1 -1
  34. package/dist/inference/logical/generators/view-generator.js +6 -26
  35. package/dist/inference/logical/generators/view-generator.js.map +1 -1
  36. package/dist/inference/logical/index.d.ts +2 -2
  37. package/dist/inference/logical/index.d.ts.map +1 -1
  38. package/dist/inference/logical/logical-engine.d.ts.map +1 -1
  39. package/dist/inference/logical/logical-engine.js +17 -80
  40. package/dist/inference/logical/logical-engine.js.map +1 -1
  41. package/dist/inference/quint-transpiler.d.ts +5 -3
  42. package/dist/inference/quint-transpiler.d.ts.map +1 -1
  43. package/dist/inference/quint-transpiler.js +11 -6
  44. package/dist/inference/quint-transpiler.js.map +1 -1
  45. package/dist/libs/instance-factories/CURVED-INTERFACE.md +278 -0
  46. package/dist/libs/instance-factories/README.md +73 -0
  47. package/dist/libs/instance-factories/applications/README.md +51 -0
  48. package/dist/libs/instance-factories/applications/generic-app.yaml +52 -0
  49. package/{libs/instance-factories/applications/react-app.yaml → dist/libs/instance-factories/applications/react-app-runtime.yaml} +30 -77
  50. package/dist/libs/instance-factories/applications/react-app-starter.yaml +143 -0
  51. package/dist/libs/instance-factories/applications/templates/react/env-example-generator.js +24 -2
  52. package/dist/libs/instance-factories/applications/templates/react/vite-config-generator.js +54 -33
  53. package/dist/libs/instance-factories/applications/templates/react-starter/README.md +211 -0
  54. package/dist/libs/instance-factories/applications/templates/react-starter/api-types-starter-generator.js +69 -0
  55. package/dist/libs/instance-factories/applications/templates/react-starter/app-tsx-generator.js +110 -0
  56. package/dist/libs/instance-factories/applications/templates/react-starter/belongs-to.js +40 -0
  57. package/dist/libs/instance-factories/applications/templates/react-starter/dashboard-body-composer.js +129 -0
  58. package/dist/libs/instance-factories/applications/templates/react-starter/detail-body-composer.js +80 -0
  59. package/dist/libs/instance-factories/applications/templates/react-starter/form-body-composer.js +217 -0
  60. package/dist/libs/instance-factories/applications/templates/react-starter/helpers-emitter.js +51 -0
  61. package/dist/libs/instance-factories/applications/templates/react-starter/html-to-jsx.js +192 -0
  62. package/dist/libs/instance-factories/applications/templates/react-starter/list-body-composer.js +56 -0
  63. package/dist/libs/instance-factories/applications/templates/react-starter/orchestrator.js +41 -0
  64. package/dist/libs/instance-factories/applications/templates/react-starter/package-json-generator.js +38 -0
  65. package/dist/libs/instance-factories/applications/templates/react-starter/regen-safety.js +89 -0
  66. package/dist/libs/instance-factories/applications/templates/react-starter/skeletons/dashboard.tsx.template +49 -0
  67. package/dist/libs/instance-factories/applications/templates/react-starter/skeletons/detail.tsx.template +96 -0
  68. package/dist/libs/instance-factories/applications/templates/react-starter/skeletons/form.tsx.template +116 -0
  69. package/dist/libs/instance-factories/applications/templates/react-starter/skeletons/list.tsx.template +74 -0
  70. package/dist/libs/instance-factories/applications/templates/react-starter/use-api-hooks-starter-generator.js +95 -0
  71. package/dist/libs/instance-factories/applications/templates/react-starter/view-emitter.js +81 -0
  72. package/dist/libs/instance-factories/applications/templates/react-starter/views-generator.js +66 -0
  73. package/dist/libs/instance-factories/archived/fastify-prisma.yaml +104 -0
  74. package/dist/libs/instance-factories/cli/README.md +43 -0
  75. package/dist/libs/instance-factories/cli/commander-js.yaml +55 -0
  76. package/dist/libs/instance-factories/cli/templates/commander/command-generator.js +63 -12
  77. package/dist/libs/instance-factories/communication/README.md +47 -0
  78. package/dist/libs/instance-factories/communication/event-emitter.yaml +60 -0
  79. package/dist/libs/instance-factories/communication/rabbitmq-events.yaml +87 -0
  80. package/dist/libs/instance-factories/controllers/README.md +42 -0
  81. package/dist/libs/instance-factories/controllers/fastify.yaml +139 -0
  82. package/dist/libs/instance-factories/controllers/templates/fastify/server-generator.js +29 -2
  83. package/dist/libs/instance-factories/infrastructure/README.md +29 -0
  84. package/dist/libs/instance-factories/infrastructure/docker-k8s.yaml +61 -0
  85. package/dist/libs/instance-factories/orms/README.md +54 -0
  86. package/dist/libs/instance-factories/orms/prisma.yaml +89 -0
  87. package/dist/libs/instance-factories/orms/templates/prisma/schema-generator.js +2 -2
  88. package/dist/libs/instance-factories/scaffolding/README.md +49 -0
  89. package/dist/libs/instance-factories/scaffolding/generic-scaffold.yaml +65 -0
  90. package/dist/libs/instance-factories/sdks/README.md +28 -0
  91. package/dist/libs/instance-factories/sdks/python-sdk.yaml +66 -0
  92. package/dist/libs/instance-factories/sdks/typescript-sdk.yaml +59 -0
  93. package/dist/libs/instance-factories/services/README.md +55 -0
  94. package/dist/libs/instance-factories/services/prisma-services.yaml +71 -0
  95. package/dist/libs/instance-factories/storage/README.md +34 -0
  96. package/dist/libs/instance-factories/storage/mongodb.yaml +79 -0
  97. package/dist/libs/instance-factories/storage/postgresql.yaml +75 -0
  98. package/dist/libs/instance-factories/storage/redis.yaml +79 -0
  99. package/dist/libs/instance-factories/testing/README.md +40 -0
  100. package/dist/libs/instance-factories/testing/vitest-tests.yaml +63 -0
  101. package/dist/libs/instance-factories/tools/README.md +70 -0
  102. package/dist/libs/instance-factories/tools/mcp.yaml +36 -0
  103. package/dist/libs/instance-factories/tools/vscode.yaml +35 -0
  104. package/dist/libs/instance-factories/validation/README.md +38 -0
  105. package/dist/libs/instance-factories/validation/zod.yaml +56 -0
  106. package/dist/realize/engines/code-generator.d.ts.map +1 -1
  107. package/dist/realize/engines/code-generator.js +3 -0
  108. package/dist/realize/engines/code-generator.js.map +1 -1
  109. package/dist/realize/index.d.ts.map +1 -1
  110. package/dist/realize/index.js +15 -22
  111. package/dist/realize/index.js.map +1 -1
  112. package/dist/registry/utils/manifest-adapter.d.ts +8 -1
  113. package/dist/registry/utils/manifest-adapter.d.ts.map +1 -1
  114. package/dist/registry/utils/manifest-adapter.js +8 -1
  115. package/dist/registry/utils/manifest-adapter.js.map +1 -1
  116. package/libs/instance-factories/applications/react-app-starter.yaml +143 -0
  117. package/libs/instance-factories/applications/templates/react/env-example-generator.ts +24 -2
  118. package/libs/instance-factories/applications/templates/react/vite-config-generator.ts +54 -33
  119. package/libs/instance-factories/applications/templates/react-starter/README.md +211 -0
  120. package/libs/instance-factories/applications/templates/react-starter/__tests__/dashboard-body-composer.test.ts +153 -0
  121. package/libs/instance-factories/applications/templates/react-starter/__tests__/detail-body-composer.test.ts +146 -0
  122. package/libs/instance-factories/applications/templates/react-starter/__tests__/form-body-composer.test.ts +188 -0
  123. package/libs/instance-factories/applications/templates/react-starter/__tests__/helpers-emitter.test.ts +55 -0
  124. package/libs/instance-factories/applications/templates/react-starter/__tests__/html-to-jsx.test.ts +140 -0
  125. package/libs/instance-factories/applications/templates/react-starter/__tests__/list-body-composer.test.ts +146 -0
  126. package/libs/instance-factories/applications/templates/react-starter/__tests__/orchestrator.test.ts +184 -0
  127. package/libs/instance-factories/applications/templates/react-starter/__tests__/parity-p2-factory-imports.test.ts +116 -0
  128. package/libs/instance-factories/applications/templates/react-starter/__tests__/parity-p3-rendered-output.test.ts +183 -0
  129. package/libs/instance-factories/applications/templates/react-starter/__tests__/regen-safety.test.ts +144 -0
  130. package/libs/instance-factories/applications/templates/react-starter/__tests__/starter-generators.test.ts +114 -0
  131. package/libs/instance-factories/applications/templates/react-starter/__tests__/view-emitter.test.ts +107 -0
  132. package/libs/instance-factories/applications/templates/react-starter/__tests__/views-generator.test.ts +139 -0
  133. package/libs/instance-factories/applications/templates/react-starter/api-types-starter-generator.ts +98 -0
  134. package/libs/instance-factories/applications/templates/react-starter/app-tsx-generator.ts +141 -0
  135. package/libs/instance-factories/applications/templates/react-starter/belongs-to.ts +82 -0
  136. package/libs/instance-factories/applications/templates/react-starter/dashboard-body-composer.ts +189 -0
  137. package/libs/instance-factories/applications/templates/react-starter/detail-body-composer.ts +135 -0
  138. package/libs/instance-factories/applications/templates/react-starter/form-body-composer.ts +383 -0
  139. package/libs/instance-factories/applications/templates/react-starter/helpers-emitter.ts +66 -0
  140. package/libs/instance-factories/applications/templates/react-starter/html-to-jsx.ts +334 -0
  141. package/libs/instance-factories/applications/templates/react-starter/list-body-composer.ts +146 -0
  142. package/libs/instance-factories/applications/templates/react-starter/orchestrator.ts +95 -0
  143. package/libs/instance-factories/applications/templates/react-starter/package-json-generator.ts +57 -0
  144. package/libs/instance-factories/applications/templates/react-starter/regen-safety.ts +157 -0
  145. package/libs/instance-factories/applications/templates/react-starter/skeletons/dashboard.tsx.template +49 -0
  146. package/libs/instance-factories/applications/templates/react-starter/skeletons/detail.tsx.template +96 -0
  147. package/libs/instance-factories/applications/templates/react-starter/skeletons/form.tsx.template +116 -0
  148. package/libs/instance-factories/applications/templates/react-starter/skeletons/list.tsx.template +74 -0
  149. package/libs/instance-factories/applications/templates/react-starter/use-api-hooks-starter-generator.ts +124 -0
  150. package/libs/instance-factories/applications/templates/react-starter/view-emitter.ts +209 -0
  151. package/libs/instance-factories/applications/templates/react-starter/views-generator.ts +137 -0
  152. package/libs/instance-factories/cli/templates/commander/command-generator.ts +63 -12
  153. package/libs/instance-factories/controllers/fastify.yaml +7 -0
  154. package/libs/instance-factories/controllers/templates/fastify/server-generator.ts +36 -2
  155. package/libs/instance-factories/orms/templates/prisma/schema-generator.ts +11 -4
  156. package/package.json +3 -3
  157. package/dist/libs/instance-factories/applications/templates/react/_view-components-source.js +0 -530
  158. package/dist/libs/instance-factories/applications/templates/react/app-tsx-generator.js +0 -73
  159. package/dist/libs/instance-factories/applications/templates/react/field-helpers-generator.js +0 -99
  160. package/dist/libs/instance-factories/applications/templates/react/package-json-generator.js +0 -49
  161. package/dist/libs/instance-factories/applications/templates/react/pattern-adapter-generator.js +0 -156
  162. package/dist/libs/instance-factories/applications/templates/react/react-pattern-adapter.js +0 -935
  163. package/dist/libs/instance-factories/applications/templates/react/relationship-field-generator.js +0 -143
  164. package/dist/libs/instance-factories/applications/templates/react/tailwind-adapter-generator.js +0 -646
  165. package/dist/libs/instance-factories/applications/templates/react/tailwind-adapter-wrapper-generator.js +0 -65
  166. package/dist/libs/instance-factories/applications/templates/react/view-dashboard-generator.js +0 -143
  167. package/dist/libs/instance-factories/applications/templates/react/view-detail-generator.js +0 -143
  168. package/dist/libs/instance-factories/applications/templates/react/view-form-generator.js +0 -355
  169. package/dist/libs/instance-factories/applications/templates/react/view-list-generator.js +0 -91
  170. package/dist/libs/instance-factories/applications/templates/react/view-router-generator.js +0 -79
  171. package/dist/libs/instance-factories/views/index.js +0 -48
  172. package/dist/libs/instance-factories/views/templates/react/adapters/antd-adapter.js +0 -742
  173. package/dist/libs/instance-factories/views/templates/react/adapters/mui-adapter.js +0 -824
  174. package/dist/libs/instance-factories/views/templates/react/adapters/shadcn-adapter.js +0 -719
  175. package/dist/libs/instance-factories/views/templates/react/app-generator.js +0 -45
  176. package/dist/libs/instance-factories/views/templates/react/components-generator.js +0 -820
  177. package/dist/libs/instance-factories/views/templates/react/forms-generator.js +0 -275
  178. package/dist/libs/instance-factories/views/templates/react/frontend-package-json-generator.js +0 -46
  179. package/dist/libs/instance-factories/views/templates/react/hooks-generator.js +0 -81
  180. package/dist/libs/instance-factories/views/templates/react/index-css-generator.js +0 -9
  181. package/dist/libs/instance-factories/views/templates/react/index-html-generator.js +0 -23
  182. package/dist/libs/instance-factories/views/templates/react/main-tsx-generator.js +0 -21
  183. package/dist/libs/instance-factories/views/templates/react/react-component-generator.js +0 -299
  184. package/dist/libs/instance-factories/views/templates/react/router-generator.js +0 -136
  185. package/dist/libs/instance-factories/views/templates/react/router-generic-generator.js +0 -107
  186. package/dist/libs/instance-factories/views/templates/react/shared-utils-generator.js +0 -187
  187. package/dist/libs/instance-factories/views/templates/react/spec-json-generator.js +0 -7
  188. package/dist/libs/instance-factories/views/templates/react/types-generator.js +0 -56
  189. package/dist/libs/instance-factories/views/templates/react/views-metadata-generator.js +0 -27
  190. package/dist/libs/instance-factories/views/templates/react/vite-config-generator.js +0 -29
  191. package/dist/libs/instance-factories/views/templates/runtime/runtime-view-renderer.js +0 -261
  192. package/dist/libs/instance-factories/views/templates/shared/adapter-types.js +0 -34
  193. package/dist/libs/instance-factories/views/templates/shared/atomic-components-registry.js +0 -800
  194. package/dist/libs/instance-factories/views/templates/shared/base-generator.js +0 -305
  195. package/dist/libs/instance-factories/views/templates/shared/component-metadata.js +0 -517
  196. package/dist/libs/instance-factories/views/templates/shared/composite-pattern-types.js +0 -0
  197. package/dist/libs/instance-factories/views/templates/shared/composite-patterns.js +0 -445
  198. package/dist/libs/instance-factories/views/templates/shared/index.js +0 -80
  199. package/dist/libs/instance-factories/views/templates/shared/pattern-validator.js +0 -210
  200. package/dist/libs/instance-factories/views/templates/shared/property-mapper.js +0 -492
  201. package/dist/libs/instance-factories/views/templates/shared/syntax-mapper.js +0 -321
  202. package/dist/realize/index.js.bak +0 -758
  203. package/libs/instance-factories/applications/templates/react/_view-components-source.ts +0 -555
  204. package/libs/instance-factories/applications/templates/react/app-tsx-generator.ts +0 -94
  205. package/libs/instance-factories/applications/templates/react/field-helpers-generator.ts +0 -106
  206. package/libs/instance-factories/applications/templates/react/package-json-generator.ts +0 -57
  207. package/libs/instance-factories/applications/templates/react/pattern-adapter-generator.ts +0 -179
  208. package/libs/instance-factories/applications/templates/react/react-pattern-adapter.tsx +0 -1347
  209. package/libs/instance-factories/applications/templates/react/relationship-field-generator.ts +0 -150
  210. package/libs/instance-factories/applications/templates/react/tailwind-adapter-generator.ts +0 -704
  211. package/libs/instance-factories/applications/templates/react/tailwind-adapter-wrapper-generator.ts +0 -84
  212. package/libs/instance-factories/applications/templates/react/view-dashboard-generator.ts +0 -150
  213. package/libs/instance-factories/applications/templates/react/view-detail-generator.ts +0 -150
  214. package/libs/instance-factories/applications/templates/react/view-form-generator.ts +0 -362
  215. package/libs/instance-factories/applications/templates/react/view-list-generator.ts +0 -98
  216. package/libs/instance-factories/applications/templates/react/view-router-generator.ts +0 -89
  217. package/libs/instance-factories/views/README.md +0 -62
  218. package/libs/instance-factories/views/index.d.ts +0 -13
  219. package/libs/instance-factories/views/index.d.ts.map +0 -1
  220. package/libs/instance-factories/views/index.js +0 -18
  221. package/libs/instance-factories/views/index.js.map +0 -1
  222. package/libs/instance-factories/views/index.ts +0 -45
  223. package/libs/instance-factories/views/react-components.yaml +0 -129
  224. package/libs/instance-factories/views/templates/ARCHITECTURE.md +0 -198
  225. package/libs/instance-factories/views/templates/react/adapters/antd-adapter.ts +0 -869
  226. package/libs/instance-factories/views/templates/react/adapters/mui-adapter.ts +0 -953
  227. package/libs/instance-factories/views/templates/react/adapters/shadcn-adapter.ts +0 -806
  228. package/libs/instance-factories/views/templates/react/app-generator.ts +0 -55
  229. package/libs/instance-factories/views/templates/react/components-generator.ts +0 -938
  230. package/libs/instance-factories/views/templates/react/forms-generator.ts +0 -325
  231. package/libs/instance-factories/views/templates/react/frontend-package-json-generator.ts +0 -57
  232. package/libs/instance-factories/views/templates/react/hooks-generator.ts +0 -106
  233. package/libs/instance-factories/views/templates/react/index-css-generator.ts +0 -14
  234. package/libs/instance-factories/views/templates/react/index-html-generator.ts +0 -34
  235. package/libs/instance-factories/views/templates/react/main-tsx-generator.ts +0 -29
  236. package/libs/instance-factories/views/templates/react/react-component-generator.d.ts +0 -152
  237. package/libs/instance-factories/views/templates/react/react-component-generator.d.ts.map +0 -1
  238. package/libs/instance-factories/views/templates/react/react-component-generator.js +0 -398
  239. package/libs/instance-factories/views/templates/react/react-component-generator.js.map +0 -1
  240. package/libs/instance-factories/views/templates/react/react-component-generator.ts +0 -533
  241. package/libs/instance-factories/views/templates/react/router-generator.ts +0 -197
  242. package/libs/instance-factories/views/templates/react/router-generic-generator.ts +0 -132
  243. package/libs/instance-factories/views/templates/react/shared-utils-generator.ts +0 -196
  244. package/libs/instance-factories/views/templates/react/spec-json-generator.ts +0 -17
  245. package/libs/instance-factories/views/templates/react/types-generator.ts +0 -76
  246. package/libs/instance-factories/views/templates/react/views-metadata-generator.ts +0 -42
  247. package/libs/instance-factories/views/templates/react/vite-config-generator.ts +0 -38
  248. package/libs/instance-factories/views/templates/runtime/runtime-view-renderer.d.ts.map +0 -1
  249. package/libs/instance-factories/views/templates/runtime/runtime-view-renderer.js.map +0 -1
  250. package/libs/instance-factories/views/templates/runtime/runtime-view-renderer.ts +0 -474
  251. package/libs/instance-factories/views/templates/shared/__tests__/composite-patterns.test.ts +0 -242
  252. package/libs/instance-factories/views/templates/shared/adapter-types.d.ts +0 -77
  253. package/libs/instance-factories/views/templates/shared/adapter-types.d.ts.map +0 -1
  254. package/libs/instance-factories/views/templates/shared/adapter-types.js +0 -47
  255. package/libs/instance-factories/views/templates/shared/adapter-types.js.map +0 -1
  256. package/libs/instance-factories/views/templates/shared/adapter-types.ts +0 -142
  257. package/libs/instance-factories/views/templates/shared/atomic-components-registry.d.ts +0 -63
  258. package/libs/instance-factories/views/templates/shared/atomic-components-registry.d.ts.map +0 -1
  259. package/libs/instance-factories/views/templates/shared/atomic-components-registry.js +0 -822
  260. package/libs/instance-factories/views/templates/shared/atomic-components-registry.js.map +0 -1
  261. package/libs/instance-factories/views/templates/shared/atomic-components-registry.ts +0 -908
  262. package/libs/instance-factories/views/templates/shared/base-generator.d.ts +0 -247
  263. package/libs/instance-factories/views/templates/shared/base-generator.d.ts.map +0 -1
  264. package/libs/instance-factories/views/templates/shared/base-generator.js +0 -363
  265. package/libs/instance-factories/views/templates/shared/base-generator.js.map +0 -1
  266. package/libs/instance-factories/views/templates/shared/base-generator.ts +0 -608
  267. package/libs/instance-factories/views/templates/shared/component-metadata.d.ts +0 -254
  268. package/libs/instance-factories/views/templates/shared/component-metadata.d.ts.map +0 -1
  269. package/libs/instance-factories/views/templates/shared/component-metadata.js +0 -602
  270. package/libs/instance-factories/views/templates/shared/component-metadata.js.map +0 -1
  271. package/libs/instance-factories/views/templates/shared/component-metadata.ts +0 -803
  272. package/libs/instance-factories/views/templates/shared/composite-pattern-types.ts +0 -250
  273. package/libs/instance-factories/views/templates/shared/composite-patterns.ts +0 -535
  274. package/libs/instance-factories/views/templates/shared/index.ts +0 -68
  275. package/libs/instance-factories/views/templates/shared/pattern-validator.ts +0 -279
  276. package/libs/instance-factories/views/templates/shared/property-mapper.d.ts +0 -149
  277. package/libs/instance-factories/views/templates/shared/property-mapper.d.ts.map +0 -1
  278. package/libs/instance-factories/views/templates/shared/property-mapper.js +0 -580
  279. package/libs/instance-factories/views/templates/shared/property-mapper.js.map +0 -1
  280. package/libs/instance-factories/views/templates/shared/property-mapper.ts +0 -700
  281. package/libs/instance-factories/views/templates/shared/syntax-mapper.d.ts +0 -143
  282. package/libs/instance-factories/views/templates/shared/syntax-mapper.d.ts.map +0 -1
  283. package/libs/instance-factories/views/templates/shared/syntax-mapper.js +0 -420
  284. package/libs/instance-factories/views/templates/shared/syntax-mapper.js.map +0 -1
  285. package/libs/instance-factories/views/templates/shared/syntax-mapper.ts +0 -539
@@ -1,355 +0,0 @@
1
- async function generate(context) {
2
- return `/**
3
- * StandardFormView - Controller-Based Form View Component
4
- *
5
- * LOCAL VERSION - Uses local hooks with instance-factory-specific API client
6
- *
7
- * Supports both Create and Edit modes with:
8
- * - Controller-driven form generation
9
- * - Smart input types (text, number, boolean, relationship selectors)
10
- * - Auto-generated field detection
11
- * - Validation and error handling
12
- * - Lifecycle management (Edit/Evolve tabs)
13
- * - Foreign key relationship fields
14
- * - Two-panel layout (form + entity list)
15
- */
16
-
17
- import { useState, useEffect } from 'react';
18
- import { useEntitiesQuery, useModelSchemaQuery, useExecuteOperationMutation, useTransitionStateMutation } from '../../hooks/useApi';
19
- import { isAutoGeneratedField, isFieldRequired, initializeFormData } from '../../utils/field-helpers';
20
- import { RelationshipField } from '../../components/fields/RelationshipField';
21
- import type { View, Entity } from '../../types/api';
22
-
23
- type FormMode = 'create' | 'update';
24
- type ActiveTab = 'edit' | 'evolve';
25
-
26
- interface StandardFormViewProps {
27
- view: View;
28
- spec?: any; // Full spec for controller access
29
- }
30
-
31
- export function FormView({ view, spec }: StandardFormViewProps) {
32
- // Determine controller and model
33
- let controllerName: string;
34
- let modelName: string;
35
-
36
- if (view.controller && spec) {
37
- // New: Controller-based
38
- controllerName = view.controller;
39
- const controller = spec.controllers[view.controller];
40
- modelName = controller.model;
41
- } else {
42
- // Legacy: Model-based
43
- modelName = view.model as string;
44
- controllerName = \`\${modelName}Controller\`;
45
- }
46
-
47
- const [selectedEntity, setSelectedEntity] = useState<Entity | null>(null);
48
- const [formMode, setFormMode] = useState<FormMode>('create');
49
- const [activeTab, setActiveTab] = useState<ActiveTab>('edit');
50
- const [formData, setFormData] = useState<Record<string, any>>({});
51
- const [errors, setErrors] = useState<Record<string, string>>({});
52
- const [selectedLifecycleStates, setSelectedLifecycleStates] = useState<Record<string, string>>({});
53
-
54
- // Fetch entities and schema - USES LOCAL HOOKS
55
- const { data: entities = [], isLoading: entitiesLoading } = useEntitiesQuery(controllerName, modelName);
56
- const { data: schema } = useModelSchemaQuery(modelName);
57
- const { mutate: executeOperation, isPending } = useExecuteOperationMutation();
58
- const { mutate: transitionState, isPending: isTransitioning } = useTransitionStateMutation();
59
-
60
- const attributes = schema?.attributes || {};
61
- const relationships = schema?.relationships || {};
62
- const lifecycles = schema?.lifecycles || {};
63
-
64
- // Sync selected entity with updated entities list
65
- useEffect(() => {
66
- if (selectedEntity && entities.length > 0) {
67
- const updatedEntity = entities.find((e) => e.id === selectedEntity.id);
68
- if (updatedEntity) {
69
- const oldStates = JSON.stringify(selectedEntity.metadata?.lifecycleStates || {});
70
- const newStates = JSON.stringify(updatedEntity.metadata?.lifecycleStates || {});
71
-
72
- if (oldStates !== newStates) {
73
- setSelectedEntity(updatedEntity);
74
- setSelectedLifecycleStates({ ...(updatedEntity.metadata?.lifecycleStates || {}) });
75
- }
76
- }
77
- }
78
- }, [entities, selectedEntity?.id]);
79
-
80
- // Initialize form data when schema changes or when switching modes
81
- useEffect(() => {
82
- if (selectedEntity && formMode === 'update') {
83
- setFormData({ ...selectedEntity.data });
84
- const currentStates = selectedEntity.metadata?.lifecycleStates || {};
85
- setSelectedLifecycleStates({ ...currentStates });
86
- } else if (schema?.attributes) {
87
- setFormData(initializeFormData(schema.attributes, { includeAutoGenerated: false }));
88
- setSelectedLifecycleStates({});
89
- }
90
- }, [selectedEntity, formMode, schema]);
91
-
92
- // Check if field should be shown
93
- const shouldShowField = (attrName: string, attrDef: any): boolean => {
94
- const isAuto = isAutoGeneratedField(attrName, attrDef);
95
- // In create mode, hide auto-generated fields
96
- if (formMode === 'create' && isAuto) {
97
- return false;
98
- }
99
- // In update mode, show all fields
100
- return true;
101
- };
102
-
103
- // Handle form submission
104
- const handleSubmit = async (e: React.FormEvent) => {
105
- e.preventDefault();
106
- setErrors({});
107
-
108
- const operation = formMode === 'create' ? 'create' : 'update';
109
- const params = formMode === 'update' && selectedEntity
110
- ? { ...formData, id: selectedEntity.id }
111
- : formData;
112
-
113
- executeOperation(
114
- { controllerName, operationName: operation, params },
115
- {
116
- onSuccess: () => {
117
- if (formMode === 'create' && schema?.attributes) {
118
- setFormData(initializeFormData(schema.attributes, { includeAutoGenerated: false }));
119
- }
120
- setFormMode('create');
121
- setSelectedEntity(null);
122
- },
123
- onError: (error: any) => {
124
- setErrors({ _form: error.message || 'Operation failed' });
125
- }
126
- }
127
- );
128
- };
129
-
130
- // Handle entity selection for editing
131
- const handleEntitySelect = (entity: Entity) => {
132
- setSelectedEntity(entity);
133
- setFormMode('update');
134
- setActiveTab('edit');
135
- };
136
-
137
- // Handle lifecycle state transition
138
- const handleLifecycleTransition = (lifecycleName: string, toState: string) => {
139
- if (!selectedEntity) return;
140
-
141
- transitionState(
142
- { modelName, entityId: selectedEntity.id, toState, lifecycleName },
143
- {
144
- onSuccess: () => {
145
- setSelectedLifecycleStates((prev) => ({ ...prev, [lifecycleName]: toState }));
146
- },
147
- onError: (error: any) => {
148
- setErrors({ _lifecycle: error.message || 'Transition failed' });
149
- }
150
- }
151
- );
152
- };
153
-
154
- // Render field input
155
- const renderFieldInput = (attrName: string, attrDef: any) => {
156
- const value = formData[attrName] ?? '';
157
- const isRequired = isFieldRequired(attrDef);
158
-
159
- const handleChange = (newValue: any) => {
160
- setFormData((prev) => ({ ...prev, [attrName]: newValue }));
161
- };
162
-
163
- // Boolean field
164
- if (attrDef.type === 'Boolean') {
165
- return (
166
- <input
167
- type="checkbox"
168
- checked={!!value}
169
- onChange={(e) => handleChange(e.target.checked)}
170
- className="h-4 w-4 rounded border-gray-300"
171
- />
172
- );
173
- }
174
-
175
- // Number field
176
- if (attrDef.type === 'Integer' || attrDef.type === 'Float' || attrDef.type === 'Decimal') {
177
- return (
178
- <input
179
- type="number"
180
- value={value}
181
- onChange={(e) => handleChange(e.target.value ? Number(e.target.value) : '')}
182
- required={isRequired}
183
- className="block w-full rounded-md border-gray-300 shadow-sm focus:border-blue-500 focus:ring-blue-500"
184
- />
185
- );
186
- }
187
-
188
- // Text field (default)
189
- return (
190
- <input
191
- type="text"
192
- value={value}
193
- onChange={(e) => handleChange(e.target.value)}
194
- required={isRequired}
195
- className="block w-full rounded-md border-gray-300 shadow-sm focus:border-blue-500 focus:ring-blue-500"
196
- />
197
- );
198
- };
199
-
200
- return (
201
- <div className="flex gap-4 h-full">
202
- {/* Form Panel */}
203
- <div className="flex-1 bg-white dark:bg-gray-800 rounded-lg shadow p-6">
204
- <h2 className="text-2xl font-bold mb-4 text-gray-800 dark:text-white">
205
- {formMode === 'create' ? \`Create \${modelName}\` : \`Edit \${modelName}\`}
206
- </h2>
207
-
208
- {/* Tabs for Edit/Evolve modes */}
209
- {formMode === 'update' && Object.keys(lifecycles).length > 0 && (
210
- <div className="flex gap-2 mb-4 border-b border-gray-200">
211
- <button
212
- onClick={() => setActiveTab('edit')}
213
- className={\`px-4 py-2 font-medium \${activeTab === 'edit' ? 'border-b-2 border-blue-500 text-blue-600' : 'text-gray-500'}\`}
214
- >
215
- Edit Data
216
- </button>
217
- <button
218
- onClick={() => setActiveTab('evolve')}
219
- className={\`px-4 py-2 font-medium \${activeTab === 'evolve' ? 'border-b-2 border-blue-500 text-blue-600' : 'text-gray-500'}\`}
220
- >
221
- Lifecycle
222
- </button>
223
- </div>
224
- )}
225
-
226
- {activeTab === 'edit' ? (
227
- <form onSubmit={handleSubmit} className="space-y-4">
228
- {errors._form && (
229
- <div className="p-3 bg-red-100 text-red-700 rounded-md">{errors._form}</div>
230
- )}
231
-
232
- {/* Attributes */}
233
- {Object.entries(attributes).map(([attrName, attrDef]: [string, any]) => {
234
- if (!shouldShowField(attrName, attrDef)) return null;
235
-
236
- return (
237
- <div key={attrName}>
238
- <label className="block text-sm font-medium text-gray-700 dark:text-gray-300 mb-1">
239
- {attrName}
240
- {isFieldRequired(attrDef) && <span className="text-red-500">*</span>}
241
- </label>
242
- {renderFieldInput(attrName, attrDef)}
243
- </div>
244
- );
245
- })}
246
-
247
- {/* Relationships */}
248
- {Object.entries(relationships).map(([relName, relDef]: [string, any]) => (
249
- <RelationshipField
250
- key={relName}
251
- name={relName}
252
- relationship={relDef}
253
- value={formData[relName]}
254
- onChange={(value) => setFormData((prev) => ({ ...prev, [relName]: value }))}
255
- />
256
- ))}
257
-
258
- <div className="flex gap-2 pt-4">
259
- <button
260
- type="submit"
261
- disabled={isPending}
262
- className="px-4 py-2 bg-blue-600 text-white rounded-md hover:bg-blue-700 disabled:opacity-50"
263
- >
264
- {isPending ? 'Saving...' : formMode === 'create' ? 'Create' : 'Update'}
265
- </button>
266
- {formMode === 'update' && (
267
- <button
268
- type="button"
269
- onClick={() => {
270
- setFormMode('create');
271
- setSelectedEntity(null);
272
- if (schema?.attributes) {
273
- setFormData(initializeFormData(schema.attributes, { includeAutoGenerated: false }));
274
- }
275
- }}
276
- className="px-4 py-2 bg-gray-500 text-white rounded-md hover:bg-gray-600"
277
- >
278
- Cancel
279
- </button>
280
- )}
281
- </div>
282
- </form>
283
- ) : (
284
- /* Lifecycle Tab */
285
- <div className="space-y-4">
286
- {errors._lifecycle && (
287
- <div className="p-3 bg-red-100 text-red-700 rounded-md">{errors._lifecycle}</div>
288
- )}
289
-
290
- {Object.entries(lifecycles).map(([lifecycleName, lifecycle]: [string, any]) => {
291
- const currentState = selectedLifecycleStates[lifecycleName] || lifecycle.initial;
292
-
293
- return (
294
- <div key={lifecycleName} className="border border-gray-200 rounded-lg p-4">
295
- <h3 className="font-semibold text-lg mb-2">{lifecycleName}</h3>
296
- <p className="text-sm text-gray-600 mb-3">Current: {currentState}</p>
297
-
298
- <div className="flex flex-wrap gap-2">
299
- {Object.keys(lifecycle.states || {}).map((state) => (
300
- <button
301
- key={state}
302
- onClick={() => handleLifecycleTransition(lifecycleName, state)}
303
- disabled={isTransitioning || state === currentState}
304
- className={\`px-3 py-1 rounded-md \${state === currentState ? 'bg-blue-600 text-white' : 'bg-gray-200 text-gray-700 hover:bg-gray-300'} disabled:opacity-50\`}
305
- >
306
- {state}
307
- </button>
308
- ))}
309
- </div>
310
- </div>
311
- );
312
- })}
313
- </div>
314
- )}
315
- </div>
316
-
317
- {/* Entity List Panel */}
318
- <div className="w-80 bg-white dark:bg-gray-800 rounded-lg shadow p-4">
319
- <h3 className="text-lg font-semibold mb-3 text-gray-800 dark:text-white">
320
- {modelName} List
321
- </h3>
322
-
323
- {entitiesLoading ? (
324
- <p className="text-gray-500">Loading...</p>
325
- ) : entities.length === 0 ? (
326
- <p className="text-gray-500 italic">No entities yet</p>
327
- ) : (
328
- <div className="space-y-2">
329
- {entities.map((entity) => (
330
- <div
331
- key={entity.id}
332
- onClick={() => handleEntitySelect(entity)}
333
- className={\`p-3 rounded-md cursor-pointer \${selectedEntity?.id === entity.id ? 'bg-blue-100 border-blue-500' : 'bg-gray-50 hover:bg-gray-100'} border\`}
334
- >
335
- <p className="font-medium text-sm">{entity.id}</p>
336
- {Object.entries(entity.data).slice(0, 2).map(([key, value]) => (
337
- <p key={key} className="text-xs text-gray-600">
338
- {key}: {String(value)}
339
- </p>
340
- ))}
341
- </div>
342
- ))}
343
- </div>
344
- )}
345
- </div>
346
- </div>
347
- );
348
- }
349
-
350
- export default FormView;
351
- `;
352
- }
353
- export {
354
- generate
355
- };
@@ -1,91 +0,0 @@
1
- async function generate(context) {
2
- return `/**
3
- * ListView - Pattern-Based List View Component
4
- *
5
- * Uses pattern-based rendering with ReactPatternAdapter.
6
- * Reads from modelSchemas for schema-driven field generation.
7
- */
8
-
9
- import { useMemo } from 'react';
10
- import { useEntitiesQuery, useModelSchemaQuery } from '../../hooks/useApi';
11
- import { usePatternAdapter, REACT_PROTOCOL_MAPPING } from '../../lib/react-pattern-adapter';
12
- import type { View } from '../../types/api';
13
-
14
- interface ListViewProps {
15
- view: View;
16
- spec?: any;
17
- }
18
-
19
- export function ListView({ view, spec }: ListViewProps) {
20
- const patternAdapter = usePatternAdapter();
21
-
22
- // Determine controller and model
23
- let controllerName: string;
24
- let modelName: string;
25
-
26
- if (view.controller && spec) {
27
- controllerName = view.controller;
28
- const controller = spec.controllers[view.controller];
29
- modelName = controller.model;
30
- } else {
31
- modelName = view.model as string;
32
- controllerName = \`\${modelName}Controller\`;
33
- }
34
-
35
- // Fetch data and schema
36
- const { data: entities = [], isLoading } = useEntitiesQuery(controllerName, modelName);
37
- const { data: schema } = useModelSchemaQuery(modelName);
38
-
39
- // Build model data and schemas
40
- const modelData = useMemo(() => ({
41
- [modelName]: entities
42
- }), [modelName, entities]);
43
-
44
- const modelSchemas = useMemo(() =>
45
- schema ? { [modelName]: schema } : {}
46
- , [modelName, schema]);
47
-
48
- if (isLoading) {
49
- return <div className="p-4">Loading...</div>;
50
- }
51
-
52
- // Detect pattern
53
- const pattern = patternAdapter.detectPattern({ ...view, type: 'list' });
54
-
55
- if (!pattern) {
56
- return (
57
- <div className="p-4 text-red-600">
58
- Pattern not found for list view
59
- </div>
60
- );
61
- }
62
-
63
- // Build render context
64
- const context = {
65
- pattern,
66
- viewSpec: { ...view, type: 'list', model: modelName },
67
- modelData,
68
- modelSchemas,
69
- primaryModel: modelName,
70
- selectedEntity: null,
71
- primaryEntities: entities,
72
- protocolMapping: REACT_PROTOCOL_MAPPING,
73
- tailwindAdapter: patternAdapter['tailwindAdapter']
74
- };
75
-
76
- // Render pattern
77
- const html = patternAdapter.renderPattern(context);
78
-
79
- return (
80
- <div className="runtime-view-container p-4 h-full overflow-auto">
81
- <div dangerouslySetInnerHTML={{ __html: html }} />
82
- </div>
83
- );
84
- }
85
-
86
- export default ListView;
87
- `;
88
- }
89
- export {
90
- generate
91
- };
@@ -1,79 +0,0 @@
1
- async function generate(context) {
2
- return `/**
3
- * ViewRouter - Hybrid View Router
4
- *
5
- * Pattern-Based Rendering Architecture:
6
- * - Forms (interactive) \u2192 FormView (controller-based with React hooks)
7
- * - Display views \u2192 Pattern-based rendering (list, detail, dashboard)
8
- *
9
- * Benefits:
10
- * - Forms get React hooks, state management, UUID handling
11
- * - Display views get schema-driven pattern rendering
12
- * - Both approaches coexist seamlessly
13
- */
14
-
15
- import type { View } from '../../types/api';
16
- import { FormView } from './FormView';
17
- import { ListView } from './ListView';
18
- import { DetailView } from './DetailView';
19
- import { DashboardView } from './DashboardView';
20
-
21
- interface ViewRouterProps {
22
- view: View;
23
- spec?: any; // Full spec for controller access
24
- }
25
-
26
- export function ViewRouter({ view, spec }: ViewRouterProps) {
27
- const viewType = view.type?.toLowerCase();
28
-
29
- // Determine rendering strategy
30
- const useFormRenderer = (type: string): boolean => {
31
- // Forms require React hooks and state - use FormView (controller-based)
32
- const interactiveTypes = ['form', 'create', 'edit', 'create-form', 'edit-form'];
33
- return interactiveTypes.includes(type);
34
- };
35
-
36
- // Route to appropriate renderer
37
- if (useFormRenderer(viewType)) {
38
- // Controller-based form with React hooks
39
- return <FormView view={view} spec={spec} />;
40
- }
41
-
42
- // Pattern-based rendering for display views
43
- switch (viewType) {
44
- case 'list':
45
- case 'table':
46
- return <ListView view={view} spec={spec} />;
47
-
48
- case 'detail':
49
- case 'master-detail':
50
- return <DetailView view={view} spec={spec} />;
51
-
52
- case 'dashboard':
53
- return <DashboardView view={view} spec={spec} />;
54
-
55
- default:
56
- return (
57
- <div className="flex items-center justify-center h-full p-8">
58
- <div className="text-center">
59
- <h3 className="text-lg font-semibold text-gray-800 dark:text-gray-100 mb-2">
60
- Unknown View Type: {view.type}
61
- </h3>
62
- <p className="text-gray-500 dark:text-gray-400">
63
- View "{view.name}" has an unsupported type.
64
- </p>
65
- <p className="text-sm text-gray-400 dark:text-gray-500 mt-2">
66
- Supported types: list, detail, dashboard, form
67
- </p>
68
- </div>
69
- </div>
70
- );
71
- }
72
- }
73
-
74
- export default ViewRouter;
75
- `;
76
- }
77
- export {
78
- generate
79
- };
@@ -1,48 +0,0 @@
1
- import {
2
- BaseComponentGenerator,
3
- ViewSpec,
4
- StateDefinition,
5
- EventDefinition,
6
- UIComponent,
7
- RenderContext,
8
- GeneratorConfig,
9
- extractComponentTypes,
10
- countComponents,
11
- validateNestingDepth
12
- } from "./templates/shared/base-generator.js";
13
- export * from "./templates/shared/property-mapper.js";
14
- export * from "./templates/shared/syntax-mapper.js";
15
- export * from "./templates/shared/component-metadata.js";
16
- import {
17
- ATOMIC_COMPONENTS_REGISTRY,
18
- AtomicComponentDefinition
19
- } from "./templates/shared/atomic-components-registry.js";
20
- import {
21
- ComponentAdapter,
22
- ComponentLibraryAdapter,
23
- ComponentMapping,
24
- renderProps,
25
- indent,
26
- wrapWithChildren
27
- } from "./templates/shared/adapter-types.js";
28
- export * from "./templates/react/react-component-generator.js";
29
- export {
30
- ATOMIC_COMPONENTS_REGISTRY,
31
- AtomicComponentDefinition,
32
- BaseComponentGenerator,
33
- ComponentAdapter,
34
- ComponentLibraryAdapter,
35
- ComponentMapping,
36
- EventDefinition,
37
- GeneratorConfig,
38
- RenderContext,
39
- StateDefinition,
40
- UIComponent,
41
- ViewSpec,
42
- countComponents,
43
- extractComponentTypes,
44
- indent,
45
- renderProps,
46
- validateNestingDepth,
47
- wrapWithChildren
48
- };