@specverse/engines 4.1.28 → 4.2.0

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 (237) 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/dist/inference/comprehensive-engine.d.ts.map +1 -1
  5. package/dist/inference/comprehensive-engine.js +3 -19
  6. package/dist/inference/comprehensive-engine.js.map +1 -1
  7. package/dist/inference/core/rule-engine.d.ts +31 -0
  8. package/dist/inference/core/rule-engine.d.ts.map +1 -1
  9. package/dist/inference/core/rule-engine.js +117 -33
  10. package/dist/inference/core/rule-engine.js.map +1 -1
  11. package/dist/inference/core/rule-file-types.d.ts +0 -2
  12. package/dist/inference/core/rule-file-types.d.ts.map +1 -1
  13. package/dist/inference/core/rule-file-types.js +3 -6
  14. package/dist/inference/core/rule-file-types.js.map +1 -1
  15. package/dist/inference/core/rule-loader.d.ts +5 -15
  16. package/dist/inference/core/rule-loader.d.ts.map +1 -1
  17. package/dist/inference/core/rule-loader.js +43 -132
  18. package/dist/inference/core/rule-loader.js.map +1 -1
  19. package/dist/inference/core/types.d.ts +0 -6
  20. package/dist/inference/core/types.d.ts.map +1 -1
  21. package/dist/inference/core/types.js +0 -4
  22. package/dist/inference/core/types.js.map +1 -1
  23. package/dist/inference/logical/generators/component-type-resolver.d.ts +0 -26
  24. package/dist/inference/logical/generators/component-type-resolver.d.ts.map +1 -1
  25. package/dist/inference/logical/generators/component-type-resolver.js +0 -19
  26. package/dist/inference/logical/generators/component-type-resolver.js.map +1 -1
  27. package/dist/inference/logical/generators/specialist-view-expander.d.ts +1 -17
  28. package/dist/inference/logical/generators/specialist-view-expander.d.ts.map +1 -1
  29. package/dist/inference/logical/generators/specialist-view-expander.js +0 -15
  30. package/dist/inference/logical/generators/specialist-view-expander.js.map +1 -1
  31. package/dist/inference/logical/generators/view-generator.d.ts +4 -14
  32. package/dist/inference/logical/generators/view-generator.d.ts.map +1 -1
  33. package/dist/inference/logical/generators/view-generator.js +6 -26
  34. package/dist/inference/logical/generators/view-generator.js.map +1 -1
  35. package/dist/inference/logical/index.d.ts +2 -2
  36. package/dist/inference/logical/index.d.ts.map +1 -1
  37. package/dist/inference/logical/logical-engine.d.ts.map +1 -1
  38. package/dist/inference/logical/logical-engine.js +17 -80
  39. package/dist/inference/logical/logical-engine.js.map +1 -1
  40. package/dist/inference/quint-transpiler.d.ts +5 -3
  41. package/dist/inference/quint-transpiler.d.ts.map +1 -1
  42. package/dist/inference/quint-transpiler.js +11 -6
  43. package/dist/inference/quint-transpiler.js.map +1 -1
  44. package/dist/libs/instance-factories/applications/templates/generic/main-generator.js +3 -3
  45. package/dist/libs/instance-factories/applications/templates/react/api-client-generator.js +16 -6
  46. package/dist/libs/instance-factories/applications/templates/react-starter/app-tsx-generator.js +110 -0
  47. package/dist/libs/instance-factories/applications/templates/react-starter/dashboard-body-composer.js +121 -0
  48. package/dist/libs/instance-factories/applications/templates/react-starter/detail-body-composer.js +78 -0
  49. package/dist/libs/instance-factories/applications/templates/react-starter/form-body-composer.js +190 -0
  50. package/dist/libs/instance-factories/applications/templates/react-starter/helpers-emitter.js +45 -0
  51. package/dist/libs/instance-factories/applications/templates/react-starter/html-to-jsx.js +192 -0
  52. package/dist/libs/instance-factories/applications/templates/react-starter/list-body-composer.js +46 -0
  53. package/dist/libs/instance-factories/applications/templates/react-starter/orchestrator.js +30 -0
  54. package/dist/libs/instance-factories/applications/templates/react-starter/package-json-generator.js +38 -0
  55. package/dist/libs/instance-factories/applications/templates/react-starter/regen-safety.js +89 -0
  56. package/dist/libs/instance-factories/applications/templates/react-starter/view-emitter.js +56 -0
  57. package/dist/libs/instance-factories/applications/templates/react-starter/views-generator.js +66 -0
  58. package/dist/libs/instance-factories/cli/templates/commander/command-generator.js +14 -11
  59. package/dist/libs/instance-factories/controllers/templates/fastify/server-generator.js +11 -3
  60. package/dist/libs/instance-factories/services/templates/prisma/controller-generator.js +27 -17
  61. package/dist/libs/instance-factories/shared/path-resolver.js +1 -1
  62. package/dist/realize/index.d.ts.map +1 -1
  63. package/dist/realize/index.js +15 -22
  64. package/dist/realize/index.js.map +1 -1
  65. package/dist/registry/utils/manifest-adapter.d.ts +8 -1
  66. package/dist/registry/utils/manifest-adapter.d.ts.map +1 -1
  67. package/dist/registry/utils/manifest-adapter.js +8 -1
  68. package/dist/registry/utils/manifest-adapter.js.map +1 -1
  69. package/libs/instance-factories/applications/react-app-starter.yaml +150 -0
  70. package/libs/instance-factories/applications/templates/generic/main-generator.ts +3 -3
  71. package/libs/instance-factories/applications/templates/react/api-client-generator.ts +16 -6
  72. package/libs/instance-factories/applications/templates/react-starter/README.md +211 -0
  73. package/libs/instance-factories/applications/templates/react-starter/__tests__/dashboard-body-composer.test.ts +153 -0
  74. package/libs/instance-factories/applications/templates/react-starter/__tests__/detail-body-composer.test.ts +145 -0
  75. package/libs/instance-factories/applications/templates/react-starter/__tests__/form-body-composer.test.ts +175 -0
  76. package/libs/instance-factories/applications/templates/react-starter/__tests__/helpers-emitter.test.ts +55 -0
  77. package/libs/instance-factories/applications/templates/react-starter/__tests__/html-to-jsx.test.ts +140 -0
  78. package/libs/instance-factories/applications/templates/react-starter/__tests__/list-body-composer.test.ts +146 -0
  79. package/libs/instance-factories/applications/templates/react-starter/__tests__/orchestrator.test.ts +163 -0
  80. package/libs/instance-factories/applications/templates/react-starter/__tests__/parity-p2-factory-imports.test.ts +116 -0
  81. package/libs/instance-factories/applications/templates/react-starter/__tests__/parity-p3-rendered-output.test.ts +183 -0
  82. package/libs/instance-factories/applications/templates/react-starter/__tests__/regen-safety.test.ts +144 -0
  83. package/libs/instance-factories/applications/templates/react-starter/__tests__/starter-generators.test.ts +114 -0
  84. package/libs/instance-factories/applications/templates/react-starter/__tests__/view-emitter.test.ts +107 -0
  85. package/libs/instance-factories/applications/templates/react-starter/__tests__/views-generator.test.ts +139 -0
  86. package/libs/instance-factories/applications/templates/react-starter/app-tsx-generator.ts +141 -0
  87. package/libs/instance-factories/applications/templates/react-starter/dashboard-body-composer.ts +174 -0
  88. package/libs/instance-factories/applications/templates/react-starter/detail-body-composer.ts +135 -0
  89. package/libs/instance-factories/applications/templates/react-starter/form-body-composer.ts +306 -0
  90. package/libs/instance-factories/applications/templates/react-starter/helpers-emitter.ts +60 -0
  91. package/libs/instance-factories/applications/templates/react-starter/html-to-jsx.ts +334 -0
  92. package/libs/instance-factories/applications/templates/react-starter/list-body-composer.ts +120 -0
  93. package/libs/instance-factories/applications/templates/react-starter/orchestrator.ts +80 -0
  94. package/libs/instance-factories/applications/templates/react-starter/package-json-generator.ts +57 -0
  95. package/libs/instance-factories/applications/templates/react-starter/regen-safety.ts +157 -0
  96. package/libs/instance-factories/applications/templates/react-starter/skeletons/dashboard.tsx.template +47 -0
  97. package/libs/instance-factories/applications/templates/react-starter/skeletons/detail.tsx.template +94 -0
  98. package/libs/instance-factories/applications/templates/react-starter/skeletons/form.tsx.template +114 -0
  99. package/libs/instance-factories/applications/templates/react-starter/skeletons/list.tsx.template +72 -0
  100. package/libs/instance-factories/applications/templates/react-starter/view-emitter.ts +151 -0
  101. package/libs/instance-factories/applications/templates/react-starter/views-generator.ts +137 -0
  102. package/libs/instance-factories/cli/templates/commander/command-generator.ts +14 -11
  103. package/libs/instance-factories/controllers/templates/fastify/server-generator.ts +11 -3
  104. package/libs/instance-factories/services/templates/prisma/controller-generator.ts +27 -17
  105. package/libs/instance-factories/shared/path-resolver.ts +8 -2
  106. package/package.json +3 -3
  107. package/dist/libs/instance-factories/applications/templates/react/_view-components-source.js +0 -530
  108. package/dist/libs/instance-factories/applications/templates/react/app-tsx-generator.js +0 -73
  109. package/dist/libs/instance-factories/applications/templates/react/field-helpers-generator.js +0 -99
  110. package/dist/libs/instance-factories/applications/templates/react/package-json-generator.js +0 -49
  111. package/dist/libs/instance-factories/applications/templates/react/pattern-adapter-generator.js +0 -156
  112. package/dist/libs/instance-factories/applications/templates/react/react-pattern-adapter.js +0 -935
  113. package/dist/libs/instance-factories/applications/templates/react/relationship-field-generator.js +0 -143
  114. package/dist/libs/instance-factories/applications/templates/react/tailwind-adapter-generator.js +0 -646
  115. package/dist/libs/instance-factories/applications/templates/react/tailwind-adapter-wrapper-generator.js +0 -65
  116. package/dist/libs/instance-factories/applications/templates/react/view-dashboard-generator.js +0 -143
  117. package/dist/libs/instance-factories/applications/templates/react/view-detail-generator.js +0 -143
  118. package/dist/libs/instance-factories/applications/templates/react/view-form-generator.js +0 -355
  119. package/dist/libs/instance-factories/applications/templates/react/view-list-generator.js +0 -91
  120. package/dist/libs/instance-factories/applications/templates/react/view-router-generator.js +0 -79
  121. package/dist/libs/instance-factories/tools/templates/vscode/vscode-extension-generator.js.bak +0 -244
  122. package/dist/libs/instance-factories/views/index.js +0 -48
  123. package/dist/libs/instance-factories/views/templates/react/adapters/antd-adapter.js +0 -742
  124. package/dist/libs/instance-factories/views/templates/react/adapters/mui-adapter.js +0 -824
  125. package/dist/libs/instance-factories/views/templates/react/adapters/shadcn-adapter.js +0 -719
  126. package/dist/libs/instance-factories/views/templates/react/app-generator.js +0 -45
  127. package/dist/libs/instance-factories/views/templates/react/components-generator.js +0 -820
  128. package/dist/libs/instance-factories/views/templates/react/forms-generator.js +0 -275
  129. package/dist/libs/instance-factories/views/templates/react/frontend-package-json-generator.js +0 -46
  130. package/dist/libs/instance-factories/views/templates/react/hooks-generator.js +0 -81
  131. package/dist/libs/instance-factories/views/templates/react/index-css-generator.js +0 -9
  132. package/dist/libs/instance-factories/views/templates/react/index-html-generator.js +0 -23
  133. package/dist/libs/instance-factories/views/templates/react/main-tsx-generator.js +0 -21
  134. package/dist/libs/instance-factories/views/templates/react/react-component-generator.js +0 -299
  135. package/dist/libs/instance-factories/views/templates/react/router-generator.js +0 -136
  136. package/dist/libs/instance-factories/views/templates/react/router-generic-generator.js +0 -107
  137. package/dist/libs/instance-factories/views/templates/react/shared-utils-generator.js +0 -187
  138. package/dist/libs/instance-factories/views/templates/react/spec-json-generator.js +0 -7
  139. package/dist/libs/instance-factories/views/templates/react/types-generator.js +0 -56
  140. package/dist/libs/instance-factories/views/templates/react/views-metadata-generator.js +0 -27
  141. package/dist/libs/instance-factories/views/templates/react/vite-config-generator.js +0 -29
  142. package/dist/libs/instance-factories/views/templates/runtime/runtime-view-renderer.js +0 -261
  143. package/dist/libs/instance-factories/views/templates/shared/adapter-types.js +0 -34
  144. package/dist/libs/instance-factories/views/templates/shared/atomic-components-registry.js +0 -800
  145. package/dist/libs/instance-factories/views/templates/shared/base-generator.js +0 -305
  146. package/dist/libs/instance-factories/views/templates/shared/component-metadata.js +0 -517
  147. package/dist/libs/instance-factories/views/templates/shared/composite-pattern-types.js +0 -0
  148. package/dist/libs/instance-factories/views/templates/shared/composite-patterns.js +0 -445
  149. package/dist/libs/instance-factories/views/templates/shared/index.js +0 -80
  150. package/dist/libs/instance-factories/views/templates/shared/pattern-validator.js +0 -210
  151. package/dist/libs/instance-factories/views/templates/shared/property-mapper.js +0 -492
  152. package/dist/libs/instance-factories/views/templates/shared/syntax-mapper.js +0 -321
  153. package/dist/realize/index.js.bak +0 -758
  154. package/libs/instance-factories/applications/react-app.yaml +0 -186
  155. package/libs/instance-factories/applications/templates/react/_view-components-source.ts +0 -555
  156. package/libs/instance-factories/applications/templates/react/app-tsx-generator.ts +0 -94
  157. package/libs/instance-factories/applications/templates/react/field-helpers-generator.ts +0 -106
  158. package/libs/instance-factories/applications/templates/react/package-json-generator.ts +0 -57
  159. package/libs/instance-factories/applications/templates/react/pattern-adapter-generator.ts +0 -179
  160. package/libs/instance-factories/applications/templates/react/react-pattern-adapter.tsx +0 -1347
  161. package/libs/instance-factories/applications/templates/react/relationship-field-generator.ts +0 -150
  162. package/libs/instance-factories/applications/templates/react/tailwind-adapter-generator.ts +0 -704
  163. package/libs/instance-factories/applications/templates/react/tailwind-adapter-wrapper-generator.ts +0 -84
  164. package/libs/instance-factories/applications/templates/react/view-dashboard-generator.ts +0 -150
  165. package/libs/instance-factories/applications/templates/react/view-detail-generator.ts +0 -150
  166. package/libs/instance-factories/applications/templates/react/view-form-generator.ts +0 -362
  167. package/libs/instance-factories/applications/templates/react/view-list-generator.ts +0 -98
  168. package/libs/instance-factories/applications/templates/react/view-router-generator.ts +0 -89
  169. package/libs/instance-factories/views/README.md +0 -62
  170. package/libs/instance-factories/views/index.d.ts +0 -13
  171. package/libs/instance-factories/views/index.d.ts.map +0 -1
  172. package/libs/instance-factories/views/index.js +0 -18
  173. package/libs/instance-factories/views/index.js.map +0 -1
  174. package/libs/instance-factories/views/index.ts +0 -45
  175. package/libs/instance-factories/views/react-components.yaml +0 -129
  176. package/libs/instance-factories/views/templates/ARCHITECTURE.md +0 -198
  177. package/libs/instance-factories/views/templates/react/adapters/antd-adapter.ts +0 -869
  178. package/libs/instance-factories/views/templates/react/adapters/mui-adapter.ts +0 -953
  179. package/libs/instance-factories/views/templates/react/adapters/shadcn-adapter.ts +0 -806
  180. package/libs/instance-factories/views/templates/react/app-generator.ts +0 -55
  181. package/libs/instance-factories/views/templates/react/components-generator.ts +0 -938
  182. package/libs/instance-factories/views/templates/react/forms-generator.ts +0 -325
  183. package/libs/instance-factories/views/templates/react/frontend-package-json-generator.ts +0 -57
  184. package/libs/instance-factories/views/templates/react/hooks-generator.ts +0 -106
  185. package/libs/instance-factories/views/templates/react/index-css-generator.ts +0 -14
  186. package/libs/instance-factories/views/templates/react/index-html-generator.ts +0 -34
  187. package/libs/instance-factories/views/templates/react/main-tsx-generator.ts +0 -29
  188. package/libs/instance-factories/views/templates/react/react-component-generator.d.ts +0 -152
  189. package/libs/instance-factories/views/templates/react/react-component-generator.d.ts.map +0 -1
  190. package/libs/instance-factories/views/templates/react/react-component-generator.js +0 -398
  191. package/libs/instance-factories/views/templates/react/react-component-generator.js.map +0 -1
  192. package/libs/instance-factories/views/templates/react/react-component-generator.ts +0 -533
  193. package/libs/instance-factories/views/templates/react/router-generator.ts +0 -197
  194. package/libs/instance-factories/views/templates/react/router-generic-generator.ts +0 -132
  195. package/libs/instance-factories/views/templates/react/shared-utils-generator.ts +0 -196
  196. package/libs/instance-factories/views/templates/react/spec-json-generator.ts +0 -17
  197. package/libs/instance-factories/views/templates/react/types-generator.ts +0 -76
  198. package/libs/instance-factories/views/templates/react/views-metadata-generator.ts +0 -42
  199. package/libs/instance-factories/views/templates/react/vite-config-generator.ts +0 -38
  200. package/libs/instance-factories/views/templates/runtime/runtime-view-renderer.d.ts.map +0 -1
  201. package/libs/instance-factories/views/templates/runtime/runtime-view-renderer.js.map +0 -1
  202. package/libs/instance-factories/views/templates/runtime/runtime-view-renderer.ts +0 -474
  203. package/libs/instance-factories/views/templates/shared/__tests__/composite-patterns.test.ts +0 -242
  204. package/libs/instance-factories/views/templates/shared/adapter-types.d.ts +0 -77
  205. package/libs/instance-factories/views/templates/shared/adapter-types.d.ts.map +0 -1
  206. package/libs/instance-factories/views/templates/shared/adapter-types.js +0 -47
  207. package/libs/instance-factories/views/templates/shared/adapter-types.js.map +0 -1
  208. package/libs/instance-factories/views/templates/shared/adapter-types.ts +0 -142
  209. package/libs/instance-factories/views/templates/shared/atomic-components-registry.d.ts +0 -63
  210. package/libs/instance-factories/views/templates/shared/atomic-components-registry.d.ts.map +0 -1
  211. package/libs/instance-factories/views/templates/shared/atomic-components-registry.js +0 -822
  212. package/libs/instance-factories/views/templates/shared/atomic-components-registry.js.map +0 -1
  213. package/libs/instance-factories/views/templates/shared/atomic-components-registry.ts +0 -908
  214. package/libs/instance-factories/views/templates/shared/base-generator.d.ts +0 -247
  215. package/libs/instance-factories/views/templates/shared/base-generator.d.ts.map +0 -1
  216. package/libs/instance-factories/views/templates/shared/base-generator.js +0 -363
  217. package/libs/instance-factories/views/templates/shared/base-generator.js.map +0 -1
  218. package/libs/instance-factories/views/templates/shared/base-generator.ts +0 -608
  219. package/libs/instance-factories/views/templates/shared/component-metadata.d.ts +0 -254
  220. package/libs/instance-factories/views/templates/shared/component-metadata.d.ts.map +0 -1
  221. package/libs/instance-factories/views/templates/shared/component-metadata.js +0 -602
  222. package/libs/instance-factories/views/templates/shared/component-metadata.js.map +0 -1
  223. package/libs/instance-factories/views/templates/shared/component-metadata.ts +0 -803
  224. package/libs/instance-factories/views/templates/shared/composite-pattern-types.ts +0 -250
  225. package/libs/instance-factories/views/templates/shared/composite-patterns.ts +0 -535
  226. package/libs/instance-factories/views/templates/shared/index.ts +0 -68
  227. package/libs/instance-factories/views/templates/shared/pattern-validator.ts +0 -279
  228. package/libs/instance-factories/views/templates/shared/property-mapper.d.ts +0 -149
  229. package/libs/instance-factories/views/templates/shared/property-mapper.d.ts.map +0 -1
  230. package/libs/instance-factories/views/templates/shared/property-mapper.js +0 -580
  231. package/libs/instance-factories/views/templates/shared/property-mapper.js.map +0 -1
  232. package/libs/instance-factories/views/templates/shared/property-mapper.ts +0 -700
  233. package/libs/instance-factories/views/templates/shared/syntax-mapper.d.ts +0 -143
  234. package/libs/instance-factories/views/templates/shared/syntax-mapper.d.ts.map +0 -1
  235. package/libs/instance-factories/views/templates/shared/syntax-mapper.js +0 -420
  236. package/libs/instance-factories/views/templates/shared/syntax-mapper.js.map +0 -1
  237. package/libs/instance-factories/views/templates/shared/syntax-mapper.ts +0 -539
@@ -1,539 +0,0 @@
1
- /**
2
- * Syntax Mapper - Framework Syntax Patterns
3
- *
4
- * Maps universal programming patterns to framework-specific syntax.
5
- * Enables consistent code generation across React, Vue, Svelte, Angular, and runtime.
6
- *
7
- * Architecture:
8
- * - SyntaxPattern: Template strings for each framework
9
- * - SYNTAX_PATTERNS: Universal patterns (state, loops, events, conditions, imports)
10
- * - getSyntaxPattern(): Template variable replacement
11
- *
12
- * Example:
13
- * getSyntaxPattern('stateDeclaration', 'react', {name: 'count', initial: '0'})
14
- * → "const [count, setCount] = useState(0);"
15
- */
16
-
17
- // ============================================================================
18
- // Types
19
- // ============================================================================
20
-
21
- /**
22
- * All supported framework targets for syntax generation
23
- */
24
- export type FrameworkTarget = 'react' | 'vue' | 'svelte' | 'angular' | 'runtime';
25
-
26
- /**
27
- * Syntax pattern definition for a single programming pattern
28
- * Maps each framework to its specific syntax template
29
- */
30
- export interface SyntaxPattern {
31
- react: string;
32
- vue: string;
33
- svelte: string;
34
- angular: string;
35
- runtime: string;
36
- }
37
-
38
- /**
39
- * Available syntax pattern categories
40
- */
41
- export type SyntaxPatternKey =
42
- // State management
43
- | 'stateDeclaration'
44
- | 'stateUpdate'
45
- | 'stateGetter'
46
- // Rendering patterns
47
- | 'loopRender'
48
- | 'conditionalRender'
49
- | 'componentRender'
50
- // Event handling
51
- | 'eventHandler'
52
- | 'eventBinding'
53
- // Lifecycle
54
- | 'onMount'
55
- | 'onUnmount'
56
- | 'onUpdate'
57
- // Props/Attributes
58
- | 'propDeclaration'
59
- | 'propAccess'
60
- | 'propBinding'
61
- // Imports
62
- | 'componentImport'
63
- | 'hookImport'
64
- | 'libraryImport';
65
-
66
- // ============================================================================
67
- // Syntax Pattern Definitions
68
- // ============================================================================
69
-
70
- /**
71
- * State Management Patterns
72
- */
73
- export const STATE_PATTERNS: Record<string, SyntaxPattern> = {
74
- /**
75
- * Declare a state variable
76
- * Variables: name, Name (capitalized), type (optional), initial
77
- */
78
- stateDeclaration: {
79
- react: 'const [${name}, set${Name}] = useState<${type}>(${initial});',
80
- vue: 'const ${name} = ref<${type}>(${initial});',
81
- svelte: 'let ${name}: ${type} = ${initial};',
82
- angular: '${name}: ${type} = ${initial};',
83
- runtime: 'const [${name}, set${Name}] = useState<${type}>(${initial});'
84
- },
85
-
86
- /**
87
- * Update a state variable
88
- * Variables: name, Name (capitalized), value
89
- */
90
- stateUpdate: {
91
- react: 'set${Name}(${value});',
92
- vue: '${name}.value = ${value};',
93
- svelte: '${name} = ${value};',
94
- angular: 'this.${name} = ${value};',
95
- runtime: 'set${Name}(${value});'
96
- },
97
-
98
- /**
99
- * Access a state variable value
100
- * Variables: name
101
- */
102
- stateGetter: {
103
- react: '${name}',
104
- vue: '${name}.value',
105
- svelte: '${name}',
106
- angular: 'this.${name}',
107
- runtime: '${name}'
108
- }
109
- };
110
-
111
- /**
112
- * Rendering Patterns
113
- */
114
- export const RENDER_PATTERNS: Record<string, SyntaxPattern> = {
115
- /**
116
- * Render array of items with loop
117
- * Variables: array, item, key, Component
118
- */
119
- loopRender: {
120
- react: '{${array}.map((${item}) => <${Component} key={${item}.${key}} ${item}={${item}} />)}',
121
- vue: '<${Component} v-for="${item} in ${array}" :key="${item}.${key}" :${item}="${item}" />',
122
- svelte: '{#each ${array} as ${item} (${item}.${key})}<${Component} ${item}={${item}} />{/each}',
123
- angular: '<${component} *ngFor="let ${item} of ${array}; trackBy: track${Item}" [${item}]="${item}"></${component}>',
124
- runtime: '{${array}.map((${item}) => createElement(${Component}, { key: ${item}.${key}, ${item} }))}'
125
- },
126
-
127
- /**
128
- * Conditional rendering
129
- * Variables: condition, Component, props (optional)
130
- */
131
- conditionalRender: {
132
- react: '{${condition} && <${Component} ${props} />}',
133
- vue: '<${Component} v-if="${condition}" ${props} />',
134
- svelte: '{#if ${condition}}<${Component} ${props} />{/if}',
135
- angular: '<${component} *ngIf="${condition}" ${props}></${component}>',
136
- runtime: '{${condition} && createElement(${Component}, ${props})}'
137
- },
138
-
139
- /**
140
- * Render a component with props
141
- * Variables: Component, props
142
- */
143
- componentRender: {
144
- react: '<${Component} ${props} />',
145
- vue: '<${Component} ${props} />',
146
- svelte: '<${Component} ${props} />',
147
- angular: '<${component} ${props}></${component}>',
148
- runtime: 'createElement(${Component}, ${props})'
149
- }
150
- };
151
-
152
- /**
153
- * Event Handling Patterns
154
- */
155
- export const EVENT_PATTERNS: Record<string, SyntaxPattern> = {
156
- /**
157
- * Declare event handler function
158
- * Variables: name, Name (capitalized), params, body
159
- */
160
- eventHandler: {
161
- react: 'const handle${Name} = (${params}) => {\n ${body}\n};',
162
- vue: 'const handle${Name} = (${params}) => {\n ${body}\n};',
163
- svelte: 'function handle${Name}(${params}) {\n ${body}\n}',
164
- angular: 'handle${Name}(${params}): void {\n ${body}\n}',
165
- runtime: 'const handle${Name} = (${params}) => {\n ${body}\n};'
166
- },
167
-
168
- /**
169
- * Bind event to handler
170
- * Variables: event, handler
171
- */
172
- eventBinding: {
173
- react: '${event}={${handler}}',
174
- vue: '@${event}="${handler}"',
175
- svelte: 'on:${event}={${handler}}',
176
- angular: '(${event})="${handler}($event)"',
177
- runtime: '${event}: ${handler}'
178
- }
179
- };
180
-
181
- /**
182
- * Lifecycle Patterns
183
- */
184
- export const LIFECYCLE_PATTERNS: Record<string, SyntaxPattern> = {
185
- /**
186
- * Component mount lifecycle
187
- * Variables: body
188
- */
189
- onMount: {
190
- react: 'useEffect(() => {\n ${body}\n}, []);',
191
- vue: 'onMounted(() => {\n ${body}\n});',
192
- svelte: 'onMount(() => {\n ${body}\n});',
193
- angular: 'ngOnInit(): void {\n ${body}\n}',
194
- runtime: 'useEffect(() => {\n ${body}\n}, []);'
195
- },
196
-
197
- /**
198
- * Component unmount lifecycle
199
- * Variables: body
200
- */
201
- onUnmount: {
202
- react: 'useEffect(() => {\n return () => {\n ${body}\n };\n}, []);',
203
- vue: 'onUnmounted(() => {\n ${body}\n});',
204
- svelte: 'onDestroy(() => {\n ${body}\n});',
205
- angular: 'ngOnDestroy(): void {\n ${body}\n}',
206
- runtime: 'useEffect(() => {\n return () => {\n ${body}\n };\n}, []);'
207
- },
208
-
209
- /**
210
- * Value change/update lifecycle
211
- * Variables: dependencies, body
212
- */
213
- onUpdate: {
214
- react: 'useEffect(() => {\n ${body}\n}, [${dependencies}]);',
215
- vue: 'watch([${dependencies}], () => {\n ${body}\n});',
216
- svelte: '$: if (${dependencies}) {\n ${body}\n}',
217
- angular: 'ngOnChanges(changes: SimpleChanges): void {\n ${body}\n}',
218
- runtime: 'useEffect(() => {\n ${body}\n}, [${dependencies}]);'
219
- }
220
- };
221
-
222
- /**
223
- * Props/Attributes Patterns
224
- */
225
- export const PROP_PATTERNS: Record<string, SyntaxPattern> = {
226
- /**
227
- * Declare component props/properties
228
- * Variables: name, type, required (boolean)
229
- */
230
- propDeclaration: {
231
- react: '${name}${required ? "" : "?"}: ${type}',
232
- vue: '${name}: { type: ${type}, required: ${required} }',
233
- svelte: 'export let ${name}: ${type}${required ? "" : " | undefined"};',
234
- angular: '@Input() ${name}${required ? "!" : "?"}: ${type};',
235
- runtime: '${name}${required ? "" : "?"}: ${type}'
236
- },
237
-
238
- /**
239
- * Access props inside component
240
- * Variables: name
241
- */
242
- propAccess: {
243
- react: '${name}',
244
- vue: 'props.${name}',
245
- svelte: '${name}',
246
- angular: 'this.${name}',
247
- runtime: '${name}'
248
- },
249
-
250
- /**
251
- * Bind prop value to component
252
- * Variables: name, value
253
- */
254
- propBinding: {
255
- react: '${name}={${value}}',
256
- vue: ':${name}="${value}"',
257
- svelte: '${name}={${value}}',
258
- angular: '[${name}]="${value}"',
259
- runtime: '${name}: ${value}'
260
- }
261
- };
262
-
263
- /**
264
- * Import Patterns
265
- */
266
- export const IMPORT_PATTERNS: Record<string, SyntaxPattern> = {
267
- /**
268
- * Import a component
269
- * Variables: Component, path
270
- */
271
- componentImport: {
272
- react: "import ${Component} from '${path}';",
273
- vue: "import ${Component} from '${path}';",
274
- svelte: "import ${Component} from '${path}';",
275
- angular: "import { ${Component} } from '${path}';",
276
- runtime: "import ${Component} from '${path}';"
277
- },
278
-
279
- /**
280
- * Import hooks/composables
281
- * Variables: hooks (comma-separated), source
282
- */
283
- hookImport: {
284
- react: "import { ${hooks} } from '${source}';",
285
- vue: "import { ${hooks} } from '${source}';",
286
- svelte: "import { ${hooks} } from '${source}';",
287
- angular: "import { ${hooks} } from '${source}';",
288
- runtime: "import { ${hooks} } from '${source}';"
289
- },
290
-
291
- /**
292
- * Import from library
293
- * Variables: exports, library
294
- */
295
- libraryImport: {
296
- react: "import { ${exports} } from '${library}';",
297
- vue: "import { ${exports} } from '${library}';",
298
- svelte: "import { ${exports} } from '${library}';",
299
- angular: "import { ${exports} } from '${library}';",
300
- runtime: "import { ${exports} } from '${library}';"
301
- }
302
- };
303
-
304
- /**
305
- * All syntax patterns organized by category
306
- */
307
- export const SYNTAX_PATTERNS: Record<SyntaxPatternKey, SyntaxPattern> = {
308
- // State
309
- stateDeclaration: STATE_PATTERNS.stateDeclaration,
310
- stateUpdate: STATE_PATTERNS.stateUpdate,
311
- stateGetter: STATE_PATTERNS.stateGetter,
312
- // Rendering
313
- loopRender: RENDER_PATTERNS.loopRender,
314
- conditionalRender: RENDER_PATTERNS.conditionalRender,
315
- componentRender: RENDER_PATTERNS.componentRender,
316
- // Events
317
- eventHandler: EVENT_PATTERNS.eventHandler,
318
- eventBinding: EVENT_PATTERNS.eventBinding,
319
- // Lifecycle
320
- onMount: LIFECYCLE_PATTERNS.onMount,
321
- onUnmount: LIFECYCLE_PATTERNS.onUnmount,
322
- onUpdate: LIFECYCLE_PATTERNS.onUpdate,
323
- // Props
324
- propDeclaration: PROP_PATTERNS.propDeclaration,
325
- propAccess: PROP_PATTERNS.propAccess,
326
- propBinding: PROP_PATTERNS.propBinding,
327
- // Imports
328
- componentImport: IMPORT_PATTERNS.componentImport,
329
- hookImport: IMPORT_PATTERNS.hookImport,
330
- libraryImport: IMPORT_PATTERNS.libraryImport
331
- };
332
-
333
- // ============================================================================
334
- // Template Replacement Functions
335
- // ============================================================================
336
-
337
- /**
338
- * Replaces template variables in a pattern string
339
- *
340
- * Template variables use ${variableName} syntax.
341
- * Special handling for capitalization: ${Name} will capitalize first letter
342
- *
343
- * @param template - Template string with ${variables}
344
- * @param variables - Object mapping variable names to values
345
- * @returns String with variables replaced
346
- */
347
- export function replaceTemplateVariables(
348
- template: string,
349
- variables: Record<string, any>
350
- ): string {
351
- let result = template;
352
-
353
- // Replace all ${variable} patterns
354
- for (const [key, value] of Object.entries(variables)) {
355
- // Handle capitalized version (e.g., ${Name} from ${name})
356
- const capitalizedKey = key.charAt(0).toUpperCase() + key.slice(1);
357
- const capitalizedPattern = new RegExp(`\\$\\{${capitalizedKey}\\}`, 'g');
358
- result = result.replace(capitalizedPattern, String(value).charAt(0).toUpperCase() + String(value).slice(1));
359
-
360
- // Handle normal version (e.g., ${name})
361
- const normalPattern = new RegExp(`\\$\\{${key}\\}`, 'g');
362
- result = result.replace(normalPattern, String(value));
363
- }
364
-
365
- // Handle conditional expressions in template (e.g., ${required ? "" : "?"})
366
- // This is a simple evaluator for common patterns
367
- result = result.replace(/\$\{(\w+)\s*\?\s*"([^"]*)"\s*:\s*"([^"]*)"\}/g, (match, varName, trueVal, falseVal) => {
368
- const varValue = variables[varName];
369
- return varValue ? trueVal : falseVal;
370
- });
371
-
372
- return result;
373
- }
374
-
375
- /**
376
- * Gets a syntax pattern for a specific framework with variable replacement
377
- *
378
- * @param pattern - The syntax pattern key to use
379
- * @param framework - Target framework
380
- * @param variables - Variables to replace in template
381
- * @returns Generated code string for the framework
382
- */
383
- export function getSyntaxPattern(
384
- pattern: SyntaxPatternKey,
385
- framework: FrameworkTarget,
386
- variables: Record<string, any>
387
- ): string {
388
- const syntaxPattern = SYNTAX_PATTERNS[pattern];
389
-
390
- if (!syntaxPattern) {
391
- throw new Error(`Unknown syntax pattern: ${pattern}`);
392
- }
393
-
394
- const template = syntaxPattern[framework];
395
-
396
- if (!template) {
397
- throw new Error(`Framework ${framework} not supported for pattern ${pattern}`);
398
- }
399
-
400
- return replaceTemplateVariables(template, variables);
401
- }
402
-
403
- /**
404
- * Gets all framework implementations of a pattern
405
- *
406
- * Useful for documentation or comparison
407
- *
408
- * @param pattern - The syntax pattern key
409
- * @param variables - Variables to replace in templates
410
- * @returns Object mapping frameworks to generated code
411
- */
412
- export function getAllFrameworkSyntax(
413
- pattern: SyntaxPatternKey,
414
- variables: Record<string, any>
415
- ): Record<FrameworkTarget, string> {
416
- const frameworks: FrameworkTarget[] = ['react', 'vue', 'svelte', 'angular', 'runtime'];
417
- const result: Partial<Record<FrameworkTarget, string>> = {};
418
-
419
- for (const framework of frameworks) {
420
- result[framework] = getSyntaxPattern(pattern, framework, variables);
421
- }
422
-
423
- return result as Record<FrameworkTarget, string>;
424
- }
425
-
426
- /**
427
- * Checks if a pattern is available for a framework
428
- *
429
- * @param pattern - The syntax pattern key
430
- * @param framework - Target framework
431
- * @returns True if pattern exists for framework
432
- */
433
- export function hasPattern(
434
- pattern: SyntaxPatternKey,
435
- framework: FrameworkTarget
436
- ): boolean {
437
- const syntaxPattern = SYNTAX_PATTERNS[pattern];
438
- return Boolean(syntaxPattern && syntaxPattern[framework] !== undefined);
439
- }
440
-
441
- /**
442
- * Gets all available pattern keys
443
- *
444
- * @returns Array of all syntax pattern keys
445
- */
446
- export function getAllPatternKeys(): SyntaxPatternKey[] {
447
- return Object.keys(SYNTAX_PATTERNS) as SyntaxPatternKey[];
448
- }
449
-
450
- /**
451
- * Gets pattern keys by category
452
- *
453
- * @param category - Pattern category
454
- * @returns Array of pattern keys in that category
455
- */
456
- export function getPatternsByCategory(
457
- category: 'state' | 'render' | 'event' | 'lifecycle' | 'prop' | 'import'
458
- ): SyntaxPatternKey[] {
459
- const categoryMap: Record<string, SyntaxPatternKey[]> = {
460
- state: ['stateDeclaration', 'stateUpdate', 'stateGetter'],
461
- render: ['loopRender', 'conditionalRender', 'componentRender'],
462
- event: ['eventHandler', 'eventBinding'],
463
- lifecycle: ['onMount', 'onUnmount', 'onUpdate'],
464
- prop: ['propDeclaration', 'propAccess', 'propBinding'],
465
- import: ['componentImport', 'hookImport', 'libraryImport']
466
- };
467
-
468
- return categoryMap[category] || [];
469
- }
470
-
471
- // ============================================================================
472
- // Framework-Specific Helpers
473
- // ============================================================================
474
-
475
- /**
476
- * Generate state management code for a framework
477
- * Convenience function that combines declaration and update patterns
478
- *
479
- * @param framework - Target framework
480
- * @param stateName - Name of state variable
481
- * @param stateType - TypeScript type
482
- * @param initialValue - Initial value
483
- * @returns Object with declaration and updater syntax
484
- */
485
- export function generateStateCode(
486
- framework: FrameworkTarget,
487
- stateName: string,
488
- stateType: string,
489
- initialValue: string
490
- ): { declaration: string; update: (value: string) => string; get: string } {
491
- const declaration = getSyntaxPattern('stateDeclaration', framework, {
492
- name: stateName,
493
- Name: stateName.charAt(0).toUpperCase() + stateName.slice(1),
494
- type: stateType,
495
- initial: initialValue
496
- });
497
-
498
- const update = (value: string) => getSyntaxPattern('stateUpdate', framework, {
499
- name: stateName,
500
- Name: stateName.charAt(0).toUpperCase() + stateName.slice(1),
501
- value
502
- });
503
-
504
- const get = getSyntaxPattern('stateGetter', framework, { name: stateName });
505
-
506
- return { declaration, update, get };
507
- }
508
-
509
- /**
510
- * Generate event handler code for a framework
511
- *
512
- * @param framework - Target framework
513
- * @param eventName - Name of event (e.g., 'click', 'submit')
514
- * @param handlerName - Name of handler function
515
- * @param params - Handler parameters
516
- * @param body - Handler body code
517
- * @returns Object with handler function and binding syntax
518
- */
519
- export function generateEventCode(
520
- framework: FrameworkTarget,
521
- eventName: string,
522
- handlerName: string,
523
- params: string,
524
- body: string
525
- ): { handler: string; binding: string } {
526
- const handler = getSyntaxPattern('eventHandler', framework, {
527
- name: handlerName,
528
- Name: handlerName.charAt(0).toUpperCase() + handlerName.slice(1),
529
- params,
530
- body
531
- });
532
-
533
- const binding = getSyntaxPattern('eventBinding', framework, {
534
- event: eventName,
535
- handler: `handle${handlerName.charAt(0).toUpperCase() + handlerName.slice(1)}`
536
- });
537
-
538
- return { handler, binding };
539
- }