@mmapp/react-compiler 0.1.0-alpha.18 → 0.1.0-alpha.20

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 (199) hide show
  1. package/dist/babel/index.d.mts +1 -1
  2. package/dist/babel/index.d.ts +1 -1
  3. package/dist/babel/index.js +9 -6
  4. package/dist/babel/index.mjs +1 -1
  5. package/dist/chunk-26U577GB.mjs +3465 -0
  6. package/dist/chunk-2FBDFAX6.mjs +2362 -0
  7. package/dist/chunk-2REDFOER.mjs +931 -0
  8. package/dist/{chunk-FPAMQXKB.mjs → chunk-2UTXM2QX.mjs} +10 -20
  9. package/dist/chunk-2YDQTFAL.mjs +879 -0
  10. package/dist/chunk-2ZRKQE74.mjs +175 -0
  11. package/dist/chunk-3QHG2JWV.mjs +154 -0
  12. package/dist/chunk-466OWSTT.mjs +186 -0
  13. package/dist/chunk-467SFYOD.mjs +3127 -0
  14. package/dist/chunk-4AIJO7DZ.mjs +214 -0
  15. package/dist/chunk-4D43TZYL.mjs +7495 -0
  16. package/dist/chunk-4FP5DXY4.mjs +3456 -0
  17. package/dist/chunk-4HX4PI4R.mjs +734 -0
  18. package/dist/chunk-4VU56NTZ.mjs +544 -0
  19. package/dist/chunk-4XHK6FWL.mjs +2058 -0
  20. package/dist/chunk-52C2JKH2.mjs +186 -0
  21. package/dist/chunk-52XHYD2V.mjs +214 -0
  22. package/dist/chunk-5GUFFFGL.mjs +148 -0
  23. package/dist/chunk-5N2FDDS6.mjs +214 -0
  24. package/dist/chunk-5ZSJXWZT.mjs +1646 -0
  25. package/dist/chunk-6CQOAAMV.mjs +1803 -0
  26. package/dist/chunk-6SEVAAVT.mjs +3516 -0
  27. package/dist/chunk-6YLR5ZDA.mjs +2829 -0
  28. package/dist/chunk-77UJB356.mjs +244 -0
  29. package/dist/chunk-7QOAJPQF.mjs +774 -0
  30. package/dist/chunk-A5RCMIBP.mjs +1795 -0
  31. package/dist/chunk-A63R3GKH.mjs +1803 -0
  32. package/dist/chunk-ABNTZXF5.mjs +951 -0
  33. package/dist/chunk-ADHWW56I.mjs +214 -0
  34. package/dist/chunk-AOGY2GK6.mjs +3292 -0
  35. package/dist/chunk-AXXUXRNA.mjs +1434 -0
  36. package/dist/chunk-BZLU5YK5.mjs +1025 -0
  37. package/dist/chunk-C7XCDDBH.mjs +1802 -0
  38. package/dist/chunk-CHLVKMQW.mjs +175 -0
  39. package/dist/chunk-CKGOZAB7.mjs +939 -0
  40. package/dist/chunk-CSXYDIVC.mjs +214 -0
  41. package/dist/chunk-CXTV4VGG.mjs +148 -0
  42. package/dist/chunk-D34RAZUX.mjs +2223 -0
  43. package/dist/chunk-DDIC7WM6.mjs +3127 -0
  44. package/dist/chunk-DPUQOBU6.mjs +4810 -0
  45. package/dist/chunk-E6MDVTGT.mjs +148 -0
  46. package/dist/chunk-EGKMUEM6.mjs +544 -0
  47. package/dist/chunk-EO6SYNCG.mjs +175 -0
  48. package/dist/chunk-EQGA6A6D.mjs +121 -0
  49. package/dist/chunk-EY2CSXYA.mjs +822 -0
  50. package/dist/chunk-EYLOSECJ.mjs +544 -0
  51. package/dist/chunk-FF5BQVII.mjs +148 -0
  52. package/dist/chunk-FIQ65CDR.mjs +925 -0
  53. package/dist/chunk-FOZXJFAR.mjs +186 -0
  54. package/dist/chunk-G2IAZ5Q6.mjs +148 -0
  55. package/dist/chunk-G7SMOWOL.mjs +828 -0
  56. package/dist/chunk-GK7NU6DO.mjs +214 -0
  57. package/dist/chunk-HDSCPEHY.mjs +4061 -0
  58. package/dist/chunk-HJELFNEA.mjs +186 -0
  59. package/dist/chunk-HOIUP6IF.mjs +690 -0
  60. package/dist/chunk-HRJGDPNE.mjs +148 -0
  61. package/dist/chunk-I3AU7GRD.mjs +120 -0
  62. package/dist/chunk-I3VQQJZ6.mjs +2843 -0
  63. package/dist/chunk-I6SSPILI.mjs +550 -0
  64. package/dist/chunk-IPTX5MJU.mjs +3223 -0
  65. package/dist/chunk-ITGUSH2Z.mjs +2783 -0
  66. package/dist/chunk-IXHBCAMF.mjs +3306 -0
  67. package/dist/chunk-J7JUAHS4.mjs +186 -0
  68. package/dist/chunk-J7TWJ3TM.mjs +2784 -0
  69. package/dist/chunk-JDPLDGVF.mjs +4810 -0
  70. package/dist/chunk-JK72MQ4N.mjs +877 -0
  71. package/dist/chunk-K2HHCAS2.mjs +148 -0
  72. package/dist/chunk-K5HX2SVL.mjs +1902 -0
  73. package/dist/chunk-KAUEQ2F3.mjs +148 -0
  74. package/dist/chunk-KFVVOS5N.mjs +925 -0
  75. package/dist/chunk-KIH4AN3Y.mjs +154 -0
  76. package/dist/chunk-KPDMN5IX.mjs +175 -0
  77. package/dist/chunk-LZL2IRCH.mjs +186 -0
  78. package/dist/chunk-MIZV3TAN.mjs +3293 -0
  79. package/dist/chunk-MRH4J7IX.mjs +2846 -0
  80. package/dist/chunk-NKBL5GUC.mjs +186 -0
  81. package/dist/chunk-NQCNSCF6.mjs +148 -0
  82. package/dist/chunk-NRP5J3BR.mjs +4811 -0
  83. package/dist/chunk-NTB7OEX2.mjs +2918 -0
  84. package/dist/chunk-NUPJYPFU.mjs +801 -0
  85. package/dist/chunk-NVQUTSQX.mjs +3128 -0
  86. package/dist/chunk-OGMG64EY.mjs +148 -0
  87. package/dist/chunk-OL5B2HTH.mjs +175 -0
  88. package/dist/chunk-OPJKP747.mjs +7506 -0
  89. package/dist/chunk-OQLGGBNE.mjs +2918 -0
  90. package/dist/chunk-OW4AQUDL.mjs +544 -0
  91. package/dist/chunk-OWI6XWCD.mjs +3375 -0
  92. package/dist/chunk-OZT2EAF2.mjs +2776 -0
  93. package/dist/chunk-PBRBRKIQ.mjs +175 -0
  94. package/dist/chunk-PRUMNNDI.mjs +3192 -0
  95. package/dist/chunk-QPNHDTSM.mjs +4839 -0
  96. package/dist/chunk-RNEIAJDR.mjs +897 -0
  97. package/dist/chunk-RY7POBNT.mjs +3127 -0
  98. package/dist/chunk-S6FJ4DXL.mjs +1813 -0
  99. package/dist/chunk-SU4E6E7B.mjs +3153 -0
  100. package/dist/chunk-SYUUKW5A.mjs +3379 -0
  101. package/dist/chunk-THB5SX2S.mjs +113 -0
  102. package/dist/chunk-THFYE5ZX.mjs +244 -0
  103. package/dist/chunk-TK3QMXIP.mjs +2921 -0
  104. package/dist/chunk-TRR2NPAV.mjs +248 -0
  105. package/dist/chunk-TTTTOT7P.mjs +1803 -0
  106. package/dist/chunk-TXONBY6A.mjs +7509 -0
  107. package/dist/chunk-U2PX3JSY.mjs +1933 -0
  108. package/dist/chunk-U6F7CTHK.mjs +550 -0
  109. package/dist/chunk-UASOWKDI.mjs +186 -0
  110. package/dist/chunk-UDDTWG5J.mjs +734 -0
  111. package/dist/chunk-UIWLAQCL.mjs +175 -0
  112. package/dist/chunk-UL2XZEMA.mjs +3128 -0
  113. package/dist/chunk-US3AVDAI.mjs +3456 -0
  114. package/dist/chunk-V5DIDOTT.mjs +148 -0
  115. package/dist/chunk-VLTKQDJ3.mjs +244 -0
  116. package/dist/chunk-VVC42PTS.mjs +175 -0
  117. package/dist/chunk-VX3T3NIR.mjs +897 -0
  118. package/dist/chunk-WBYMW4NQ.mjs +3450 -0
  119. package/dist/chunk-XMWUHQVV.mjs +939 -0
  120. package/dist/chunk-XUQ5R6F3.mjs +213 -0
  121. package/dist/chunk-Y6FXYEAI.mjs +10 -0
  122. package/dist/chunk-YCWC2SCO.mjs +148 -0
  123. package/dist/chunk-YFS6JMYO.mjs +3342 -0
  124. package/dist/chunk-ZE67HOSN.mjs +148 -0
  125. package/dist/chunk-ZSK5TPIV.mjs +148 -0
  126. package/dist/cli/index.js +329 -653
  127. package/dist/cli/index.mjs +9 -9
  128. package/dist/config-PL24KEWL.mjs +219 -0
  129. package/dist/deploy-VAHWALWB.mjs +9 -0
  130. package/dist/dev-server-Bs_sz2DG.d.mts +111 -0
  131. package/dist/dev-server-Bs_sz2DG.d.ts +111 -0
  132. package/dist/dev-server-RmGHIntF.d.mts +113 -0
  133. package/dist/dev-server-RmGHIntF.d.ts +113 -0
  134. package/dist/dev-server.js +205 -522
  135. package/dist/dev-server.mjs +4 -4
  136. package/dist/engine-binary-KQB23JDR.mjs +97 -0
  137. package/dist/envelope-DD7v0v6E.d.mts +265 -0
  138. package/dist/envelope-DD7v0v6E.d.ts +265 -0
  139. package/dist/envelope.js +9 -6
  140. package/dist/envelope.mjs +2 -2
  141. package/dist/index-B5gSgvnd.d.mts +44 -0
  142. package/dist/index-B5gSgvnd.d.ts +44 -0
  143. package/dist/index-Bs0MnR54.d.mts +103 -0
  144. package/dist/index-Bs0MnR54.d.ts +103 -0
  145. package/dist/index-DR0nNc_f.d.mts +101 -0
  146. package/dist/index-DR0nNc_f.d.ts +101 -0
  147. package/dist/index-revho_gS.d.mts +104 -0
  148. package/dist/index-revho_gS.d.ts +104 -0
  149. package/dist/index-vQjwYekL.d.mts +104 -0
  150. package/dist/index-vQjwYekL.d.ts +104 -0
  151. package/dist/index.d.mts +2 -2
  152. package/dist/index.d.ts +2 -2
  153. package/dist/index.js +210 -525
  154. package/dist/index.mjs +10 -9
  155. package/dist/init-2XLTUF7O.mjs +407 -0
  156. package/dist/init-7FJENUDK.mjs +407 -0
  157. package/dist/init-AVZJHZYY.mjs +538 -0
  158. package/dist/init-DQDX3QK6.mjs +369 -0
  159. package/dist/init-K3GVM4JS.mjs +538 -0
  160. package/dist/init-NXS5BJN3.mjs +454 -0
  161. package/dist/init-UC3FWPIW.mjs +367 -0
  162. package/dist/init-UNV5XIDE.mjs +367 -0
  163. package/dist/project-compiler-2HOPO7GC.mjs +10 -0
  164. package/dist/project-compiler-D245L5QR.mjs +10 -0
  165. package/dist/project-compiler-FUQRMB4X.mjs +10 -0
  166. package/dist/project-compiler-LA5OBI5P.mjs +10 -0
  167. package/dist/project-compiler-OP2VVGJQ.mjs +10 -0
  168. package/dist/project-compiler-PZNFE6AH.mjs +10 -0
  169. package/dist/project-compiler-QBVF6MFI.mjs +10 -0
  170. package/dist/project-compiler-VFR6CSDX.mjs +10 -0
  171. package/dist/project-compiler-WMJZA4UH.mjs +10 -0
  172. package/dist/project-compiler-XXS27TZT.mjs +10 -0
  173. package/dist/project-compiler-YYGDSHY5.mjs +10 -0
  174. package/dist/project-decompiler-5GY2KSG4.mjs +7 -0
  175. package/dist/project-decompiler-7I2OMUVY.mjs +7 -0
  176. package/dist/project-decompiler-QCZYY4TW.mjs +7 -0
  177. package/dist/project-decompiler-US7GAVIC.mjs +7 -0
  178. package/dist/pull-2Q53HF3H.mjs +107 -0
  179. package/dist/pull-5AFHD3QG.mjs +109 -0
  180. package/dist/pull-5WJ4LW4U.mjs +109 -0
  181. package/dist/pull-65GUSX6F.mjs +109 -0
  182. package/dist/pull-6LVI4LMM.mjs +109 -0
  183. package/dist/pull-A2QUHW4K.mjs +109 -0
  184. package/dist/pull-B6T5BUKV.mjs +109 -0
  185. package/dist/pull-CKHWZT33.mjs +109 -0
  186. package/dist/pull-GM74ERRT.mjs +109 -0
  187. package/dist/pull-JBEQWVPE.mjs +109 -0
  188. package/dist/pull-P44LDRWB.mjs +109 -0
  189. package/dist/pull-W2US3T3E.mjs +109 -0
  190. package/dist/testing/index.js +9 -6
  191. package/dist/testing/index.mjs +1 -1
  192. package/dist/verify-3PPS4XAM.mjs +1833 -0
  193. package/dist/verify-GKEH5FZQ.mjs +1833 -0
  194. package/dist/verify-HDKUNHZ4.mjs +1833 -0
  195. package/dist/verify-SEIXUGN4.mjs +1833 -0
  196. package/dist/vite/index.js +10 -7
  197. package/dist/vite/index.mjs +2 -2
  198. package/mm-dev.db +0 -0
  199. package/package.json +2 -2
@@ -0,0 +1,822 @@
1
+ // src/babel/visitor.ts
2
+ import * as t6 from "@babel/types";
3
+
4
+ // src/babel/extractors/state-extractor.ts
5
+ import * as t from "@babel/types";
6
+ function inferFieldType(typeAnnotation, defaultValue) {
7
+ if (typeAnnotation) {
8
+ if (t.isTSNumberKeyword(typeAnnotation)) return "number";
9
+ if (t.isTSStringKeyword(typeAnnotation)) return "text";
10
+ if (t.isTSBooleanKeyword(typeAnnotation)) return "boolean";
11
+ if (t.isTSTypeReference(typeAnnotation)) {
12
+ const typeName = t.isIdentifier(typeAnnotation.typeName) ? typeAnnotation.typeName.name : "";
13
+ if (typeName === "Date") return "date";
14
+ }
15
+ if (t.isTSArrayType(typeAnnotation) || t.isTSTypeLiteral(typeAnnotation) || t.isTSTupleType(typeAnnotation)) {
16
+ return "json";
17
+ }
18
+ }
19
+ if (defaultValue) {
20
+ if (t.isNumericLiteral(defaultValue)) return "number";
21
+ if (t.isStringLiteral(defaultValue)) return "text";
22
+ if (t.isBooleanLiteral(defaultValue)) return "boolean";
23
+ if (t.isArrayExpression(defaultValue) || t.isObjectExpression(defaultValue)) {
24
+ return "json";
25
+ }
26
+ if (t.isNewExpression(defaultValue) && t.isIdentifier(defaultValue.callee)) {
27
+ if (defaultValue.callee.name === "Date") return "date";
28
+ }
29
+ }
30
+ return "text";
31
+ }
32
+ function extractDefaultValue(arg) {
33
+ if (t.isNumericLiteral(arg)) return arg.value;
34
+ if (t.isStringLiteral(arg)) return arg.value;
35
+ if (t.isBooleanLiteral(arg)) return arg.value;
36
+ if (t.isNullLiteral(arg)) return null;
37
+ if (t.isArrayExpression(arg)) {
38
+ return arg.elements.map(
39
+ (el) => el && t.isExpression(el) ? extractDefaultValue(el) : null
40
+ );
41
+ }
42
+ if (t.isObjectExpression(arg)) {
43
+ const obj = {};
44
+ arg.properties.forEach((prop) => {
45
+ if (t.isObjectProperty(prop) && t.isIdentifier(prop.key) && t.isExpression(prop.value)) {
46
+ obj[prop.key.name] = extractDefaultValue(prop.value);
47
+ }
48
+ });
49
+ return obj;
50
+ }
51
+ return void 0;
52
+ }
53
+ function extractStates(path, state) {
54
+ const parent = path.parentPath;
55
+ if (!parent.isVariableDeclarator()) return;
56
+ const id = parent.node.id;
57
+ if (!t.isArrayPattern(id) || id.elements.length < 1) return;
58
+ const firstElement = id.elements[0];
59
+ if (!t.isIdentifier(firstElement)) return;
60
+ const fieldName = firstElement.name;
61
+ const args = path.node.arguments;
62
+ const defaultValue = args.length > 0 && t.isExpression(args[0]) ? args[0] : null;
63
+ let typeAnnotation = null;
64
+ if (path.node.typeParameters && t.isTSTypeParameterInstantiation(path.node.typeParameters)) {
65
+ const params = path.node.typeParameters.params;
66
+ if (params.length > 0) {
67
+ typeAnnotation = params[0];
68
+ }
69
+ }
70
+ const fieldType = inferFieldType(typeAnnotation, defaultValue);
71
+ const fieldDefaultValue = defaultValue ? extractDefaultValue(defaultValue) : void 0;
72
+ const field = {
73
+ name: fieldName,
74
+ type: fieldType,
75
+ default_value: fieldDefaultValue
76
+ };
77
+ const compilerState = state;
78
+ if (!compilerState.fields) compilerState.fields = [];
79
+ if (!compilerState.fields.some((f) => f.name === fieldName)) {
80
+ compilerState.fields.push(field);
81
+ }
82
+ }
83
+
84
+ // src/babel/extractors/effect-extractor.ts
85
+ import * as t2 from "@babel/types";
86
+ function analyzeCallbackBody(body, actionCounter) {
87
+ const actions = [];
88
+ for (const statement of body) {
89
+ if (t2.isExpressionStatement(statement)) {
90
+ const expr = statement.expression;
91
+ if (t2.isCallExpression(expr) && t2.isIdentifier(expr.callee)) {
92
+ const calleeName = expr.callee.name;
93
+ const args = expr.arguments;
94
+ if (calleeName === "setField" && args.length >= 2) {
95
+ const field = t2.isStringLiteral(args[0]) ? args[0].value : void 0;
96
+ const arg1 = args[1];
97
+ if (field !== void 0 && !t2.isArgumentPlaceholder(arg1)) {
98
+ const value = extractValue(arg1);
99
+ actions.push({
100
+ id: `auto_${++actionCounter.value}`,
101
+ type: "set_field",
102
+ mode: "auto",
103
+ config: { field, value }
104
+ });
105
+ }
106
+ } else if (calleeName === "setMemory" && args.length >= 2) {
107
+ const key = t2.isStringLiteral(args[0]) ? args[0].value : void 0;
108
+ const arg1 = args[1];
109
+ if (key !== void 0 && !t2.isArgumentPlaceholder(arg1)) {
110
+ const value = extractValue(arg1);
111
+ actions.push({
112
+ id: `auto_${++actionCounter.value}`,
113
+ type: "set_memory",
114
+ mode: "auto",
115
+ config: { key, value }
116
+ });
117
+ }
118
+ } else if (calleeName.startsWith("set") && args.length >= 1) {
119
+ const fieldName = calleeName.slice(3).charAt(0).toLowerCase() + calleeName.slice(4);
120
+ const arg0 = args[0];
121
+ if (!t2.isArgumentPlaceholder(arg0)) {
122
+ const value = extractValue(arg0);
123
+ actions.push({
124
+ id: `auto_${++actionCounter.value}`,
125
+ type: "set_field",
126
+ mode: "auto",
127
+ config: { field: fieldName, value }
128
+ });
129
+ }
130
+ }
131
+ } else if (t2.isCallExpression(expr)) {
132
+ const callee = expr.callee;
133
+ const args = expr.arguments;
134
+ if (t2.isMemberExpression(callee) && t2.isIdentifier(callee.object) && callee.object.name === "console" && t2.isIdentifier(callee.property) && callee.property.name === "log" && args.length > 0) {
135
+ const arg0 = args[0];
136
+ if (!t2.isArgumentPlaceholder(arg0)) {
137
+ const message = extractValue(arg0);
138
+ actions.push({
139
+ id: `auto_${++actionCounter.value}`,
140
+ type: "log_event",
141
+ mode: "auto",
142
+ config: { message }
143
+ });
144
+ }
145
+ } else {
146
+ actions.push({
147
+ id: `auto_${++actionCounter.value}`,
148
+ type: "custom",
149
+ mode: "auto",
150
+ config: { expression: generateCode(expr) }
151
+ });
152
+ }
153
+ }
154
+ }
155
+ }
156
+ return actions;
157
+ }
158
+ function extractValue(node) {
159
+ if (t2.isNumericLiteral(node)) return node.value;
160
+ if (t2.isStringLiteral(node)) return node.value;
161
+ if (t2.isBooleanLiteral(node)) return node.value;
162
+ if (t2.isNullLiteral(node)) return null;
163
+ if (t2.isArrayExpression(node)) {
164
+ return node.elements.map((el) => el && t2.isExpression(el) ? extractValue(el) : null);
165
+ }
166
+ if (t2.isObjectExpression(node)) {
167
+ const obj = {};
168
+ node.properties.forEach((prop) => {
169
+ if (t2.isObjectProperty(prop) && t2.isIdentifier(prop.key) && t2.isExpression(prop.value)) {
170
+ obj[prop.key.name] = extractValue(prop.value);
171
+ }
172
+ });
173
+ return obj;
174
+ }
175
+ return generateCode(node);
176
+ }
177
+ function generateCode(node) {
178
+ if (t2.isIdentifier(node)) return node.name;
179
+ if (t2.isNumericLiteral(node)) return String(node.value);
180
+ if (t2.isStringLiteral(node)) return `"${node.value}"`;
181
+ if (t2.isBooleanLiteral(node)) return String(node.value);
182
+ if (t2.isNullLiteral(node)) return "null";
183
+ if (t2.isCallExpression(node) && t2.isMemberExpression(node.callee) && t2.isIdentifier(node.callee.object) && node.callee.object.name === "Date" && t2.isIdentifier(node.callee.property) && node.callee.property.name === "now") {
184
+ return "now()";
185
+ }
186
+ if (t2.isCallExpression(node) && t2.isMemberExpression(node.callee) && t2.isNewExpression(node.callee.object) && t2.isIdentifier(node.callee.object.callee) && node.callee.object.callee.name === "Date" && t2.isIdentifier(node.callee.property) && node.callee.property.name === "toISOString") {
187
+ return "now()";
188
+ }
189
+ if (t2.isTemplateLiteral(node)) {
190
+ return node.quasis.map((q) => q.value.raw).join("${}");
191
+ }
192
+ if (t2.isMemberExpression(node) && t2.isIdentifier(node.object) && t2.isIdentifier(node.property)) {
193
+ return `${node.object.name}.${node.property.name}`;
194
+ }
195
+ return "[Expression]";
196
+ }
197
+ function ensureState(states, stateName) {
198
+ if (!states.has(stateName)) {
199
+ states.set(stateName, {
200
+ name: stateName,
201
+ type: "REGULAR",
202
+ on_enter: [],
203
+ during: [],
204
+ on_exit: []
205
+ });
206
+ }
207
+ return states.get(stateName);
208
+ }
209
+ function extractEffects(path, state) {
210
+ const callee = path.node.callee;
211
+ if (!t2.isIdentifier(callee)) return;
212
+ const hookName = callee.name;
213
+ const args = path.node.arguments;
214
+ if ((hookName === "useOnEnter" || hookName === "useOnExit") && args.length >= 2) {
215
+ const stateArg = args[0];
216
+ const callbackArg = args[1];
217
+ if (!t2.isStringLiteral(stateArg)) return;
218
+ const stateName = stateArg.value;
219
+ let callbackBody = [];
220
+ if (t2.isArrowFunctionExpression(callbackArg) || t2.isFunctionExpression(callbackArg)) {
221
+ const body = callbackArg.body;
222
+ if (t2.isBlockStatement(body)) {
223
+ callbackBody = body.body;
224
+ } else if (t2.isExpression(body)) {
225
+ callbackBody = [t2.expressionStatement(body)];
226
+ }
227
+ }
228
+ const compilerState = state;
229
+ if (!compilerState.states) compilerState.states = /* @__PURE__ */ new Map();
230
+ if (!compilerState.actionCounter) compilerState.actionCounter = 0;
231
+ const stateDefinition = ensureState(compilerState.states, stateName);
232
+ const actions = analyzeCallbackBody(callbackBody, { value: compilerState.actionCounter });
233
+ compilerState.actionCounter += actions.length;
234
+ if (hookName === "useOnEnter") {
235
+ stateDefinition.on_enter.push(...actions);
236
+ } else if (hookName === "useOnExit") {
237
+ stateDefinition.on_exit.push(...actions);
238
+ }
239
+ }
240
+ }
241
+
242
+ // src/babel/extractors/transition-extractor.ts
243
+ import * as t3 from "@babel/types";
244
+ function extractTransitions(path, state) {
245
+ const callee = path.node.callee;
246
+ if (!t3.isIdentifier(callee) || callee.name !== "useTransition") return;
247
+ const args = path.node.arguments;
248
+ if (args.length < 1) return;
249
+ const nameArg = args[0];
250
+ if (!t3.isStringLiteral(nameArg)) return;
251
+ const transitionName = nameArg.value;
252
+ const compilerState = state;
253
+ if (!compilerState.transitions) compilerState.transitions = [];
254
+ const existing = compilerState.transitions.find((tr) => tr.name === transitionName);
255
+ if (existing) return;
256
+ let from = [];
257
+ let to = "";
258
+ if (args.length >= 2 && t3.isObjectExpression(args[1])) {
259
+ const opts = args[1];
260
+ for (const prop of opts.properties) {
261
+ if (!t3.isObjectProperty(prop) || !t3.isIdentifier(prop.key)) continue;
262
+ if (prop.key.name === "from") {
263
+ if (t3.isArrayExpression(prop.value)) {
264
+ from = prop.value.elements.filter((el) => t3.isStringLiteral(el)).map((el) => el.value);
265
+ } else if (t3.isStringLiteral(prop.value)) {
266
+ from = [prop.value.value];
267
+ }
268
+ } else if (prop.key.name === "to") {
269
+ if (t3.isStringLiteral(prop.value)) {
270
+ to = prop.value.value;
271
+ }
272
+ }
273
+ }
274
+ }
275
+ const transition = {
276
+ name: transitionName,
277
+ from,
278
+ to,
279
+ actions: [],
280
+ conditions: []
281
+ };
282
+ compilerState.transitions.push(transition);
283
+ }
284
+ function inferTransitionStates(transitions, states) {
285
+ const stateArray = Array.from(states.values());
286
+ const startStates = stateArray.filter((s) => s.type === "START");
287
+ const regularStates = stateArray.filter((s) => s.type === "REGULAR");
288
+ const needsInference = transitions.filter((t7) => t7.from.length === 0 || !t7.to);
289
+ if (needsInference.length === 0) return;
290
+ if (startStates.length === 1 && regularStates.length > 0) {
291
+ needsInference.forEach((t7, idx) => {
292
+ if (t7.from.length === 0) {
293
+ t7.from = [startStates[0].name];
294
+ }
295
+ if (!t7.to) {
296
+ t7.to = regularStates[idx % regularStates.length]?.name || startStates[0].name;
297
+ }
298
+ });
299
+ } else {
300
+ const allStateNames = stateArray.map((s) => s.name);
301
+ needsInference.forEach((t7, idx) => {
302
+ if (t7.from.length === 0 && allStateNames.length > 0) {
303
+ t7.from = [allStateNames[0]];
304
+ }
305
+ if (!t7.to && allStateNames.length > 1) {
306
+ t7.to = allStateNames[Math.min(idx + 1, allStateNames.length - 1)];
307
+ }
308
+ });
309
+ }
310
+ }
311
+
312
+ // src/babel/extractors/event-extractor.ts
313
+ import * as t4 from "@babel/types";
314
+ function analyzeEventCallback(body) {
315
+ const actions = [];
316
+ for (const statement of body) {
317
+ if (t4.isExpressionStatement(statement)) {
318
+ const expr = statement.expression;
319
+ if (t4.isCallExpression(expr) && t4.isIdentifier(expr.callee)) {
320
+ const calleeName = expr.callee.name;
321
+ const args = expr.arguments;
322
+ if (calleeName === "setField" && args.length >= 2) {
323
+ const field = t4.isStringLiteral(args[0]) ? args[0].value : void 0;
324
+ const expression = generateExpression(args[1]);
325
+ if (field) {
326
+ actions.push({
327
+ type: "set_field",
328
+ field,
329
+ expression
330
+ });
331
+ }
332
+ } else if (calleeName === "setMemory" && args.length >= 2) {
333
+ const key = t4.isStringLiteral(args[0]) ? args[0].value : void 0;
334
+ const expression = generateExpression(args[1]);
335
+ if (key) {
336
+ actions.push({
337
+ type: "set_memory",
338
+ key,
339
+ expression
340
+ });
341
+ }
342
+ }
343
+ } else if (t4.isCallExpression(expr)) {
344
+ const callee = expr.callee;
345
+ const args = expr.arguments;
346
+ if (t4.isMemberExpression(callee) && t4.isIdentifier(callee.object) && callee.object.name === "console" && t4.isIdentifier(callee.property) && callee.property.name === "log") {
347
+ const message = args.length > 0 ? generateExpression(args[0]) : "";
348
+ actions.push({
349
+ type: "log_event",
350
+ message
351
+ });
352
+ }
353
+ }
354
+ }
355
+ }
356
+ return actions;
357
+ }
358
+ function generateExpression(node) {
359
+ if (t4.isStringLiteral(node)) return node.value;
360
+ if (t4.isNumericLiteral(node)) return String(node.value);
361
+ if (t4.isBooleanLiteral(node)) return String(node.value);
362
+ if (t4.isIdentifier(node)) return node.name;
363
+ if (t4.isBinaryExpression(node)) {
364
+ return `${generateExpression(node.left)} ${node.operator} ${generateExpression(node.right)}`;
365
+ }
366
+ if (t4.isCallExpression(node) && t4.isIdentifier(node.callee)) {
367
+ const args = node.arguments.map((arg) => generateExpression(arg)).join(", ");
368
+ return `${node.callee.name}(${args})`;
369
+ }
370
+ return "[Expression]";
371
+ }
372
+ function ensureState2(states, stateName) {
373
+ if (!states.has(stateName)) {
374
+ states.set(stateName, {
375
+ name: stateName,
376
+ type: "REGULAR",
377
+ on_enter: [],
378
+ during: [],
379
+ on_exit: []
380
+ });
381
+ }
382
+ return states.get(stateName);
383
+ }
384
+ function extractEvents(path, state) {
385
+ const callee = path.node.callee;
386
+ if (!t4.isIdentifier(callee) || callee.name !== "useOnEvent") return;
387
+ const args = path.node.arguments;
388
+ if (args.length < 2) return;
389
+ const patternArg = args[0];
390
+ const callbackArg = args[1];
391
+ const optionsArg = args.length > 2 ? args[2] : null;
392
+ if (!t4.isStringLiteral(patternArg)) return;
393
+ const pattern = patternArg.value;
394
+ let callbackBody = [];
395
+ if (t4.isArrowFunctionExpression(callbackArg) || t4.isFunctionExpression(callbackArg)) {
396
+ const body = callbackArg.body;
397
+ if (t4.isBlockStatement(body)) {
398
+ callbackBody = body.body;
399
+ } else if (t4.isExpression(body)) {
400
+ callbackBody = [t4.expressionStatement(body)];
401
+ }
402
+ }
403
+ let stateName = null;
404
+ if (optionsArg && t4.isObjectExpression(optionsArg)) {
405
+ const whileProp = optionsArg.properties.find(
406
+ (prop) => t4.isObjectProperty(prop) && t4.isIdentifier(prop.key) && prop.key.name === "while"
407
+ );
408
+ if (whileProp && t4.isObjectProperty(whileProp) && t4.isStringLiteral(whileProp.value)) {
409
+ stateName = whileProp.value.value;
410
+ }
411
+ }
412
+ const actions = analyzeEventCallback(callbackBody);
413
+ const subscription = {
414
+ match: pattern,
415
+ conditions: [],
416
+ actions
417
+ };
418
+ const compilerState = state;
419
+ if (!compilerState.states) compilerState.states = /* @__PURE__ */ new Map();
420
+ if (stateName) {
421
+ const stateDefinition = ensureState2(compilerState.states, stateName);
422
+ if (!stateDefinition.on_event) stateDefinition.on_event = [];
423
+ stateDefinition.on_event.push(subscription);
424
+ } else {
425
+ if (!compilerState.events) compilerState.events = [];
426
+ compilerState.events.push(subscription);
427
+ }
428
+ }
429
+
430
+ // src/babel/extractors/component-extractor.ts
431
+ import * as t5 from "@babel/types";
432
+ var nodeIdCounter = 0;
433
+ function jsxToExperienceNode(node) {
434
+ if (t5.isJSXFragment(node)) {
435
+ return {
436
+ id: `fragment_${++nodeIdCounter}`,
437
+ children: node.children.map(jsxChildToNode).filter(Boolean)
438
+ };
439
+ }
440
+ const element = node.openingElement;
441
+ const componentName = t5.isJSXIdentifier(element.name) ? element.name.name : "div";
442
+ const id = generateNodeId(componentName);
443
+ const config = {};
444
+ const bindings = {};
445
+ let visibleWhen;
446
+ for (const attr of element.attributes) {
447
+ if (t5.isJSXAttribute(attr) && t5.isJSXIdentifier(attr.name)) {
448
+ const attrName = attr.name.name;
449
+ const attrValue = attr.value;
450
+ if (attrName === "visible_when" && t5.isStringLiteral(attrValue)) {
451
+ visibleWhen = attrValue.value;
452
+ } else if (attrName === "data-slot" && t5.isStringLiteral(attrValue)) {
453
+ config.slot = attrValue.value;
454
+ } else if (t5.isJSXExpressionContainer(attrValue)) {
455
+ const expr = attrValue.expression;
456
+ if (t5.isIdentifier(expr)) {
457
+ bindings[attrName] = `$instance.${expr.name}`;
458
+ } else if (t5.isExpression(expr)) {
459
+ bindings[attrName] = generateExpression2(expr);
460
+ }
461
+ } else if (t5.isStringLiteral(attrValue)) {
462
+ config[attrName] = attrValue.value;
463
+ }
464
+ }
465
+ }
466
+ const children = node.children.map(jsxChildToNode).filter(Boolean);
467
+ const experienceNode = {
468
+ id,
469
+ component: componentName,
470
+ ...Object.keys(bindings).length > 0 && { bindings },
471
+ ...Object.keys(config).length > 0 && { config },
472
+ ...visibleWhen && { visible_when: visibleWhen },
473
+ ...children.length > 0 && { children }
474
+ };
475
+ return experienceNode;
476
+ }
477
+ function jsxChildToNode(child) {
478
+ if (t5.isJSXElement(child)) {
479
+ return jsxToExperienceNode(child);
480
+ }
481
+ if (t5.isJSXFragment(child)) {
482
+ return jsxToExperienceNode(child);
483
+ }
484
+ return null;
485
+ }
486
+ function generateNodeId(componentName) {
487
+ const id = componentName.replace(/([A-Z])/g, "-$1").toLowerCase().replace(/^-/, "");
488
+ return `${id}_${++nodeIdCounter}`;
489
+ }
490
+ function generateExpression2(node) {
491
+ if (t5.isIdentifier(node)) return node.name;
492
+ if (t5.isStringLiteral(node)) return node.value;
493
+ if (t5.isNumericLiteral(node)) return String(node.value);
494
+ if (t5.isBooleanLiteral(node)) return String(node.value);
495
+ if (t5.isMemberExpression(node)) {
496
+ const obj = generateExpression2(node.object);
497
+ const prop = t5.isIdentifier(node.property) ? node.property.name : "[property]";
498
+ return `${obj}.${prop}`;
499
+ }
500
+ return "[Expression]";
501
+ }
502
+ function extractComponents(path, state) {
503
+ const arg = path.node.argument;
504
+ if (!arg) return;
505
+ let experienceNode = null;
506
+ if (t5.isJSXElement(arg)) {
507
+ experienceNode = jsxToExperienceNode(arg);
508
+ } else if (t5.isJSXFragment(arg)) {
509
+ experienceNode = jsxToExperienceNode(arg);
510
+ }
511
+ if (experienceNode) {
512
+ const compilerState = state;
513
+ compilerState.experience = experienceNode;
514
+ }
515
+ }
516
+
517
+ // src/babel/emitters/pure-form-emitter.ts
518
+ function toSnakeCase(str) {
519
+ return str.replace(/([A-Z])/g, "_$1").toLowerCase().replace(/^_/, "");
520
+ }
521
+ function convertAction(action) {
522
+ return {
523
+ id: action.id,
524
+ action_type: action.type,
525
+ config: action.config || {}
526
+ };
527
+ }
528
+ function emitPureForm(extracted) {
529
+ const { slug, name, version, description, category, fields, states, transitions } = extracted;
530
+ const stateArray = Array.from(states.values());
531
+ if (stateArray.length === 0) {
532
+ stateArray.push({
533
+ name: "draft",
534
+ type: "START",
535
+ on_enter: [],
536
+ during: [],
537
+ on_exit: []
538
+ });
539
+ } else {
540
+ const hasStart = stateArray.some((s) => s.type === "START");
541
+ if (!hasStart && stateArray.length > 0) {
542
+ stateArray[0].type = "START";
543
+ }
544
+ }
545
+ inferTransitionStates(transitions, states);
546
+ const stateNames = new Set(stateArray.map((s) => s.name));
547
+ for (const transition of transitions) {
548
+ if (transition.to && !stateNames.has(transition.to)) {
549
+ stateArray.push({
550
+ name: transition.to,
551
+ type: "REGULAR",
552
+ on_enter: [],
553
+ during: [],
554
+ on_exit: []
555
+ });
556
+ stateNames.add(transition.to);
557
+ }
558
+ }
559
+ return {
560
+ slug,
561
+ name,
562
+ version,
563
+ description,
564
+ category,
565
+ fields,
566
+ states: stateArray,
567
+ transitions,
568
+ roles: [],
569
+ tags: [],
570
+ metadata: extracted.experience ? { experience: extracted.experience } : {}
571
+ };
572
+ }
573
+ function emitWorkflowDefinition(extracted) {
574
+ const ir = emitPureForm(extracted);
575
+ const states = ir.states.map((s) => ({
576
+ name: s.name,
577
+ state_type: s.type,
578
+ description: "",
579
+ on_enter: (s.on_enter || []).map(convertAction),
580
+ on_exit: (s.on_exit || []).map(convertAction),
581
+ during: s.during || [],
582
+ on_event: []
583
+ }));
584
+ const fields = ir.fields.map((f) => ({
585
+ name: toSnakeCase(f.name),
586
+ field_type: f.type,
587
+ label: f.name.replace(/([A-Z])/g, " $1").replace(/^./, (c) => c.toUpperCase()),
588
+ required: false,
589
+ default_value: f.default_value ?? null
590
+ }));
591
+ const transitions = ir.transitions.map((t7) => ({
592
+ name: t7.name,
593
+ from: t7.from,
594
+ to: t7.to,
595
+ description: "",
596
+ roles: [],
597
+ auto: false,
598
+ conditions: t7.conditions || [],
599
+ actions: (t7.actions || []).map(convertAction),
600
+ required_fields: [],
601
+ priority: 0
602
+ }));
603
+ const state_data = {};
604
+ for (const f of fields) {
605
+ state_data[f.name] = f.default_value;
606
+ }
607
+ return {
608
+ id: `def-${ir.slug}`,
609
+ slug: ir.slug,
610
+ name: ir.name,
611
+ version: ir.version,
612
+ description: ir.description || "",
613
+ category: ir.category,
614
+ states,
615
+ transitions,
616
+ fields,
617
+ state_data,
618
+ roles: [],
619
+ child_definitions: [],
620
+ tags: ir.tags || [],
621
+ metadata: ir.metadata || {},
622
+ config: {},
623
+ is_immutable: false
624
+ };
625
+ }
626
+ function compilerStateToWorkflow(state, metadata) {
627
+ return {
628
+ slug: metadata.slug || "workflow",
629
+ name: metadata.name || "Workflow",
630
+ version: metadata.version || "0.1.0",
631
+ description: metadata.description,
632
+ category: metadata.category || "workflow",
633
+ fields: state.fields || [],
634
+ states: state.states || /* @__PURE__ */ new Map(),
635
+ transitions: state.transitions || [],
636
+ events: state.events || [],
637
+ experience: state.experience
638
+ };
639
+ }
640
+
641
+ // src/babel/visitor.ts
642
+ function createVisitor(_options = {}) {
643
+ return {
644
+ Program: {
645
+ // Initialize compiler state at program entry
646
+ enter(_path, state) {
647
+ const compilerState = {
648
+ fields: [],
649
+ states: /* @__PURE__ */ new Map(),
650
+ transitions: [],
651
+ events: [],
652
+ actionCounter: 0,
653
+ metadata: {}
654
+ };
655
+ const extractMetadataFromComments = (comments) => {
656
+ for (const comment of comments) {
657
+ if (comment.type === "CommentBlock") {
658
+ const lines = comment.value.split("\n");
659
+ for (const line of lines) {
660
+ const workflowMatch = line.match(/@workflow\s+(.+)/);
661
+ if (workflowMatch) {
662
+ const rest = workflowMatch[1].trim();
663
+ const kvRegex = /(\w+)="([^"]+)"/g;
664
+ let kvMatch;
665
+ let hasKV = false;
666
+ while ((kvMatch = kvRegex.exec(rest)) !== null) {
667
+ hasKV = true;
668
+ const [, key, val] = kvMatch;
669
+ if (key === "slug") compilerState.metadata.slug = val;
670
+ else if (key === "version") compilerState.metadata.version = val;
671
+ else if (key === "category") compilerState.metadata.category = val;
672
+ else if (key === "description") compilerState.metadata.description = val;
673
+ }
674
+ if (!hasKV) {
675
+ compilerState.metadata.slug = rest;
676
+ }
677
+ continue;
678
+ }
679
+ const match = line.match(/@(\w+)\s+(.+)/);
680
+ if (match) {
681
+ const [, tag, value] = match;
682
+ if (tag === "version") compilerState.metadata.version = value.trim();
683
+ if (tag === "category") compilerState.metadata.category = value.trim();
684
+ if (tag === "description") compilerState.metadata.description = value.trim();
685
+ }
686
+ }
687
+ }
688
+ }
689
+ };
690
+ const program = _path.node;
691
+ const leadingComments = program.leadingComments || [];
692
+ extractMetadataFromComments(leadingComments);
693
+ const exportDeclaration = program.body.find(
694
+ (node) => t6.isExportNamedDeclaration(node) || t6.isExportDefaultDeclaration(node)
695
+ );
696
+ if (exportDeclaration) {
697
+ if (t6.isExportNamedDeclaration(exportDeclaration)) {
698
+ const declaration = exportDeclaration.declaration;
699
+ if (t6.isFunctionDeclaration(declaration)) {
700
+ if (declaration.id) {
701
+ compilerState.metadata.name = declaration.id.name;
702
+ }
703
+ if (declaration.leadingComments) {
704
+ extractMetadataFromComments(declaration.leadingComments);
705
+ }
706
+ }
707
+ } else if (t6.isExportDefaultDeclaration(exportDeclaration)) {
708
+ const declaration = exportDeclaration.declaration;
709
+ if (t6.isFunctionDeclaration(declaration)) {
710
+ if (declaration.id) {
711
+ compilerState.metadata.name = declaration.id.name;
712
+ }
713
+ if (declaration.leadingComments) {
714
+ extractMetadataFromComments(declaration.leadingComments);
715
+ }
716
+ } else if (t6.isIdentifier(declaration)) {
717
+ compilerState.metadata.name = declaration.name;
718
+ }
719
+ }
720
+ }
721
+ if (!compilerState.metadata.slug && state.filename) {
722
+ const fileName = state.filename.split("/").pop() || "";
723
+ compilerState.metadata.slug = fileName.replace(/\.workflow\.(tsx?|jsx?)$/, "").replace(/\.(tsx?|jsx?)$/, "").replace(/([A-Z])/g, "-$1").toLowerCase().replace(/^-/, "");
724
+ }
725
+ Object.assign(state, compilerState);
726
+ },
727
+ // After all extraction, emit Pure Form JSON
728
+ exit(_path, state) {
729
+ const compilerState = state;
730
+ const extracted = compilerStateToWorkflow(compilerState, compilerState.metadata);
731
+ const ir = emitPureForm(extracted);
732
+ const definition = emitWorkflowDefinition(extracted);
733
+ if (!state.file.metadata) state.file.metadata = {};
734
+ state.file.metadata.mindmatrixIR = ir;
735
+ state.file.metadata.mindmatrixDefinition = definition;
736
+ }
737
+ },
738
+ // Extract metadata from function declarations with JSDoc
739
+ FunctionDeclaration(path, state) {
740
+ const comments = path.node.leadingComments || [];
741
+ const compilerState = state;
742
+ for (const comment of comments) {
743
+ if (comment.type === "CommentBlock") {
744
+ const lines = comment.value.split("\n");
745
+ for (const line of lines) {
746
+ const workflowMatch = line.match(/@workflow\s+(.+)/);
747
+ if (workflowMatch) {
748
+ const rest = workflowMatch[1].trim();
749
+ const kvRegex = /(\w+)="([^"]+)"/g;
750
+ let kvMatch;
751
+ let hasKV = false;
752
+ while ((kvMatch = kvRegex.exec(rest)) !== null) {
753
+ hasKV = true;
754
+ const [, key, val] = kvMatch;
755
+ if (key === "slug") compilerState.metadata.slug = val;
756
+ else if (key === "version") compilerState.metadata.version = val;
757
+ else if (key === "category") compilerState.metadata.category = val;
758
+ else if (key === "description") compilerState.metadata.description = val;
759
+ }
760
+ if (!hasKV) compilerState.metadata.slug = rest;
761
+ continue;
762
+ }
763
+ const match = line.match(/@(\w+)\s+(.+)/);
764
+ if (match) {
765
+ const [, tag, value] = match;
766
+ if (tag === "version") compilerState.metadata.version = value.trim();
767
+ if (tag === "category") compilerState.metadata.category = value.trim();
768
+ if (tag === "description") compilerState.metadata.description = value.trim();
769
+ }
770
+ }
771
+ }
772
+ }
773
+ },
774
+ // Extract useState calls
775
+ CallExpression(path, state) {
776
+ const callee = path.node.callee;
777
+ if (!t6.isIdentifier(callee)) return;
778
+ switch (callee.name) {
779
+ case "useState":
780
+ extractStates(path, state);
781
+ break;
782
+ case "useOnEnter":
783
+ case "useOnExit":
784
+ extractEffects(path, state);
785
+ break;
786
+ case "useTransition":
787
+ extractTransitions(path, state);
788
+ break;
789
+ case "useOnEvent":
790
+ extractEvents(path, state);
791
+ break;
792
+ }
793
+ },
794
+ // Extract JSX from function component return
795
+ ReturnStatement(path, state) {
796
+ if (t6.isJSXElement(path.node.argument) || t6.isJSXFragment(path.node.argument)) {
797
+ extractComponents(path, state);
798
+ }
799
+ }
800
+ };
801
+ }
802
+
803
+ // src/babel/index.ts
804
+ function babelPlugin(api, options = {}) {
805
+ api.assertVersion(7);
806
+ return {
807
+ name: "mindmatrix-react",
808
+ visitor: createVisitor(options)
809
+ };
810
+ }
811
+
812
+ export {
813
+ extractStates,
814
+ extractEffects,
815
+ extractTransitions,
816
+ extractEvents,
817
+ extractComponents,
818
+ emitPureForm,
819
+ compilerStateToWorkflow,
820
+ createVisitor,
821
+ babelPlugin
822
+ };