@mmapp/react-compiler 0.1.0-alpha.1 → 0.1.0-alpha.5

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 (265) hide show
  1. package/ATOM-PIPELINE.md +144 -0
  2. package/README.md +88 -40
  3. package/dist/babel/index.js +2814 -277
  4. package/dist/babel/index.mjs +2 -2
  5. package/dist/chunk-3USIFFE4.mjs +2190 -0
  6. package/dist/chunk-45YMGEVT.mjs +186 -0
  7. package/dist/chunk-4FN2AISW.mjs +148 -0
  8. package/dist/chunk-4OPI5L7G.mjs +2593 -0
  9. package/dist/chunk-4RYTKOOJ.mjs +186 -0
  10. package/dist/chunk-52XHYD2V.mjs +214 -0
  11. package/dist/chunk-5GUFFFGL.mjs +148 -0
  12. package/dist/chunk-5RKTOVR5.mjs +244 -0
  13. package/dist/chunk-5YDMOO4X.mjs +214 -0
  14. package/dist/chunk-64ZWEMLJ.mjs +148 -0
  15. package/dist/chunk-6XP4KSWQ.mjs +2190 -0
  16. package/dist/chunk-72QWL54I.mjs +175 -0
  17. package/dist/chunk-7B4TRI7C.mjs +4835 -0
  18. package/dist/chunk-7ZKGHTNB.mjs +4952 -0
  19. package/dist/chunk-CIESM3BP.mjs +33 -0
  20. package/dist/chunk-DE3ZGQAC.mjs +148 -0
  21. package/dist/chunk-DMCY3BBG.mjs +1933 -0
  22. package/dist/chunk-DPIK3PJS.mjs +244 -0
  23. package/dist/chunk-E5IVH4RE.mjs +186 -0
  24. package/dist/chunk-E6FZNUR5.mjs +4953 -0
  25. package/dist/chunk-EJRBDQDP.mjs +2607 -0
  26. package/dist/chunk-ELO4TXJL.mjs +186 -0
  27. package/dist/chunk-EO6SYNCG.mjs +175 -0
  28. package/dist/chunk-FKRO52XH.mjs +3446 -0
  29. package/dist/chunk-FL4YAKU6.mjs +4941 -0
  30. package/dist/chunk-FYT47UBU.mjs +5076 -0
  31. package/dist/chunk-GCLGPOJZ.mjs +148 -0
  32. package/dist/chunk-GXB4JOP7.mjs +5072 -0
  33. package/dist/chunk-HFXOUMTD.mjs +175 -0
  34. package/dist/chunk-HWIZ47US.mjs +214 -0
  35. package/dist/chunk-IB7MNPQL.mjs +4953 -0
  36. package/dist/chunk-ICSIHQCG.mjs +148 -0
  37. package/dist/chunk-J7JUAHS4.mjs +186 -0
  38. package/dist/chunk-JLA5VNQ3.mjs +186 -0
  39. package/dist/chunk-JQLWFCTM.mjs +214 -0
  40. package/dist/chunk-KFJJCQAL.mjs +148 -0
  41. package/dist/chunk-KJUIIEQE.mjs +186 -0
  42. package/dist/chunk-KNWTHRVQ.mjs +175 -0
  43. package/dist/chunk-KSG4XSZF.mjs +175 -0
  44. package/dist/chunk-LF5N6DOU.mjs +175 -0
  45. package/dist/chunk-LJQCM2IM.mjs +214 -0
  46. package/dist/chunk-NTB7OEX2.mjs +2918 -0
  47. package/dist/chunk-NW6555WJ.mjs +186 -0
  48. package/dist/chunk-OMZE6VLQ.mjs +214 -0
  49. package/dist/chunk-OPJKP747.mjs +7506 -0
  50. package/dist/chunk-P4BR7WVO.mjs +2190 -0
  51. package/dist/chunk-QQHVYH2X.mjs +244 -0
  52. package/dist/chunk-S5QLWLLT.mjs +186 -0
  53. package/dist/chunk-SCWGT2FY.mjs +2190 -0
  54. package/dist/chunk-SMKJUSB3.mjs +2190 -0
  55. package/dist/chunk-THFYE5ZX.mjs +244 -0
  56. package/dist/chunk-VCAY2KGM.mjs +175 -0
  57. package/dist/chunk-WBYMW4NQ.mjs +3450 -0
  58. package/dist/chunk-WECAV6QB.mjs +148 -0
  59. package/dist/chunk-WMKBXUCE.mjs +3228 -0
  60. package/dist/chunk-XAJ5BKKL.mjs +4947 -0
  61. package/dist/chunk-XG2X7AEA.mjs +175 -0
  62. package/dist/chunk-XG7Z23NQ.mjs +148 -0
  63. package/dist/chunk-XWZAOCQ7.mjs +2607 -0
  64. package/dist/chunk-Y6MA7ULW.mjs +148 -0
  65. package/dist/chunk-YMS7Q7LG.mjs +214 -0
  66. package/dist/chunk-ZA37XTGA.mjs +175 -0
  67. package/dist/cli/index.js +13189 -6838
  68. package/dist/cli/index.mjs +140 -22
  69. package/dist/codemod/cli.mjs +1 -1
  70. package/dist/codemod/index.mjs +1 -1
  71. package/dist/config-PL24KEWL.mjs +219 -0
  72. package/dist/dev-server-RmGHIntF.d.mts +113 -0
  73. package/dist/dev-server-RmGHIntF.d.ts +113 -0
  74. package/dist/dev-server.d.mts +1 -1
  75. package/dist/dev-server.d.ts +1 -1
  76. package/dist/dev-server.js +4135 -440
  77. package/dist/dev-server.mjs +5 -5
  78. package/dist/envelope.js +2812 -275
  79. package/dist/envelope.mjs +3 -3
  80. package/dist/index.d.mts +161 -2
  81. package/dist/index.d.ts +161 -2
  82. package/dist/index.js +4429 -428
  83. package/dist/index.mjs +217 -9
  84. package/{src/cli/init.ts → dist/init-7JQMAAXS.mjs} +70 -95
  85. package/dist/init-DQDX3QK6.mjs +369 -0
  86. package/dist/init-EHO4VQ22.mjs +369 -0
  87. package/dist/init-UC3FWPIW.mjs +367 -0
  88. package/dist/init-UNSMVKIK.mjs +366 -0
  89. package/dist/init-UNV5XIDE.mjs +367 -0
  90. package/dist/project-compiler-2P4N4DR7.mjs +10 -0
  91. package/dist/project-compiler-D2LCC27O.mjs +10 -0
  92. package/dist/project-compiler-EJ3GANJE.mjs +10 -0
  93. package/dist/project-compiler-LOQKVRZJ.mjs +10 -0
  94. package/dist/project-compiler-OP2VVGJQ.mjs +10 -0
  95. package/dist/project-compiler-RQ6OQKRM.mjs +10 -0
  96. package/dist/project-compiler-VWNNCHGO.mjs +10 -0
  97. package/dist/project-compiler-XVAAU4C5.mjs +10 -0
  98. package/dist/project-compiler-YES5FGMD.mjs +10 -0
  99. package/dist/project-compiler-ZKMQDLGU.mjs +10 -0
  100. package/dist/project-decompiler-FLXCEJHS.mjs +7 -0
  101. package/dist/project-decompiler-US7GAVIC.mjs +7 -0
  102. package/dist/project-decompiler-VLPR22QF.mjs +7 -0
  103. package/dist/pull-FUS5QYZS.mjs +109 -0
  104. package/dist/pull-LD5ENLGY.mjs +109 -0
  105. package/dist/pull-P44LDRWB.mjs +109 -0
  106. package/dist/testing/index.js +2822 -285
  107. package/dist/testing/index.mjs +2 -2
  108. package/dist/verify-SEIXUGN4.mjs +1833 -0
  109. package/dist/vite/index.js +2815 -278
  110. package/dist/vite/index.mjs +3 -3
  111. package/examples/uber-app/app/admin/fleet.tsx +19 -19
  112. package/package.json +16 -6
  113. package/compile-blueprint-chat.mjs +0 -99
  114. package/compile-blueprint-glass-console.mjs +0 -98
  115. package/compile-chat-defs.mjs +0 -92
  116. package/examples/uber-app/tests/payment.test.tsx +0 -129
  117. package/examples/uber-app/tests/ride-flow.test.tsx +0 -123
  118. package/package.json.backup +0 -86
  119. package/scripts/decompile.ts +0 -226
  120. package/scripts/seed-auth.ts +0 -267
  121. package/scripts/seed-uber.ts +0 -248
  122. package/scripts/validate-uber.ts +0 -119
  123. package/seed-blueprint-chat.mjs +0 -444
  124. package/seed-blueprint-glass-console.mjs +0 -445
  125. package/seed-compiled.mjs +0 -318
  126. package/src/RoundTripValidator.ts +0 -400
  127. package/src/__tests__/atom-rendering-coverage.test.ts +0 -680
  128. package/src/__tests__/auth-module-compilation.test.ts +0 -247
  129. package/src/__tests__/auth-template-compilation.test.ts +0 -589
  130. package/src/__tests__/change-extractor.test.ts +0 -142
  131. package/src/__tests__/cli-pull.test.ts +0 -73
  132. package/src/__tests__/cli-test.test.ts +0 -72
  133. package/src/__tests__/component-extractor.test.ts +0 -331
  134. package/src/__tests__/context-extractor.test.ts +0 -145
  135. package/src/__tests__/decompiler.test.ts +0 -718
  136. package/src/__tests__/define-blueprint.test.ts +0 -133
  137. package/src/__tests__/definition-validator.test.ts +0 -519
  138. package/src/__tests__/during-extractor.test.ts +0 -152
  139. package/src/__tests__/effect-extractor.test.ts +0 -107
  140. package/src/__tests__/event-emission.test.ts +0 -127
  141. package/src/__tests__/examples.test.ts +0 -236
  142. package/src/__tests__/full-blueprint-coverage.test.ts +0 -1221
  143. package/src/__tests__/golden-suite.test.ts +0 -403
  144. package/src/__tests__/grammar-island-extractor.test.ts +0 -289
  145. package/src/__tests__/instance-key.test.ts +0 -82
  146. package/src/__tests__/ir-migration.test.ts +0 -255
  147. package/src/__tests__/lock-file.test.ts +0 -117
  148. package/src/__tests__/model-extractor.test.ts +0 -195
  149. package/src/__tests__/model-field-acl.test.ts +0 -237
  150. package/src/__tests__/model-hooks.test.ts +0 -130
  151. package/src/__tests__/model-ref-resolution.test.ts +0 -268
  152. package/src/__tests__/model-roundtrip.test.ts +0 -502
  153. package/src/__tests__/model-runtime.test.ts +0 -112
  154. package/src/__tests__/model-transitions.test.ts +0 -183
  155. package/src/__tests__/nrt-action-trace.test.ts +0 -391
  156. package/src/__tests__/pipeline-hardening.test.ts +0 -413
  157. package/src/__tests__/project-compiler.test.ts +0 -546
  158. package/src/__tests__/project-decompiler.test.ts +0 -343
  159. package/src/__tests__/query-compilation.test.ts +0 -145
  160. package/src/__tests__/round-trip/PLAN.md +0 -158
  161. package/src/__tests__/round-trip/README.md +0 -52
  162. package/src/__tests__/round-trip/RESULTS.md +0 -86
  163. package/src/__tests__/round-trip/fixtures/data-heavy/main.workflow.tsx +0 -55
  164. package/src/__tests__/round-trip/fixtures/data-heavy/mm.config.ts +0 -11
  165. package/src/__tests__/round-trip/fixtures/data-heavy/models/contact.ts +0 -54
  166. package/src/__tests__/round-trip/fixtures/full-workflow/main.workflow.tsx +0 -79
  167. package/src/__tests__/round-trip/fixtures/full-workflow/mm.config.ts +0 -12
  168. package/src/__tests__/round-trip/fixtures/full-workflow/models/order.ts +0 -50
  169. package/src/__tests__/round-trip/fixtures/simple-crud/main.workflow.tsx +0 -25
  170. package/src/__tests__/round-trip/fixtures/simple-crud/mm.config.ts +0 -11
  171. package/src/__tests__/round-trip/fixtures/simple-crud/models/task.ts +0 -32
  172. package/src/__tests__/round-trip/fixtures/view-heavy/main.workflow.tsx +0 -79
  173. package/src/__tests__/round-trip/fixtures/view-heavy/mm.config.ts +0 -10
  174. package/src/__tests__/round-trip/round-trip.test.ts +0 -2598
  175. package/src/__tests__/round-trip-ir.test.ts +0 -300
  176. package/src/__tests__/round-trip.test.ts +0 -1212
  177. package/src/__tests__/route-merging.test.ts +0 -372
  178. package/src/__tests__/router-composition.test.ts +0 -489
  179. package/src/__tests__/router-extractor.test.ts +0 -176
  180. package/src/__tests__/server-action-extractor.test.ts +0 -128
  181. package/src/__tests__/smart-type-inference.test.ts +0 -365
  182. package/src/__tests__/source-envelope.test.ts +0 -284
  183. package/src/__tests__/source-fidelity.test.ts +0 -516
  184. package/src/__tests__/state-extractor.test.ts +0 -115
  185. package/src/__tests__/strict-mode.test.ts +0 -227
  186. package/src/__tests__/transition-effect-extractor.test.ts +0 -119
  187. package/src/__tests__/transition-extractor.test.ts +0 -68
  188. package/src/__tests__/ts-to-expression.test.ts +0 -462
  189. package/src/__tests__/type-generator.test.ts +0 -201
  190. package/src/__tests__/uber-validation.test.ts +0 -502
  191. package/src/action-compiler.ts +0 -361
  192. package/src/babel/emitters/experience-transform.ts +0 -199
  193. package/src/babel/emitters/ir-to-tsx-emitter.ts +0 -110
  194. package/src/babel/emitters/pure-form-emitter.ts +0 -1023
  195. package/src/babel/emitters/runtime-glue-emitter.ts +0 -39
  196. package/src/babel/extractors/change-extractor.ts +0 -199
  197. package/src/babel/extractors/component-extractor.ts +0 -907
  198. package/src/babel/extractors/computed-extractor.ts +0 -262
  199. package/src/babel/extractors/context-extractor.ts +0 -277
  200. package/src/babel/extractors/during-extractor.ts +0 -295
  201. package/src/babel/extractors/effect-extractor.ts +0 -340
  202. package/src/babel/extractors/event-extractor.ts +0 -235
  203. package/src/babel/extractors/grammar-island-extractor.ts +0 -302
  204. package/src/babel/extractors/model-extractor.ts +0 -1018
  205. package/src/babel/extractors/router-extractor.ts +0 -303
  206. package/src/babel/extractors/server-action-extractor.ts +0 -173
  207. package/src/babel/extractors/server-action-hook-extractor.ts +0 -72
  208. package/src/babel/extractors/server-state-extractor.ts +0 -88
  209. package/src/babel/extractors/state-extractor.ts +0 -214
  210. package/src/babel/extractors/transition-effect-extractor.ts +0 -176
  211. package/src/babel/extractors/transition-extractor.ts +0 -143
  212. package/src/babel/index.ts +0 -24
  213. package/src/babel/transpilers/ts-to-expression.ts +0 -674
  214. package/src/babel/visitor.ts +0 -807
  215. package/src/cli/auth.ts +0 -255
  216. package/src/cli/build.ts +0 -288
  217. package/src/cli/deploy.ts +0 -206
  218. package/src/cli/index.ts +0 -328
  219. package/src/cli/installer.ts +0 -261
  220. package/src/cli/lock-file.ts +0 -94
  221. package/src/cli/mmrc.ts +0 -22
  222. package/src/cli/pull.ts +0 -172
  223. package/src/cli/registry-client.ts +0 -175
  224. package/src/cli/test.ts +0 -397
  225. package/src/cli/type-generator.ts +0 -243
  226. package/src/codemod/__tests__/forward.test.ts +0 -239
  227. package/src/codemod/__tests__/reverse.test.ts +0 -145
  228. package/src/codemod/__tests__/round-trip.test.ts +0 -137
  229. package/src/codemod/annotation.ts +0 -97
  230. package/src/codemod/classify.ts +0 -197
  231. package/src/codemod/cli.ts +0 -207
  232. package/src/codemod/control-flow.ts +0 -409
  233. package/src/codemod/forward.ts +0 -244
  234. package/src/codemod/import-manager.ts +0 -171
  235. package/src/codemod/index.ts +0 -120
  236. package/src/codemod/reverse.ts +0 -197
  237. package/src/codemod/rules.ts +0 -174
  238. package/src/codemod/state-transform.ts +0 -126
  239. package/src/decompiler/ast-builder.ts +0 -538
  240. package/src/decompiler/config-generator.ts +0 -151
  241. package/src/decompiler/index.ts +0 -315
  242. package/src/decompiler/project-decompiler.ts +0 -1776
  243. package/src/decompiler/project.ts +0 -862
  244. package/src/decompiler/split-strategy.ts +0 -140
  245. package/src/decompiler/state-emitter.ts +0 -1053
  246. package/src/decompiler/sx-emitter.ts +0 -318
  247. package/src/decompiler/workspace-hydrator.ts +0 -189
  248. package/src/dev-server.ts +0 -238
  249. package/src/envelope/fs-tree.ts +0 -217
  250. package/src/envelope/source-envelope.ts +0 -264
  251. package/src/envelope.ts +0 -315
  252. package/src/incremental-compiler.ts +0 -401
  253. package/src/index.ts +0 -99
  254. package/src/model-compiler.ts +0 -277
  255. package/src/project-compiler.ts +0 -1629
  256. package/src/route-extractor.ts +0 -333
  257. package/src/testing/index.ts +0 -32
  258. package/src/testing/snapshot.ts +0 -252
  259. package/src/testing/test-utils.ts +0 -226
  260. package/src/types.ts +0 -68
  261. package/src/vite/index.ts +0 -288
  262. package/test-compile.mjs +0 -142
  263. package/tsconfig.json +0 -25
  264. package/tsup.config.ts +0 -23
  265. package/vitest.config.ts +0 -9
@@ -1,226 +0,0 @@
1
- /**
2
- * Test Utilities — mock providers and compile helpers for .workflow.tsx unit tests.
3
- *
4
- * These wrappers let test authors compile workflow source, inspect IR output,
5
- * and wrap components in mock providers — without touching the Babel API directly.
6
- *
7
- * Usage:
8
- * import { compileWorkflow, compileModel, MockBlueprintProvider, MockWorkflowProvider } from '@mindmatrix/react-compiler/testing';
9
- *
10
- * const ir = compileWorkflow(`
11
- * import { useState } from 'react';
12
- * export function Counter() { ... }
13
- * `);
14
- * expect(ir.fields).toHaveLength(1);
15
- */
16
-
17
- import { transformSync } from '@babel/core';
18
- import babelPlugin from '../babel';
19
- import type { IRWorkflowDefinition } from '@mindmatrix/player-core';
20
-
21
- // =============================================================================
22
- // Compilation Helpers
23
- // =============================================================================
24
-
25
- export interface CompileOptions {
26
- /** Compilation mode. Default: 'infer' */
27
- mode?: 'strict' | 'infer';
28
- /** Override filename (affects file-type detection). */
29
- filename?: string;
30
- }
31
-
32
- /**
33
- * Compile a .workflow.tsx source string to IR.
34
- * Returns the full IRWorkflowDefinition extracted by the Babel plugin.
35
- */
36
- export function compileWorkflow(
37
- code: string,
38
- options: CompileOptions = {},
39
- ): IRWorkflowDefinition {
40
- const filename = options.filename ?? 'test.workflow.tsx';
41
- const mode = options.mode ?? 'infer';
42
-
43
- const result = transformSync(code, {
44
- filename,
45
- plugins: [[babelPlugin, { mode }]],
46
- parserOpts: { plugins: ['typescript', 'jsx'], attachComment: true },
47
- });
48
-
49
- const ir = (result as any)?.metadata?.mindmatrixIR;
50
- if (!ir) {
51
- throw new Error(
52
- `compileWorkflow: no IR produced. Check that the source exports a component or model.\n` +
53
- `Source preview: ${code.trim().slice(0, 120)}...`,
54
- );
55
- }
56
- return ir;
57
- }
58
-
59
- /**
60
- * Compile a model file (models/*.ts) to IR.
61
- * Model files use interface-based extraction (no JSX).
62
- */
63
- export function compileModel(
64
- code: string,
65
- options: CompileOptions = {},
66
- ): IRWorkflowDefinition {
67
- const filename = options.filename ?? 'models/test.ts';
68
- const mode = options.mode ?? 'infer';
69
-
70
- const result = transformSync(code, {
71
- filename,
72
- plugins: [[babelPlugin, { mode }]],
73
- parserOpts: { plugins: ['typescript'], attachComment: true },
74
- });
75
-
76
- const ir = (result as any)?.metadata?.mindmatrixIR;
77
- if (!ir) {
78
- throw new Error(
79
- `compileModel: no IR produced. Check that the source exports an interface and transitions.\n` +
80
- `Source preview: ${code.trim().slice(0, 120)}...`,
81
- );
82
- }
83
- return ir;
84
- }
85
-
86
- /**
87
- * Compile a server action file (*.server.ts) to IR.
88
- */
89
- export function compileServerAction(
90
- code: string,
91
- options: CompileOptions = {},
92
- ): IRWorkflowDefinition {
93
- const filename = options.filename ?? 'actions.server.ts';
94
- return compileWorkflow(code, { ...options, filename });
95
- }
96
-
97
- /**
98
- * Extract raw Babel metadata from compilation (IR + warnings + errors).
99
- */
100
- export function compileRaw(code: string, options: CompileOptions = {}): {
101
- ir: IRWorkflowDefinition | undefined;
102
- code: string | null;
103
- warnings: Array<{ message: string; code?: string }>;
104
- errors: Array<{ message: string; code?: string }>;
105
- } {
106
- const filename = options.filename ?? 'test.workflow.tsx';
107
- const mode = options.mode ?? 'infer';
108
-
109
- const result = transformSync(code, {
110
- filename,
111
- plugins: [[babelPlugin, { mode }]],
112
- parserOpts: { plugins: ['typescript', 'jsx'], attachComment: true },
113
- });
114
-
115
- const metadata = (result as any)?.metadata ?? {};
116
- return {
117
- ir: metadata.mindmatrixIR,
118
- code: result?.code ?? null,
119
- warnings: metadata.mindmatrixWarnings ?? [],
120
- errors: metadata.mindmatrixErrors ?? [],
121
- };
122
- }
123
-
124
- // =============================================================================
125
- // Mock Providers — lightweight wrappers for rendering .workflow.tsx in tests
126
- // =============================================================================
127
-
128
- /**
129
- * Mock blueprint context for testing workflow components.
130
- *
131
- * Provides the minimal context shape that @mindmatrix/react hooks expect.
132
- * Does NOT render React — this is a data-only mock for unit testing IR output.
133
- */
134
- export interface MockBlueprintProviderProps {
135
- /** Blueprint slug. Default: 'test-blueprint' */
136
- slug?: string;
137
- /** Blueprint version. Default: '1.0.0' */
138
- version?: string;
139
- /** Initial state data for the workflow instance. */
140
- initialState?: Record<string, unknown>;
141
- /** Mock definitions available in context. */
142
- definitions?: IRWorkflowDefinition[];
143
- }
144
-
145
- /**
146
- * Creates a mock blueprint context value.
147
- *
148
- * Use this to provide context when testing hooks or components that
149
- * read from BlueprintContext.
150
- */
151
- export function createMockBlueprintContext(props: MockBlueprintProviderProps = {}) {
152
- const {
153
- slug = 'test-blueprint',
154
- version = '1.0.0',
155
- initialState = {},
156
- definitions = [],
157
- } = props;
158
-
159
- return {
160
- slug,
161
- version,
162
- definitions,
163
- activeDefinition: definitions[0] ?? null,
164
- instanceState: initialState,
165
- dispatch: () => {},
166
- navigate: () => {},
167
- };
168
- }
169
-
170
- /**
171
- * Mock workflow provider props for testing individual workflow components.
172
- */
173
- export interface MockWorkflowProviderProps {
174
- /** Workflow slug. Default: 'test-workflow' */
175
- slug?: string;
176
- /** Current state name. Default: 'draft' */
177
- currentState?: string;
178
- /** Field values. */
179
- fields?: Record<string, unknown>;
180
- /** Available transitions from current state. */
181
- transitions?: string[];
182
- /** Mock transition handler. */
183
- onTransition?: (name: string, data?: Record<string, unknown>) => void;
184
- }
185
-
186
- /**
187
- * Creates a mock workflow context value.
188
- *
189
- * Provides the shape expected by useWorkflow(), useTransition(), etc.
190
- */
191
- export function createMockWorkflowContext(props: MockWorkflowProviderProps = {}) {
192
- const {
193
- slug = 'test-workflow',
194
- currentState = 'draft',
195
- fields = {},
196
- transitions = [],
197
- onTransition = () => {},
198
- } = props;
199
-
200
- return {
201
- slug,
202
- currentState,
203
- fields,
204
- availableTransitions: transitions,
205
- transition: onTransition,
206
- setField: (name: string, value: unknown) => {
207
- (fields as Record<string, unknown>)[name] = value;
208
- },
209
- getField: (name: string) => (fields as Record<string, unknown>)[name],
210
- };
211
- }
212
-
213
- /**
214
- * Convenience: compile + extract specific parts of the IR.
215
- */
216
- export function extractFields(code: string, options?: CompileOptions) {
217
- return compileWorkflow(code, options).fields;
218
- }
219
-
220
- export function extractStates(code: string, options?: CompileOptions) {
221
- return compileWorkflow(code, options).states;
222
- }
223
-
224
- export function extractTransitions(code: string, options?: CompileOptions) {
225
- return compileWorkflow(code, options).transitions;
226
- }
package/src/types.ts DELETED
@@ -1,68 +0,0 @@
1
- /**
2
- * Internal types for the compiler state and extracted data.
3
- */
4
-
5
- import type {
6
- IRFieldDefinition,
7
- IRStateDefinition,
8
- IRTransitionDefinition,
9
- IROnEventSubscription,
10
- IRExperienceNode,
11
- IRGrammarIsland,
12
- CompilerErrorCode,
13
- } from '@mindmatrix/player-core';
14
-
15
- import type { FieldWatcher } from './babel/extractors/change-extractor';
16
- import type { TransitionEffect } from './babel/extractors/transition-effect-extractor';
17
-
18
- export interface ExtractedWorkflow {
19
- slug: string;
20
- name: string;
21
- version: string;
22
- description?: string;
23
- category: string;
24
- fields: IRFieldDefinition[];
25
- states: Map<string, IRStateDefinition>;
26
- transitions: IRTransitionDefinition[];
27
- events: IROnEventSubscription[];
28
- experience?: IRExperienceNode;
29
- fieldWatchers?: FieldWatcher[];
30
- transitionEffects?: TransitionEffect[];
31
- grammarIslands?: IRGrammarIsland[];
32
- errors?: ReactCompilerError[];
33
- warnings?: ReactCompilerError[];
34
- /** Extra metadata from model files (runtime, fieldOptions, etc.) */
35
- extraMetadata?: Record<string, unknown>;
36
- }
37
-
38
- export interface CompilerState {
39
- fields: IRFieldDefinition[];
40
- states: Map<string, IRStateDefinition>;
41
- transitions: IRTransitionDefinition[];
42
- events: IROnEventSubscription[];
43
- experience?: IRExperienceNode;
44
- actionCounter: number;
45
- metadata: {
46
- slug?: string;
47
- name?: string;
48
- version?: string;
49
- description?: string;
50
- category?: string;
51
- [key: string]: unknown;
52
- };
53
- errors?: ReactCompilerError[];
54
- warnings?: ReactCompilerError[];
55
- }
56
-
57
- export interface CompilerOptions {
58
- mode?: 'strict' | 'infer';
59
- filename?: string;
60
- }
61
-
62
- export interface ReactCompilerError {
63
- code: CompilerErrorCode;
64
- message: string;
65
- line?: number;
66
- column?: number;
67
- severity: 'error' | 'warning';
68
- }
package/src/vite/index.ts DELETED
@@ -1,288 +0,0 @@
1
- /**
2
- * Vite Plugin — integrates the MindMatrix Babel compiler into the Vite build pipeline.
3
- *
4
- * Transforms `.workflow.tsx` files through the Babel plugin to extract workflow
5
- * IR (fields, states, transitions, experience tree) and emit:
6
- * 1. Transformed React code (standard JSX, runs in browser)
7
- * 2. `.workflow.json` sidecar files (IR for mm-engine consumption)
8
- *
9
- * Supports HMR: re-compiles on save, optionally seeds definitions to the dev API.
10
- *
11
- * Usage:
12
- * // vite.config.ts
13
- * import { mindmatrixReact } from '@mindmatrix/react-compiler/vite';
14
- *
15
- * export default defineConfig({
16
- * plugins: [
17
- * mindmatrixReact({
18
- * mode: 'infer',
19
- * include: ['**\/*.workflow.tsx'],
20
- * seedOnCompile: true,
21
- * apiUrl: 'http://localhost:4200/api/v1',
22
- * })
23
- * ]
24
- * });
25
- */
26
-
27
- import type { Plugin } from 'vite';
28
- import { transformSync } from '@babel/core';
29
- import { writeFileSync, mkdirSync } from 'fs';
30
- import { dirname, join, relative, basename } from 'path';
31
- import babelPlugin from '../babel';
32
-
33
- export interface MindMatrixReactOptions {
34
- /** Compilation mode: 'strict' validates imports, 'infer' is permissive. Default: 'infer' */
35
- mode?: 'strict' | 'infer';
36
- /** Glob patterns for files to compile. Default: ['**\/*.workflow.tsx'] */
37
- include?: string[];
38
- /** Output directory for .workflow.json sidecar files. Default: 'dist/workflows' */
39
- outDir?: string;
40
- /** When true, POST compiled definitions to the dev API on each compile. Default: false */
41
- seedOnCompile?: boolean;
42
- /** Dev API base URL for seeding. Default: 'http://localhost:4200/api/v1' */
43
- apiUrl?: string;
44
- /** Auth token for dev API seeding. Default: reads from MINDMATRIX_TOKEN env var */
45
- authToken?: string;
46
- /**
47
- * Source map configuration for .workflow.tsx files.
48
- * - true: Generate source maps with original source embedded (default in dev)
49
- * - false: No source maps
50
- * - 'inline': Inline source maps in compiled output
51
- * Default: auto-detected from Vite mode (true in dev, false in build)
52
- */
53
- sourceMaps?: boolean | 'inline';
54
- /**
55
- * Embed __source metadata on IR nodes (file, line, column).
56
- * Enables: compilation error mapping, IR inspector, runtime error traces.
57
- * Default: true in dev, false in production.
58
- */
59
- sourceAnnotations?: boolean;
60
- }
61
-
62
- /** Compiled IR result attached to Babel metadata */
63
- interface CompiledIR {
64
- slug: string;
65
- name: string;
66
- version: string;
67
- category: string;
68
- fields: unknown[];
69
- states: unknown[];
70
- transitions: unknown[];
71
- experience?: unknown;
72
- metadata?: Record<string, unknown>;
73
- }
74
-
75
- export function mindmatrixReact(options?: MindMatrixReactOptions): Plugin {
76
- const include = options?.include ?? ['**/*.workflow.tsx'];
77
- const mode = options?.mode ?? 'infer';
78
- const outDir = options?.outDir ?? 'dist/workflows';
79
- const seedOnCompile = options?.seedOnCompile ?? false;
80
- const apiUrl = options?.apiUrl ?? 'http://localhost:4200/api/v1';
81
- const authToken = options?.authToken ?? process.env.MINDMATRIX_TOKEN;
82
-
83
- // Source map and annotation config — resolved in configResolved
84
- let enableSourceMaps = options?.sourceMaps;
85
- let enableSourceAnnotations = options?.sourceAnnotations;
86
- let isDev = true;
87
-
88
- // Track compiled files for HMR
89
- const compiledFiles = new Map<string, CompiledIR>();
90
-
91
- /** Check if a file path matches any of the include patterns */
92
- function shouldTransform(id: string): boolean {
93
- return include.some((pattern) => {
94
- // Convert glob-like pattern to regex
95
- const regex = pattern
96
- .replace(/[.+^${}()|[\]\\]/g, '\\$&') // escape regex chars except * and ?
97
- .replace(/\*\*/g, '<<GLOBSTAR>>')
98
- .replace(/\*/g, '[^/]*')
99
- .replace(/<<GLOBSTAR>>/g, '.*')
100
- .replace(/\?/g, '.');
101
- return new RegExp(regex).test(id);
102
- });
103
- }
104
-
105
- /** Seed a compiled definition to the dev API */
106
- async function seedToApi(ir: CompiledIR, filePath: string): Promise<void> {
107
- if (!seedOnCompile || !authToken) return;
108
-
109
- try {
110
- const body = {
111
- slug: ir.slug,
112
- name: ir.name,
113
- version: ir.version,
114
- category: ir.category || 'workflow',
115
- fields: ir.fields || [],
116
- states: ir.states || [],
117
- transitions: ir.transitions || [],
118
- experience: ir.experience || {},
119
- metadata: {
120
- ...(ir.metadata || {}),
121
- source_file: relative(process.cwd(), filePath),
122
- compiled_at: new Date().toISOString(),
123
- },
124
- };
125
-
126
- const resp = await fetch(`${apiUrl}/workflow/definitions`, {
127
- method: 'POST',
128
- headers: {
129
- 'Content-Type': 'application/json',
130
- 'Authorization': `Bearer ${authToken}`,
131
- },
132
- body: JSON.stringify(body),
133
- });
134
-
135
- if (resp.ok) {
136
- console.log(`[mindmatrix-react] Seeded ${ir.slug} to ${apiUrl}`);
137
- } else if (resp.status === 409) {
138
- // Definition already exists — try PATCH instead
139
- const existing = await fetch(
140
- `${apiUrl}/workflow/definitions?slug=${encodeURIComponent(ir.slug)}&version=${encodeURIComponent(ir.version)}`,
141
- { headers: { 'Authorization': `Bearer ${authToken}` } },
142
- );
143
- if (existing.ok) {
144
- const data = await existing.json() as Record<string, unknown> | Record<string, unknown>[];
145
- const defId = Array.isArray(data) ? (data[0] as Record<string, unknown>)?.id : data?.id;
146
- if (defId) {
147
- await fetch(`${apiUrl}/workflow/definitions/${defId}`, {
148
- method: 'PATCH',
149
- headers: {
150
- 'Content-Type': 'application/json',
151
- 'Authorization': `Bearer ${authToken}`,
152
- },
153
- body: JSON.stringify(body),
154
- });
155
- console.log(`[mindmatrix-react] Updated ${ir.slug} (PATCH)`);
156
- }
157
- }
158
- } else {
159
- const text = await resp.text().catch(() => '');
160
- console.warn(`[mindmatrix-react] Seed failed (${resp.status}): ${text.slice(0, 200)}`);
161
- }
162
- } catch (e) {
163
- console.warn(`[mindmatrix-react] Seed failed:`, e instanceof Error ? e.message : e);
164
- }
165
- }
166
-
167
- return {
168
- name: 'mindmatrix-react',
169
- enforce: 'pre',
170
-
171
- configResolved(config) {
172
- isDev = config.command === 'serve';
173
- // Resolve source map defaults based on dev/build mode
174
- if (enableSourceMaps === undefined) enableSourceMaps = isDev;
175
- if (enableSourceAnnotations === undefined) enableSourceAnnotations = isDev;
176
- },
177
-
178
- transform(code: string, id: string) {
179
- if (!shouldTransform(id)) return null;
180
-
181
- try {
182
- const wantMaps = enableSourceMaps !== false;
183
- const result = transformSync(code, {
184
- filename: id,
185
- plugins: [[babelPlugin, { mode, filename: id, sourceAnnotations: enableSourceAnnotations }]],
186
- parserOpts: { plugins: ['jsx', 'typescript'] },
187
- sourceMaps: wantMaps,
188
- // Embed original source in the source map so debuggers can show .workflow.tsx
189
- ...(wantMaps ? { sourceFileName: basename(id) } : {}),
190
- });
191
-
192
- if (!result?.code) return null;
193
-
194
- // Extract IR from Babel metadata
195
- const metadata = (result as any).metadata || {};
196
- const ir = metadata.mindmatrixIR as CompiledIR | undefined;
197
- const warnings = metadata.mindmatrixWarnings as Array<{ message: string }> | undefined;
198
- const errors = metadata.mindmatrixErrors as Array<{ message: string }> | undefined;
199
-
200
- // Report warnings
201
- if (warnings?.length) {
202
- for (const w of warnings) {
203
- console.warn(`[mindmatrix-react] ${basename(id)}: ${w.message}`);
204
- }
205
- }
206
-
207
- // Report errors (but don't fail the build in infer mode)
208
- if (errors?.length) {
209
- for (const e of errors) {
210
- if (mode === 'strict') {
211
- this.error(`${basename(id)}: ${e.message}`);
212
- } else {
213
- this.warn(`${basename(id)}: ${e.message}`);
214
- }
215
- }
216
- }
217
-
218
- if (ir) {
219
- // Track for HMR
220
- compiledFiles.set(id, ir);
221
-
222
- // Write IR to .workflow.json sidecar file
223
- const outputFileName = basename(id).replace(/\.tsx?$/, '.workflow.json');
224
- const outputPath = join(process.cwd(), outDir, outputFileName);
225
- mkdirSync(dirname(outputPath), { recursive: true });
226
- writeFileSync(outputPath, JSON.stringify(ir, null, 2), 'utf-8');
227
- console.log(`[mindmatrix-react] Compiled ${basename(id)} → ${outputFileName}`);
228
-
229
- // Seed to dev API (async, non-blocking)
230
- seedToApi(ir, id);
231
- }
232
-
233
- // Strip __source annotations from IR in production sidecar files
234
- if (!enableSourceAnnotations && ir) {
235
- stripSourceAnnotations(ir);
236
- }
237
-
238
- return {
239
- code: result.code,
240
- map: wantMaps ? result.map : undefined,
241
- };
242
- } catch (error) {
243
- const msg = error instanceof Error ? error.message : String(error);
244
- if (mode === 'strict') {
245
- this.error(`Failed to compile ${basename(id)}: ${msg}`);
246
- } else {
247
- console.error(`[mindmatrix-react] Error compiling ${basename(id)}:`, msg);
248
- }
249
- return null;
250
- }
251
- },
252
-
253
- handleHotUpdate(ctx) {
254
- if (!shouldTransform(ctx.file)) return;
255
-
256
- // Log HMR event
257
- console.log(`[mindmatrix-react] HMR: ${basename(ctx.file)} changed`);
258
-
259
- // The standard Vite HMR will re-run transform() above
260
- // and re-write the sidecar + re-seed API
261
- return undefined;
262
- },
263
- };
264
- }
265
-
266
- /**
267
- * Strip __source annotations from IR for production builds.
268
- * These are useful for dev debugging but add size to deployed definitions.
269
- */
270
- function stripSourceAnnotations(ir: CompiledIR): void {
271
- const strip = (obj: unknown) => {
272
- if (!obj || typeof obj !== 'object') return;
273
- if (Array.isArray(obj)) {
274
- for (const item of obj) strip(item);
275
- return;
276
- }
277
- const rec = obj as Record<string, unknown>;
278
- delete rec.__source;
279
- for (const val of Object.values(rec)) {
280
- if (val && typeof val === 'object') strip(val);
281
- }
282
- };
283
-
284
- strip(ir.fields);
285
- strip(ir.states);
286
- strip(ir.transitions);
287
- strip(ir.experience);
288
- }