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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (251) hide show
  1. package/ATOM-PIPELINE.md +144 -0
  2. package/README.md +88 -40
  3. package/dist/babel/index.js +113 -6
  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-5RKTOVR5.mjs +244 -0
  11. package/dist/chunk-5YDMOO4X.mjs +214 -0
  12. package/dist/chunk-64ZWEMLJ.mjs +148 -0
  13. package/dist/chunk-6XP4KSWQ.mjs +2190 -0
  14. package/dist/chunk-72QWL54I.mjs +175 -0
  15. package/dist/chunk-7B4TRI7C.mjs +4835 -0
  16. package/dist/chunk-7ZKGHTNB.mjs +4952 -0
  17. package/dist/chunk-CIESM3BP.mjs +33 -0
  18. package/dist/chunk-DE3ZGQAC.mjs +148 -0
  19. package/dist/chunk-DMCY3BBG.mjs +1933 -0
  20. package/dist/chunk-DPIK3PJS.mjs +244 -0
  21. package/dist/chunk-E5IVH4RE.mjs +186 -0
  22. package/dist/chunk-E6FZNUR5.mjs +4953 -0
  23. package/dist/chunk-EJRBDQDP.mjs +2607 -0
  24. package/dist/chunk-ELO4TXJL.mjs +186 -0
  25. package/dist/chunk-FKRO52XH.mjs +3446 -0
  26. package/dist/chunk-FL4YAKU6.mjs +4941 -0
  27. package/dist/chunk-FYT47UBU.mjs +5076 -0
  28. package/dist/chunk-GCLGPOJZ.mjs +148 -0
  29. package/dist/chunk-GXB4JOP7.mjs +5072 -0
  30. package/dist/chunk-HFXOUMTD.mjs +175 -0
  31. package/dist/chunk-HWIZ47US.mjs +214 -0
  32. package/dist/chunk-IB7MNPQL.mjs +4953 -0
  33. package/dist/chunk-ICSIHQCG.mjs +148 -0
  34. package/dist/chunk-JLA5VNQ3.mjs +186 -0
  35. package/dist/chunk-JQLWFCTM.mjs +214 -0
  36. package/dist/chunk-KFJJCQAL.mjs +148 -0
  37. package/dist/chunk-KJUIIEQE.mjs +186 -0
  38. package/dist/chunk-KNWTHRVQ.mjs +175 -0
  39. package/dist/chunk-KSG4XSZF.mjs +175 -0
  40. package/dist/chunk-LF5N6DOU.mjs +175 -0
  41. package/dist/chunk-LJQCM2IM.mjs +214 -0
  42. package/dist/chunk-NW6555WJ.mjs +186 -0
  43. package/dist/chunk-OMZE6VLQ.mjs +214 -0
  44. package/dist/chunk-P4BR7WVO.mjs +2190 -0
  45. package/dist/chunk-QQHVYH2X.mjs +244 -0
  46. package/dist/chunk-S5QLWLLT.mjs +186 -0
  47. package/dist/chunk-SCWGT2FY.mjs +2190 -0
  48. package/dist/chunk-SMKJUSB3.mjs +2190 -0
  49. package/dist/chunk-VCAY2KGM.mjs +175 -0
  50. package/dist/chunk-WECAV6QB.mjs +148 -0
  51. package/dist/chunk-WMKBXUCE.mjs +3228 -0
  52. package/dist/chunk-XAJ5BKKL.mjs +4947 -0
  53. package/dist/chunk-XG2X7AEA.mjs +175 -0
  54. package/dist/chunk-XG7Z23NQ.mjs +148 -0
  55. package/dist/chunk-XWZAOCQ7.mjs +2607 -0
  56. package/dist/chunk-Y6MA7ULW.mjs +148 -0
  57. package/dist/chunk-YMS7Q7LG.mjs +214 -0
  58. package/dist/chunk-ZA37XTGA.mjs +175 -0
  59. package/dist/cli/index.js +1616 -366
  60. package/dist/cli/index.mjs +8 -8
  61. package/dist/codemod/cli.mjs +1 -1
  62. package/dist/codemod/index.mjs +1 -1
  63. package/dist/dev-server-RmGHIntF.d.mts +113 -0
  64. package/dist/dev-server-RmGHIntF.d.ts +113 -0
  65. package/dist/dev-server.d.mts +1 -1
  66. package/dist/dev-server.d.ts +1 -1
  67. package/dist/dev-server.js +982 -53
  68. package/dist/dev-server.mjs +5 -5
  69. package/dist/envelope.js +113 -6
  70. package/dist/envelope.mjs +3 -3
  71. package/dist/index.d.mts +5 -1
  72. package/dist/index.d.ts +5 -1
  73. package/dist/index.js +992 -63
  74. package/dist/index.mjs +8 -8
  75. package/{src/cli/init.ts → dist/init-7JQMAAXS.mjs} +70 -95
  76. package/dist/init-EHO4VQ22.mjs +369 -0
  77. package/dist/init-UC3FWPIW.mjs +367 -0
  78. package/dist/init-UNSMVKIK.mjs +366 -0
  79. package/dist/init-UNV5XIDE.mjs +367 -0
  80. package/dist/project-compiler-2P4N4DR7.mjs +10 -0
  81. package/dist/project-compiler-D2LCC27O.mjs +10 -0
  82. package/dist/project-compiler-EJ3GANJE.mjs +10 -0
  83. package/dist/project-compiler-LOQKVRZJ.mjs +10 -0
  84. package/dist/project-compiler-RQ6OQKRM.mjs +10 -0
  85. package/dist/project-compiler-VWNNCHGO.mjs +10 -0
  86. package/dist/project-compiler-XVAAU4C5.mjs +10 -0
  87. package/dist/project-compiler-YES5FGMD.mjs +10 -0
  88. package/dist/project-compiler-ZKMQDLGU.mjs +10 -0
  89. package/dist/project-decompiler-FLXCEJHS.mjs +7 -0
  90. package/dist/project-decompiler-VLPR22QF.mjs +7 -0
  91. package/dist/pull-FUS5QYZS.mjs +109 -0
  92. package/dist/pull-LD5ENLGY.mjs +109 -0
  93. package/dist/testing/index.js +113 -6
  94. package/dist/testing/index.mjs +2 -2
  95. package/dist/vite/index.js +113 -6
  96. package/dist/vite/index.mjs +3 -3
  97. package/examples/uber-app/app/admin/fleet.tsx +19 -19
  98. package/package.json +4 -3
  99. package/compile-blueprint-chat.mjs +0 -99
  100. package/compile-blueprint-glass-console.mjs +0 -98
  101. package/compile-chat-defs.mjs +0 -92
  102. package/examples/uber-app/tests/payment.test.tsx +0 -129
  103. package/examples/uber-app/tests/ride-flow.test.tsx +0 -123
  104. package/package.json.backup +0 -86
  105. package/scripts/decompile.ts +0 -226
  106. package/scripts/seed-auth.ts +0 -267
  107. package/scripts/seed-uber.ts +0 -248
  108. package/scripts/validate-uber.ts +0 -119
  109. package/seed-blueprint-chat.mjs +0 -444
  110. package/seed-blueprint-glass-console.mjs +0 -445
  111. package/seed-compiled.mjs +0 -318
  112. package/src/RoundTripValidator.ts +0 -400
  113. package/src/__tests__/atom-rendering-coverage.test.ts +0 -680
  114. package/src/__tests__/auth-module-compilation.test.ts +0 -247
  115. package/src/__tests__/auth-template-compilation.test.ts +0 -589
  116. package/src/__tests__/change-extractor.test.ts +0 -142
  117. package/src/__tests__/cli-pull.test.ts +0 -73
  118. package/src/__tests__/cli-test.test.ts +0 -72
  119. package/src/__tests__/component-extractor.test.ts +0 -331
  120. package/src/__tests__/context-extractor.test.ts +0 -145
  121. package/src/__tests__/decompiler.test.ts +0 -718
  122. package/src/__tests__/define-blueprint.test.ts +0 -133
  123. package/src/__tests__/definition-validator.test.ts +0 -519
  124. package/src/__tests__/during-extractor.test.ts +0 -152
  125. package/src/__tests__/effect-extractor.test.ts +0 -107
  126. package/src/__tests__/event-emission.test.ts +0 -127
  127. package/src/__tests__/examples.test.ts +0 -236
  128. package/src/__tests__/full-blueprint-coverage.test.ts +0 -1221
  129. package/src/__tests__/golden-suite.test.ts +0 -403
  130. package/src/__tests__/grammar-island-extractor.test.ts +0 -289
  131. package/src/__tests__/instance-key.test.ts +0 -82
  132. package/src/__tests__/ir-migration.test.ts +0 -255
  133. package/src/__tests__/lock-file.test.ts +0 -117
  134. package/src/__tests__/model-extractor.test.ts +0 -195
  135. package/src/__tests__/model-field-acl.test.ts +0 -237
  136. package/src/__tests__/model-hooks.test.ts +0 -130
  137. package/src/__tests__/model-ref-resolution.test.ts +0 -268
  138. package/src/__tests__/model-roundtrip.test.ts +0 -502
  139. package/src/__tests__/model-runtime.test.ts +0 -112
  140. package/src/__tests__/model-transitions.test.ts +0 -183
  141. package/src/__tests__/nrt-action-trace.test.ts +0 -391
  142. package/src/__tests__/pipeline-hardening.test.ts +0 -413
  143. package/src/__tests__/project-compiler.test.ts +0 -546
  144. package/src/__tests__/project-decompiler.test.ts +0 -343
  145. package/src/__tests__/query-compilation.test.ts +0 -145
  146. package/src/__tests__/round-trip/PLAN.md +0 -158
  147. package/src/__tests__/round-trip/README.md +0 -52
  148. package/src/__tests__/round-trip/RESULTS.md +0 -86
  149. package/src/__tests__/round-trip/fixtures/data-heavy/main.workflow.tsx +0 -55
  150. package/src/__tests__/round-trip/fixtures/data-heavy/mm.config.ts +0 -11
  151. package/src/__tests__/round-trip/fixtures/data-heavy/models/contact.ts +0 -54
  152. package/src/__tests__/round-trip/fixtures/full-workflow/main.workflow.tsx +0 -79
  153. package/src/__tests__/round-trip/fixtures/full-workflow/mm.config.ts +0 -12
  154. package/src/__tests__/round-trip/fixtures/full-workflow/models/order.ts +0 -50
  155. package/src/__tests__/round-trip/fixtures/simple-crud/main.workflow.tsx +0 -25
  156. package/src/__tests__/round-trip/fixtures/simple-crud/mm.config.ts +0 -11
  157. package/src/__tests__/round-trip/fixtures/simple-crud/models/task.ts +0 -32
  158. package/src/__tests__/round-trip/fixtures/view-heavy/main.workflow.tsx +0 -79
  159. package/src/__tests__/round-trip/fixtures/view-heavy/mm.config.ts +0 -10
  160. package/src/__tests__/round-trip/round-trip.test.ts +0 -2598
  161. package/src/__tests__/round-trip-ir.test.ts +0 -300
  162. package/src/__tests__/round-trip.test.ts +0 -1212
  163. package/src/__tests__/route-merging.test.ts +0 -372
  164. package/src/__tests__/router-composition.test.ts +0 -489
  165. package/src/__tests__/router-extractor.test.ts +0 -176
  166. package/src/__tests__/server-action-extractor.test.ts +0 -128
  167. package/src/__tests__/smart-type-inference.test.ts +0 -365
  168. package/src/__tests__/source-envelope.test.ts +0 -284
  169. package/src/__tests__/source-fidelity.test.ts +0 -516
  170. package/src/__tests__/state-extractor.test.ts +0 -115
  171. package/src/__tests__/strict-mode.test.ts +0 -227
  172. package/src/__tests__/transition-effect-extractor.test.ts +0 -119
  173. package/src/__tests__/transition-extractor.test.ts +0 -68
  174. package/src/__tests__/ts-to-expression.test.ts +0 -462
  175. package/src/__tests__/type-generator.test.ts +0 -201
  176. package/src/__tests__/uber-validation.test.ts +0 -502
  177. package/src/action-compiler.ts +0 -361
  178. package/src/babel/emitters/experience-transform.ts +0 -199
  179. package/src/babel/emitters/ir-to-tsx-emitter.ts +0 -110
  180. package/src/babel/emitters/pure-form-emitter.ts +0 -1023
  181. package/src/babel/emitters/runtime-glue-emitter.ts +0 -39
  182. package/src/babel/extractors/change-extractor.ts +0 -199
  183. package/src/babel/extractors/component-extractor.ts +0 -907
  184. package/src/babel/extractors/computed-extractor.ts +0 -262
  185. package/src/babel/extractors/context-extractor.ts +0 -277
  186. package/src/babel/extractors/during-extractor.ts +0 -295
  187. package/src/babel/extractors/effect-extractor.ts +0 -340
  188. package/src/babel/extractors/event-extractor.ts +0 -235
  189. package/src/babel/extractors/grammar-island-extractor.ts +0 -302
  190. package/src/babel/extractors/model-extractor.ts +0 -1018
  191. package/src/babel/extractors/router-extractor.ts +0 -303
  192. package/src/babel/extractors/server-action-extractor.ts +0 -173
  193. package/src/babel/extractors/server-action-hook-extractor.ts +0 -72
  194. package/src/babel/extractors/server-state-extractor.ts +0 -88
  195. package/src/babel/extractors/state-extractor.ts +0 -214
  196. package/src/babel/extractors/transition-effect-extractor.ts +0 -176
  197. package/src/babel/extractors/transition-extractor.ts +0 -143
  198. package/src/babel/index.ts +0 -24
  199. package/src/babel/transpilers/ts-to-expression.ts +0 -674
  200. package/src/babel/visitor.ts +0 -807
  201. package/src/cli/auth.ts +0 -255
  202. package/src/cli/build.ts +0 -288
  203. package/src/cli/deploy.ts +0 -206
  204. package/src/cli/index.ts +0 -328
  205. package/src/cli/installer.ts +0 -261
  206. package/src/cli/lock-file.ts +0 -94
  207. package/src/cli/mmrc.ts +0 -22
  208. package/src/cli/pull.ts +0 -172
  209. package/src/cli/registry-client.ts +0 -175
  210. package/src/cli/test.ts +0 -397
  211. package/src/cli/type-generator.ts +0 -243
  212. package/src/codemod/__tests__/forward.test.ts +0 -239
  213. package/src/codemod/__tests__/reverse.test.ts +0 -145
  214. package/src/codemod/__tests__/round-trip.test.ts +0 -137
  215. package/src/codemod/annotation.ts +0 -97
  216. package/src/codemod/classify.ts +0 -197
  217. package/src/codemod/cli.ts +0 -207
  218. package/src/codemod/control-flow.ts +0 -409
  219. package/src/codemod/forward.ts +0 -244
  220. package/src/codemod/import-manager.ts +0 -171
  221. package/src/codemod/index.ts +0 -120
  222. package/src/codemod/reverse.ts +0 -197
  223. package/src/codemod/rules.ts +0 -174
  224. package/src/codemod/state-transform.ts +0 -126
  225. package/src/decompiler/ast-builder.ts +0 -538
  226. package/src/decompiler/config-generator.ts +0 -151
  227. package/src/decompiler/index.ts +0 -315
  228. package/src/decompiler/project-decompiler.ts +0 -1776
  229. package/src/decompiler/project.ts +0 -862
  230. package/src/decompiler/split-strategy.ts +0 -140
  231. package/src/decompiler/state-emitter.ts +0 -1053
  232. package/src/decompiler/sx-emitter.ts +0 -318
  233. package/src/decompiler/workspace-hydrator.ts +0 -189
  234. package/src/dev-server.ts +0 -238
  235. package/src/envelope/fs-tree.ts +0 -217
  236. package/src/envelope/source-envelope.ts +0 -264
  237. package/src/envelope.ts +0 -315
  238. package/src/incremental-compiler.ts +0 -401
  239. package/src/index.ts +0 -99
  240. package/src/model-compiler.ts +0 -277
  241. package/src/project-compiler.ts +0 -1629
  242. package/src/route-extractor.ts +0 -333
  243. package/src/testing/index.ts +0 -32
  244. package/src/testing/snapshot.ts +0 -252
  245. package/src/testing/test-utils.ts +0 -226
  246. package/src/types.ts +0 -68
  247. package/src/vite/index.ts +0 -288
  248. package/test-compile.mjs +0 -142
  249. package/tsconfig.json +0 -25
  250. package/tsup.config.ts +0 -23
  251. 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
- }