@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.
- package/ATOM-PIPELINE.md +144 -0
- package/README.md +88 -40
- package/dist/babel/index.js +113 -6
- package/dist/babel/index.mjs +2 -2
- package/dist/chunk-3USIFFE4.mjs +2190 -0
- package/dist/chunk-45YMGEVT.mjs +186 -0
- package/dist/chunk-4FN2AISW.mjs +148 -0
- package/dist/chunk-4OPI5L7G.mjs +2593 -0
- package/dist/chunk-4RYTKOOJ.mjs +186 -0
- package/dist/chunk-5RKTOVR5.mjs +244 -0
- package/dist/chunk-5YDMOO4X.mjs +214 -0
- package/dist/chunk-64ZWEMLJ.mjs +148 -0
- package/dist/chunk-6XP4KSWQ.mjs +2190 -0
- package/dist/chunk-72QWL54I.mjs +175 -0
- package/dist/chunk-7B4TRI7C.mjs +4835 -0
- package/dist/chunk-7ZKGHTNB.mjs +4952 -0
- package/dist/chunk-CIESM3BP.mjs +33 -0
- package/dist/chunk-DE3ZGQAC.mjs +148 -0
- package/dist/chunk-DMCY3BBG.mjs +1933 -0
- package/dist/chunk-DPIK3PJS.mjs +244 -0
- package/dist/chunk-E5IVH4RE.mjs +186 -0
- package/dist/chunk-E6FZNUR5.mjs +4953 -0
- package/dist/chunk-EJRBDQDP.mjs +2607 -0
- package/dist/chunk-ELO4TXJL.mjs +186 -0
- package/dist/chunk-FKRO52XH.mjs +3446 -0
- package/dist/chunk-FL4YAKU6.mjs +4941 -0
- package/dist/chunk-FYT47UBU.mjs +5076 -0
- package/dist/chunk-GCLGPOJZ.mjs +148 -0
- package/dist/chunk-GXB4JOP7.mjs +5072 -0
- package/dist/chunk-HFXOUMTD.mjs +175 -0
- package/dist/chunk-HWIZ47US.mjs +214 -0
- package/dist/chunk-IB7MNPQL.mjs +4953 -0
- package/dist/chunk-ICSIHQCG.mjs +148 -0
- package/dist/chunk-JLA5VNQ3.mjs +186 -0
- package/dist/chunk-JQLWFCTM.mjs +214 -0
- package/dist/chunk-KFJJCQAL.mjs +148 -0
- package/dist/chunk-KJUIIEQE.mjs +186 -0
- package/dist/chunk-KNWTHRVQ.mjs +175 -0
- package/dist/chunk-KSG4XSZF.mjs +175 -0
- package/dist/chunk-LF5N6DOU.mjs +175 -0
- package/dist/chunk-LJQCM2IM.mjs +214 -0
- package/dist/chunk-NW6555WJ.mjs +186 -0
- package/dist/chunk-OMZE6VLQ.mjs +214 -0
- package/dist/chunk-P4BR7WVO.mjs +2190 -0
- package/dist/chunk-QQHVYH2X.mjs +244 -0
- package/dist/chunk-S5QLWLLT.mjs +186 -0
- package/dist/chunk-SCWGT2FY.mjs +2190 -0
- package/dist/chunk-SMKJUSB3.mjs +2190 -0
- package/dist/chunk-VCAY2KGM.mjs +175 -0
- package/dist/chunk-WECAV6QB.mjs +148 -0
- package/dist/chunk-WMKBXUCE.mjs +3228 -0
- package/dist/chunk-XAJ5BKKL.mjs +4947 -0
- package/dist/chunk-XG2X7AEA.mjs +175 -0
- package/dist/chunk-XG7Z23NQ.mjs +148 -0
- package/dist/chunk-XWZAOCQ7.mjs +2607 -0
- package/dist/chunk-Y6MA7ULW.mjs +148 -0
- package/dist/chunk-YMS7Q7LG.mjs +214 -0
- package/dist/chunk-ZA37XTGA.mjs +175 -0
- package/dist/cli/index.js +1616 -366
- package/dist/cli/index.mjs +8 -8
- package/dist/codemod/cli.mjs +1 -1
- package/dist/codemod/index.mjs +1 -1
- package/dist/dev-server-RmGHIntF.d.mts +113 -0
- package/dist/dev-server-RmGHIntF.d.ts +113 -0
- package/dist/dev-server.d.mts +1 -1
- package/dist/dev-server.d.ts +1 -1
- package/dist/dev-server.js +982 -53
- package/dist/dev-server.mjs +5 -5
- package/dist/envelope.js +113 -6
- package/dist/envelope.mjs +3 -3
- package/dist/index.d.mts +5 -1
- package/dist/index.d.ts +5 -1
- package/dist/index.js +992 -63
- package/dist/index.mjs +8 -8
- package/{src/cli/init.ts → dist/init-7JQMAAXS.mjs} +70 -95
- package/dist/init-EHO4VQ22.mjs +369 -0
- package/dist/init-UC3FWPIW.mjs +367 -0
- package/dist/init-UNSMVKIK.mjs +366 -0
- package/dist/init-UNV5XIDE.mjs +367 -0
- package/dist/project-compiler-2P4N4DR7.mjs +10 -0
- package/dist/project-compiler-D2LCC27O.mjs +10 -0
- package/dist/project-compiler-EJ3GANJE.mjs +10 -0
- package/dist/project-compiler-LOQKVRZJ.mjs +10 -0
- package/dist/project-compiler-RQ6OQKRM.mjs +10 -0
- package/dist/project-compiler-VWNNCHGO.mjs +10 -0
- package/dist/project-compiler-XVAAU4C5.mjs +10 -0
- package/dist/project-compiler-YES5FGMD.mjs +10 -0
- package/dist/project-compiler-ZKMQDLGU.mjs +10 -0
- package/dist/project-decompiler-FLXCEJHS.mjs +7 -0
- package/dist/project-decompiler-VLPR22QF.mjs +7 -0
- package/dist/pull-FUS5QYZS.mjs +109 -0
- package/dist/pull-LD5ENLGY.mjs +109 -0
- package/dist/testing/index.js +113 -6
- package/dist/testing/index.mjs +2 -2
- package/dist/vite/index.js +113 -6
- package/dist/vite/index.mjs +3 -3
- package/examples/uber-app/app/admin/fleet.tsx +19 -19
- package/package.json +4 -3
- package/compile-blueprint-chat.mjs +0 -99
- package/compile-blueprint-glass-console.mjs +0 -98
- package/compile-chat-defs.mjs +0 -92
- package/examples/uber-app/tests/payment.test.tsx +0 -129
- package/examples/uber-app/tests/ride-flow.test.tsx +0 -123
- package/package.json.backup +0 -86
- package/scripts/decompile.ts +0 -226
- package/scripts/seed-auth.ts +0 -267
- package/scripts/seed-uber.ts +0 -248
- package/scripts/validate-uber.ts +0 -119
- package/seed-blueprint-chat.mjs +0 -444
- package/seed-blueprint-glass-console.mjs +0 -445
- package/seed-compiled.mjs +0 -318
- package/src/RoundTripValidator.ts +0 -400
- package/src/__tests__/atom-rendering-coverage.test.ts +0 -680
- package/src/__tests__/auth-module-compilation.test.ts +0 -247
- package/src/__tests__/auth-template-compilation.test.ts +0 -589
- package/src/__tests__/change-extractor.test.ts +0 -142
- package/src/__tests__/cli-pull.test.ts +0 -73
- package/src/__tests__/cli-test.test.ts +0 -72
- package/src/__tests__/component-extractor.test.ts +0 -331
- package/src/__tests__/context-extractor.test.ts +0 -145
- package/src/__tests__/decompiler.test.ts +0 -718
- package/src/__tests__/define-blueprint.test.ts +0 -133
- package/src/__tests__/definition-validator.test.ts +0 -519
- package/src/__tests__/during-extractor.test.ts +0 -152
- package/src/__tests__/effect-extractor.test.ts +0 -107
- package/src/__tests__/event-emission.test.ts +0 -127
- package/src/__tests__/examples.test.ts +0 -236
- package/src/__tests__/full-blueprint-coverage.test.ts +0 -1221
- package/src/__tests__/golden-suite.test.ts +0 -403
- package/src/__tests__/grammar-island-extractor.test.ts +0 -289
- package/src/__tests__/instance-key.test.ts +0 -82
- package/src/__tests__/ir-migration.test.ts +0 -255
- package/src/__tests__/lock-file.test.ts +0 -117
- package/src/__tests__/model-extractor.test.ts +0 -195
- package/src/__tests__/model-field-acl.test.ts +0 -237
- package/src/__tests__/model-hooks.test.ts +0 -130
- package/src/__tests__/model-ref-resolution.test.ts +0 -268
- package/src/__tests__/model-roundtrip.test.ts +0 -502
- package/src/__tests__/model-runtime.test.ts +0 -112
- package/src/__tests__/model-transitions.test.ts +0 -183
- package/src/__tests__/nrt-action-trace.test.ts +0 -391
- package/src/__tests__/pipeline-hardening.test.ts +0 -413
- package/src/__tests__/project-compiler.test.ts +0 -546
- package/src/__tests__/project-decompiler.test.ts +0 -343
- package/src/__tests__/query-compilation.test.ts +0 -145
- package/src/__tests__/round-trip/PLAN.md +0 -158
- package/src/__tests__/round-trip/README.md +0 -52
- package/src/__tests__/round-trip/RESULTS.md +0 -86
- package/src/__tests__/round-trip/fixtures/data-heavy/main.workflow.tsx +0 -55
- package/src/__tests__/round-trip/fixtures/data-heavy/mm.config.ts +0 -11
- package/src/__tests__/round-trip/fixtures/data-heavy/models/contact.ts +0 -54
- package/src/__tests__/round-trip/fixtures/full-workflow/main.workflow.tsx +0 -79
- package/src/__tests__/round-trip/fixtures/full-workflow/mm.config.ts +0 -12
- package/src/__tests__/round-trip/fixtures/full-workflow/models/order.ts +0 -50
- package/src/__tests__/round-trip/fixtures/simple-crud/main.workflow.tsx +0 -25
- package/src/__tests__/round-trip/fixtures/simple-crud/mm.config.ts +0 -11
- package/src/__tests__/round-trip/fixtures/simple-crud/models/task.ts +0 -32
- package/src/__tests__/round-trip/fixtures/view-heavy/main.workflow.tsx +0 -79
- package/src/__tests__/round-trip/fixtures/view-heavy/mm.config.ts +0 -10
- package/src/__tests__/round-trip/round-trip.test.ts +0 -2598
- package/src/__tests__/round-trip-ir.test.ts +0 -300
- package/src/__tests__/round-trip.test.ts +0 -1212
- package/src/__tests__/route-merging.test.ts +0 -372
- package/src/__tests__/router-composition.test.ts +0 -489
- package/src/__tests__/router-extractor.test.ts +0 -176
- package/src/__tests__/server-action-extractor.test.ts +0 -128
- package/src/__tests__/smart-type-inference.test.ts +0 -365
- package/src/__tests__/source-envelope.test.ts +0 -284
- package/src/__tests__/source-fidelity.test.ts +0 -516
- package/src/__tests__/state-extractor.test.ts +0 -115
- package/src/__tests__/strict-mode.test.ts +0 -227
- package/src/__tests__/transition-effect-extractor.test.ts +0 -119
- package/src/__tests__/transition-extractor.test.ts +0 -68
- package/src/__tests__/ts-to-expression.test.ts +0 -462
- package/src/__tests__/type-generator.test.ts +0 -201
- package/src/__tests__/uber-validation.test.ts +0 -502
- package/src/action-compiler.ts +0 -361
- package/src/babel/emitters/experience-transform.ts +0 -199
- package/src/babel/emitters/ir-to-tsx-emitter.ts +0 -110
- package/src/babel/emitters/pure-form-emitter.ts +0 -1023
- package/src/babel/emitters/runtime-glue-emitter.ts +0 -39
- package/src/babel/extractors/change-extractor.ts +0 -199
- package/src/babel/extractors/component-extractor.ts +0 -907
- package/src/babel/extractors/computed-extractor.ts +0 -262
- package/src/babel/extractors/context-extractor.ts +0 -277
- package/src/babel/extractors/during-extractor.ts +0 -295
- package/src/babel/extractors/effect-extractor.ts +0 -340
- package/src/babel/extractors/event-extractor.ts +0 -235
- package/src/babel/extractors/grammar-island-extractor.ts +0 -302
- package/src/babel/extractors/model-extractor.ts +0 -1018
- package/src/babel/extractors/router-extractor.ts +0 -303
- package/src/babel/extractors/server-action-extractor.ts +0 -173
- package/src/babel/extractors/server-action-hook-extractor.ts +0 -72
- package/src/babel/extractors/server-state-extractor.ts +0 -88
- package/src/babel/extractors/state-extractor.ts +0 -214
- package/src/babel/extractors/transition-effect-extractor.ts +0 -176
- package/src/babel/extractors/transition-extractor.ts +0 -143
- package/src/babel/index.ts +0 -24
- package/src/babel/transpilers/ts-to-expression.ts +0 -674
- package/src/babel/visitor.ts +0 -807
- package/src/cli/auth.ts +0 -255
- package/src/cli/build.ts +0 -288
- package/src/cli/deploy.ts +0 -206
- package/src/cli/index.ts +0 -328
- package/src/cli/installer.ts +0 -261
- package/src/cli/lock-file.ts +0 -94
- package/src/cli/mmrc.ts +0 -22
- package/src/cli/pull.ts +0 -172
- package/src/cli/registry-client.ts +0 -175
- package/src/cli/test.ts +0 -397
- package/src/cli/type-generator.ts +0 -243
- package/src/codemod/__tests__/forward.test.ts +0 -239
- package/src/codemod/__tests__/reverse.test.ts +0 -145
- package/src/codemod/__tests__/round-trip.test.ts +0 -137
- package/src/codemod/annotation.ts +0 -97
- package/src/codemod/classify.ts +0 -197
- package/src/codemod/cli.ts +0 -207
- package/src/codemod/control-flow.ts +0 -409
- package/src/codemod/forward.ts +0 -244
- package/src/codemod/import-manager.ts +0 -171
- package/src/codemod/index.ts +0 -120
- package/src/codemod/reverse.ts +0 -197
- package/src/codemod/rules.ts +0 -174
- package/src/codemod/state-transform.ts +0 -126
- package/src/decompiler/ast-builder.ts +0 -538
- package/src/decompiler/config-generator.ts +0 -151
- package/src/decompiler/index.ts +0 -315
- package/src/decompiler/project-decompiler.ts +0 -1776
- package/src/decompiler/project.ts +0 -862
- package/src/decompiler/split-strategy.ts +0 -140
- package/src/decompiler/state-emitter.ts +0 -1053
- package/src/decompiler/sx-emitter.ts +0 -318
- package/src/decompiler/workspace-hydrator.ts +0 -189
- package/src/dev-server.ts +0 -238
- package/src/envelope/fs-tree.ts +0 -217
- package/src/envelope/source-envelope.ts +0 -264
- package/src/envelope.ts +0 -315
- package/src/incremental-compiler.ts +0 -401
- package/src/index.ts +0 -99
- package/src/model-compiler.ts +0 -277
- package/src/project-compiler.ts +0 -1629
- package/src/route-extractor.ts +0 -333
- package/src/testing/index.ts +0 -32
- package/src/testing/snapshot.ts +0 -252
- package/src/testing/test-utils.ts +0 -226
- package/src/types.ts +0 -68
- package/src/vite/index.ts +0 -288
- package/test-compile.mjs +0 -142
- package/tsconfig.json +0 -25
- package/tsup.config.ts +0 -23
- 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
|
-
}
|