@mmapp/react-compiler 0.1.0-alpha.1

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 (314) hide show
  1. package/README.md +107 -0
  2. package/compile-blueprint-chat.mjs +99 -0
  3. package/compile-blueprint-glass-console.mjs +98 -0
  4. package/compile-chat-defs.mjs +92 -0
  5. package/dist/babel/index.d.mts +3 -0
  6. package/dist/babel/index.d.ts +3 -0
  7. package/dist/babel/index.js +4851 -0
  8. package/dist/babel/index.mjs +7 -0
  9. package/dist/chunk-26U577GB.mjs +3465 -0
  10. package/dist/chunk-2FBDFAX6.mjs +2362 -0
  11. package/dist/chunk-2L4QSMXG.mjs +175 -0
  12. package/dist/chunk-2REDFOER.mjs +931 -0
  13. package/dist/chunk-46YKSHQR.mjs +175 -0
  14. package/dist/chunk-4XHK6FWL.mjs +2058 -0
  15. package/dist/chunk-5M7DKKBC.mjs +215 -0
  16. package/dist/chunk-5VNJ7C6N.mjs +154 -0
  17. package/dist/chunk-6CQOAAMV.mjs +1803 -0
  18. package/dist/chunk-6SEVAAVT.mjs +3516 -0
  19. package/dist/chunk-6YLR5ZDA.mjs +2829 -0
  20. package/dist/chunk-AOGY2GK6.mjs +3292 -0
  21. package/dist/chunk-AXXUXRNA.mjs +1434 -0
  22. package/dist/chunk-CHLVKMQW.mjs +175 -0
  23. package/dist/chunk-CKGOZAB7.mjs +939 -0
  24. package/dist/chunk-D34RAZUX.mjs +2223 -0
  25. package/dist/chunk-EQGA6A6D.mjs +121 -0
  26. package/dist/chunk-EY2CSXYA.mjs +822 -0
  27. package/dist/chunk-FIQ65CDR.mjs +925 -0
  28. package/dist/chunk-FOZXJFAR.mjs +186 -0
  29. package/dist/chunk-FX6URXWN.mjs +186 -0
  30. package/dist/chunk-G7SMOWOL.mjs +828 -0
  31. package/dist/chunk-GGB4G5YY.mjs +175 -0
  32. package/dist/chunk-HLRGCCIL.mjs +4839 -0
  33. package/dist/chunk-HOIUP6IF.mjs +690 -0
  34. package/dist/chunk-I3AU7GRD.mjs +120 -0
  35. package/dist/chunk-ILFGMUVD.mjs +1933 -0
  36. package/dist/chunk-IPTX5MJU.mjs +3223 -0
  37. package/dist/chunk-ITGUSH2Z.mjs +2783 -0
  38. package/dist/chunk-IXHBCAMF.mjs +3306 -0
  39. package/dist/chunk-J7TWJ3TM.mjs +2784 -0
  40. package/dist/chunk-JDPLDGVF.mjs +4810 -0
  41. package/dist/chunk-K53XP2DL.mjs +148 -0
  42. package/dist/chunk-K5HX2SVL.mjs +1902 -0
  43. package/dist/chunk-KFGYOOVS.mjs +214 -0
  44. package/dist/chunk-KFVVOS5N.mjs +925 -0
  45. package/dist/chunk-L2OZ4CDV.mjs +113 -0
  46. package/dist/chunk-MIZV3TAN.mjs +3293 -0
  47. package/dist/chunk-NKKLQE5V.mjs +148 -0
  48. package/dist/chunk-NOW23XFZ.mjs +186 -0
  49. package/dist/chunk-NRXQKQ74.mjs +148 -0
  50. package/dist/chunk-OWI6XWCD.mjs +3375 -0
  51. package/dist/chunk-PRUMNNDI.mjs +3192 -0
  52. package/dist/chunk-QTBD5B3F.mjs +148 -0
  53. package/dist/chunk-SKSDPPNT.mjs +3788 -0
  54. package/dist/chunk-SP2YUS33.mjs +186 -0
  55. package/dist/chunk-SU4E6E7B.mjs +3153 -0
  56. package/dist/chunk-SYUUKW5A.mjs +3379 -0
  57. package/dist/chunk-UL2XZEMA.mjs +3128 -0
  58. package/dist/chunk-XMWUHQVV.mjs +939 -0
  59. package/dist/chunk-XZNEDRGN.mjs +3876 -0
  60. package/dist/chunk-Y6FXYEAI.mjs +10 -0
  61. package/dist/chunk-YFS6JMYO.mjs +3342 -0
  62. package/dist/chunk-Z6AIQ4KL.mjs +113 -0
  63. package/dist/cli/index.d.mts +1 -0
  64. package/dist/cli/index.d.ts +1 -0
  65. package/dist/cli/index.js +11585 -0
  66. package/dist/cli/index.mjs +701 -0
  67. package/dist/codemod/cli.d.mts +1 -0
  68. package/dist/codemod/cli.d.ts +1 -0
  69. package/dist/codemod/cli.js +1104 -0
  70. package/dist/codemod/cli.mjs +157 -0
  71. package/dist/codemod/index.d.mts +148 -0
  72. package/dist/codemod/index.d.ts +148 -0
  73. package/dist/codemod/index.js +981 -0
  74. package/dist/codemod/index.mjs +25 -0
  75. package/dist/dev-server-Bs_sz2DG.d.mts +111 -0
  76. package/dist/dev-server-Bs_sz2DG.d.ts +111 -0
  77. package/dist/dev-server-CjoufJ-u.d.mts +109 -0
  78. package/dist/dev-server-CjoufJ-u.d.ts +109 -0
  79. package/dist/dev-server.d.mts +3 -0
  80. package/dist/dev-server.d.ts +3 -0
  81. package/dist/dev-server.js +7603 -0
  82. package/dist/dev-server.mjs +11 -0
  83. package/dist/envelope-DD7v0v6E.d.mts +265 -0
  84. package/dist/envelope-DD7v0v6E.d.ts +265 -0
  85. package/dist/envelope-vCVjrHlo.d.mts +265 -0
  86. package/dist/envelope-vCVjrHlo.d.ts +265 -0
  87. package/dist/envelope.d.mts +2 -0
  88. package/dist/envelope.d.ts +2 -0
  89. package/dist/envelope.js +5184 -0
  90. package/dist/envelope.mjs +9 -0
  91. package/dist/index-B5gSgvnd.d.mts +44 -0
  92. package/dist/index-B5gSgvnd.d.ts +44 -0
  93. package/dist/index-Bs0MnR54.d.mts +103 -0
  94. package/dist/index-Bs0MnR54.d.ts +103 -0
  95. package/dist/index-DR0nNc_f.d.mts +101 -0
  96. package/dist/index-DR0nNc_f.d.ts +101 -0
  97. package/dist/index-revho_gS.d.mts +104 -0
  98. package/dist/index-revho_gS.d.ts +104 -0
  99. package/dist/index.d.mts +1099 -0
  100. package/dist/index.d.ts +1099 -0
  101. package/dist/index.js +10162 -0
  102. package/dist/index.mjs +372 -0
  103. package/dist/init-IXEE2RCF.mjs +340 -0
  104. package/dist/project-compiler-EGJUTAJU.mjs +10 -0
  105. package/dist/project-compiler-VFR6CSDX.mjs +10 -0
  106. package/dist/project-decompiler-5GY2KSG4.mjs +7 -0
  107. package/dist/pull-A2QUHW4K.mjs +109 -0
  108. package/dist/pull-JBEQWVPE.mjs +109 -0
  109. package/dist/testing/index.d.mts +211 -0
  110. package/dist/testing/index.d.ts +211 -0
  111. package/dist/testing/index.js +5106 -0
  112. package/dist/testing/index.mjs +247 -0
  113. package/dist/vite/index.d.mts +59 -0
  114. package/dist/vite/index.d.ts +59 -0
  115. package/dist/vite/index.js +5023 -0
  116. package/dist/vite/index.mjs +8 -0
  117. package/examples/README.md +72 -0
  118. package/examples/authentication/main.workflow.tsx +139 -0
  119. package/examples/authentication/mm.config.ts +22 -0
  120. package/examples/authentication/models/auth.ts +45 -0
  121. package/examples/authentication/pages/LoginPage.tsx +79 -0
  122. package/examples/authentication/pages/SignupPage.tsx +87 -0
  123. package/examples/counter.workflow.tsx +65 -0
  124. package/examples/dashboard.workflow.tsx +419 -0
  125. package/examples/invoice-approval/actions/invoice.server.ts +72 -0
  126. package/examples/invoice-approval/main.workflow.tsx +168 -0
  127. package/examples/invoice-approval/mm.config.ts +18 -0
  128. package/examples/invoice-approval/models/invoice.ts +46 -0
  129. package/examples/invoice-approval/pages/InvoiceDetailPage.tsx +175 -0
  130. package/examples/invoice-approval/pages/InvoiceFormPage.tsx +198 -0
  131. package/examples/invoice-approval/pages/InvoiceListPage.tsx +141 -0
  132. package/examples/todo-app.workflow.tsx +131 -0
  133. package/examples/uber-app/actions/matching.server.ts +177 -0
  134. package/examples/uber-app/actions/notifications.server.ts +176 -0
  135. package/examples/uber-app/actions/payments.server.ts +184 -0
  136. package/examples/uber-app/actions/pricing.server.ts +176 -0
  137. package/examples/uber-app/app/admin/analytics.tsx +102 -0
  138. package/examples/uber-app/app/admin/fleet.tsx +102 -0
  139. package/examples/uber-app/app/admin/surge-pricing.tsx +95 -0
  140. package/examples/uber-app/app/driver/dashboard.tsx +87 -0
  141. package/examples/uber-app/app/driver/earnings.tsx +101 -0
  142. package/examples/uber-app/app/driver/navigation.tsx +94 -0
  143. package/examples/uber-app/app/driver/ride-acceptance.tsx +103 -0
  144. package/examples/uber-app/app/rider/home.tsx +109 -0
  145. package/examples/uber-app/app/rider/payment-methods.tsx +134 -0
  146. package/examples/uber-app/app/rider/ride-history.tsx +90 -0
  147. package/examples/uber-app/app/rider/ride-tracking.tsx +108 -0
  148. package/examples/uber-app/components/DriverCard.tsx +176 -0
  149. package/examples/uber-app/components/MapView.tsx +216 -0
  150. package/examples/uber-app/components/RatingStars.tsx +227 -0
  151. package/examples/uber-app/components/RideCard.tsx +167 -0
  152. package/examples/uber-app/mm.config.ts +30 -0
  153. package/examples/uber-app/models/location.model.ts +70 -0
  154. package/examples/uber-app/models/payment.model.ts +87 -0
  155. package/examples/uber-app/models/rating.model.ts +54 -0
  156. package/examples/uber-app/models/ride.model.ts +118 -0
  157. package/examples/uber-app/models/user.model.ts +66 -0
  158. package/examples/uber-app/models/vehicle.model.ts +63 -0
  159. package/examples/uber-app/tests/payment.test.tsx +129 -0
  160. package/examples/uber-app/tests/ride-flow.test.tsx +123 -0
  161. package/examples/uber-app/workflows/dispute-resolution.workflow.tsx +205 -0
  162. package/examples/uber-app/workflows/driver-onboarding.workflow.tsx +227 -0
  163. package/examples/uber-app/workflows/payment-processing.workflow.tsx +223 -0
  164. package/examples/uber-app/workflows/ride-request.workflow.tsx +194 -0
  165. package/package.json +77 -0
  166. package/package.json.backup +86 -0
  167. package/scripts/decompile.ts +226 -0
  168. package/scripts/seed-auth.ts +267 -0
  169. package/scripts/seed-uber.ts +248 -0
  170. package/scripts/validate-uber.ts +119 -0
  171. package/seed-blueprint-chat.mjs +444 -0
  172. package/seed-blueprint-glass-console.mjs +445 -0
  173. package/seed-compiled.mjs +318 -0
  174. package/src/RoundTripValidator.ts +400 -0
  175. package/src/__tests__/atom-rendering-coverage.test.ts +680 -0
  176. package/src/__tests__/auth-module-compilation.test.ts +247 -0
  177. package/src/__tests__/auth-template-compilation.test.ts +589 -0
  178. package/src/__tests__/change-extractor.test.ts +142 -0
  179. package/src/__tests__/cli-pull.test.ts +73 -0
  180. package/src/__tests__/cli-test.test.ts +72 -0
  181. package/src/__tests__/component-extractor.test.ts +331 -0
  182. package/src/__tests__/context-extractor.test.ts +145 -0
  183. package/src/__tests__/decompiler.test.ts +718 -0
  184. package/src/__tests__/define-blueprint.test.ts +133 -0
  185. package/src/__tests__/definition-validator.test.ts +519 -0
  186. package/src/__tests__/during-extractor.test.ts +152 -0
  187. package/src/__tests__/effect-extractor.test.ts +107 -0
  188. package/src/__tests__/event-emission.test.ts +127 -0
  189. package/src/__tests__/examples.test.ts +236 -0
  190. package/src/__tests__/full-blueprint-coverage.test.ts +1221 -0
  191. package/src/__tests__/golden-suite.test.ts +403 -0
  192. package/src/__tests__/grammar-island-extractor.test.ts +289 -0
  193. package/src/__tests__/instance-key.test.ts +82 -0
  194. package/src/__tests__/ir-migration.test.ts +255 -0
  195. package/src/__tests__/lock-file.test.ts +117 -0
  196. package/src/__tests__/model-extractor.test.ts +195 -0
  197. package/src/__tests__/model-field-acl.test.ts +237 -0
  198. package/src/__tests__/model-hooks.test.ts +130 -0
  199. package/src/__tests__/model-ref-resolution.test.ts +268 -0
  200. package/src/__tests__/model-roundtrip.test.ts +502 -0
  201. package/src/__tests__/model-runtime.test.ts +112 -0
  202. package/src/__tests__/model-transitions.test.ts +183 -0
  203. package/src/__tests__/nrt-action-trace.test.ts +391 -0
  204. package/src/__tests__/pipeline-hardening.test.ts +413 -0
  205. package/src/__tests__/project-compiler.test.ts +546 -0
  206. package/src/__tests__/project-decompiler.test.ts +343 -0
  207. package/src/__tests__/query-compilation.test.ts +145 -0
  208. package/src/__tests__/round-trip/PLAN.md +158 -0
  209. package/src/__tests__/round-trip/README.md +52 -0
  210. package/src/__tests__/round-trip/RESULTS.md +86 -0
  211. package/src/__tests__/round-trip/fixtures/data-heavy/main.workflow.tsx +55 -0
  212. package/src/__tests__/round-trip/fixtures/data-heavy/mm.config.ts +11 -0
  213. package/src/__tests__/round-trip/fixtures/data-heavy/models/contact.ts +54 -0
  214. package/src/__tests__/round-trip/fixtures/full-workflow/main.workflow.tsx +79 -0
  215. package/src/__tests__/round-trip/fixtures/full-workflow/mm.config.ts +12 -0
  216. package/src/__tests__/round-trip/fixtures/full-workflow/models/order.ts +50 -0
  217. package/src/__tests__/round-trip/fixtures/simple-crud/main.workflow.tsx +25 -0
  218. package/src/__tests__/round-trip/fixtures/simple-crud/mm.config.ts +11 -0
  219. package/src/__tests__/round-trip/fixtures/simple-crud/models/task.ts +32 -0
  220. package/src/__tests__/round-trip/fixtures/view-heavy/main.workflow.tsx +79 -0
  221. package/src/__tests__/round-trip/fixtures/view-heavy/mm.config.ts +10 -0
  222. package/src/__tests__/round-trip/round-trip.test.ts +2598 -0
  223. package/src/__tests__/round-trip-ir.test.ts +300 -0
  224. package/src/__tests__/round-trip.test.ts +1212 -0
  225. package/src/__tests__/route-merging.test.ts +372 -0
  226. package/src/__tests__/router-composition.test.ts +489 -0
  227. package/src/__tests__/router-extractor.test.ts +176 -0
  228. package/src/__tests__/server-action-extractor.test.ts +128 -0
  229. package/src/__tests__/smart-type-inference.test.ts +365 -0
  230. package/src/__tests__/source-envelope.test.ts +284 -0
  231. package/src/__tests__/source-fidelity.test.ts +516 -0
  232. package/src/__tests__/state-extractor.test.ts +115 -0
  233. package/src/__tests__/strict-mode.test.ts +227 -0
  234. package/src/__tests__/transition-effect-extractor.test.ts +119 -0
  235. package/src/__tests__/transition-extractor.test.ts +68 -0
  236. package/src/__tests__/ts-to-expression.test.ts +462 -0
  237. package/src/__tests__/type-generator.test.ts +201 -0
  238. package/src/__tests__/uber-validation.test.ts +502 -0
  239. package/src/action-compiler.ts +361 -0
  240. package/src/babel/emitters/experience-transform.ts +199 -0
  241. package/src/babel/emitters/ir-to-tsx-emitter.ts +110 -0
  242. package/src/babel/emitters/pure-form-emitter.ts +1023 -0
  243. package/src/babel/emitters/runtime-glue-emitter.ts +39 -0
  244. package/src/babel/extractors/change-extractor.ts +199 -0
  245. package/src/babel/extractors/component-extractor.ts +907 -0
  246. package/src/babel/extractors/computed-extractor.ts +262 -0
  247. package/src/babel/extractors/context-extractor.ts +277 -0
  248. package/src/babel/extractors/during-extractor.ts +295 -0
  249. package/src/babel/extractors/effect-extractor.ts +340 -0
  250. package/src/babel/extractors/event-extractor.ts +235 -0
  251. package/src/babel/extractors/grammar-island-extractor.ts +302 -0
  252. package/src/babel/extractors/model-extractor.ts +1018 -0
  253. package/src/babel/extractors/router-extractor.ts +303 -0
  254. package/src/babel/extractors/server-action-extractor.ts +173 -0
  255. package/src/babel/extractors/server-action-hook-extractor.ts +72 -0
  256. package/src/babel/extractors/server-state-extractor.ts +88 -0
  257. package/src/babel/extractors/state-extractor.ts +214 -0
  258. package/src/babel/extractors/transition-effect-extractor.ts +176 -0
  259. package/src/babel/extractors/transition-extractor.ts +143 -0
  260. package/src/babel/index.ts +24 -0
  261. package/src/babel/transpilers/ts-to-expression.ts +674 -0
  262. package/src/babel/visitor.ts +807 -0
  263. package/src/cli/auth.ts +255 -0
  264. package/src/cli/build.ts +288 -0
  265. package/src/cli/deploy.ts +206 -0
  266. package/src/cli/index.ts +328 -0
  267. package/src/cli/init.ts +388 -0
  268. package/src/cli/installer.ts +261 -0
  269. package/src/cli/lock-file.ts +94 -0
  270. package/src/cli/mmrc.ts +22 -0
  271. package/src/cli/pull.ts +172 -0
  272. package/src/cli/registry-client.ts +175 -0
  273. package/src/cli/test.ts +397 -0
  274. package/src/cli/type-generator.ts +243 -0
  275. package/src/codemod/__tests__/forward.test.ts +239 -0
  276. package/src/codemod/__tests__/reverse.test.ts +145 -0
  277. package/src/codemod/__tests__/round-trip.test.ts +137 -0
  278. package/src/codemod/annotation.ts +97 -0
  279. package/src/codemod/classify.ts +197 -0
  280. package/src/codemod/cli.ts +207 -0
  281. package/src/codemod/control-flow.ts +409 -0
  282. package/src/codemod/forward.ts +244 -0
  283. package/src/codemod/import-manager.ts +171 -0
  284. package/src/codemod/index.ts +120 -0
  285. package/src/codemod/reverse.ts +197 -0
  286. package/src/codemod/rules.ts +174 -0
  287. package/src/codemod/state-transform.ts +126 -0
  288. package/src/decompiler/ast-builder.ts +538 -0
  289. package/src/decompiler/config-generator.ts +151 -0
  290. package/src/decompiler/index.ts +315 -0
  291. package/src/decompiler/project-decompiler.ts +1776 -0
  292. package/src/decompiler/project.ts +862 -0
  293. package/src/decompiler/split-strategy.ts +140 -0
  294. package/src/decompiler/state-emitter.ts +1053 -0
  295. package/src/decompiler/sx-emitter.ts +318 -0
  296. package/src/decompiler/workspace-hydrator.ts +189 -0
  297. package/src/dev-server.ts +238 -0
  298. package/src/envelope/fs-tree.ts +217 -0
  299. package/src/envelope/source-envelope.ts +264 -0
  300. package/src/envelope.ts +315 -0
  301. package/src/incremental-compiler.ts +401 -0
  302. package/src/index.ts +99 -0
  303. package/src/model-compiler.ts +277 -0
  304. package/src/project-compiler.ts +1629 -0
  305. package/src/route-extractor.ts +333 -0
  306. package/src/testing/index.ts +32 -0
  307. package/src/testing/snapshot.ts +252 -0
  308. package/src/testing/test-utils.ts +226 -0
  309. package/src/types.ts +68 -0
  310. package/src/vite/index.ts +288 -0
  311. package/test-compile.mjs +142 -0
  312. package/tsconfig.json +25 -0
  313. package/tsup.config.ts +23 -0
  314. package/vitest.config.ts +9 -0
@@ -0,0 +1,248 @@
1
+ #!/usr/bin/env npx tsx
2
+ /**
3
+ * Seed Uber Rideshare Example — Compiles the uber-app example and inserts
4
+ * all workflow definitions (parent blueprint + children) into PostgreSQL.
5
+ *
6
+ * Usage: npx tsx packages/react-compiler/scripts/seed-uber.ts
7
+ *
8
+ * Reads DATABASE_URL from mm-core/mm-server.env.
9
+ * Compiles examples/uber-app/ via compileProject().
10
+ * Inserts parent blueprint + all child definitions (workflows, data models, router).
11
+ */
12
+
13
+ import * as fs from 'fs';
14
+ import * as path from 'path';
15
+ import { randomUUID } from 'crypto';
16
+ import pg from 'pg';
17
+ import { compileProject } from '../src/project-compiler';
18
+
19
+ const UBER_APP_DIR = path.resolve(__dirname, '../../blueprint-uber');
20
+ const ENV_FILE = path.resolve(__dirname, '../../../mm-core/mm-server.env');
21
+
22
+ // ── Read all .ts/.tsx files recursively ──────────────────────────────────────
23
+
24
+ function readAllFiles(dir: string, prefix = ''): Record<string, string> {
25
+ const result: Record<string, string> = {};
26
+ const entries = fs.readdirSync(dir, { withFileTypes: true });
27
+ for (const entry of entries) {
28
+ const relPath = prefix ? prefix + '/' + entry.name : entry.name;
29
+ const absPath = path.join(dir, entry.name);
30
+ if (entry.isDirectory()) {
31
+ Object.assign(result, readAllFiles(absPath, relPath));
32
+ } else if (/\.(ts|tsx)$/.test(entry.name)) {
33
+ result[relPath] = fs.readFileSync(absPath, 'utf-8');
34
+ }
35
+ }
36
+ return result;
37
+ }
38
+
39
+ // ── Parse DATABASE_URL from env file ─────────────────────────────────────────
40
+
41
+ function readDatabaseUrl(): string {
42
+ const content = fs.readFileSync(ENV_FILE, 'utf-8');
43
+ for (const line of content.split('\n')) {
44
+ const match = line.match(/^DATABASE_URL=(.+)$/);
45
+ if (match) return match[1].trim();
46
+ }
47
+ throw new Error(`DATABASE_URL not found in ${ENV_FILE}`);
48
+ }
49
+
50
+ // ── Insert a single definition row ───────────────────────────────────────────
51
+
52
+ async function insertDefinition(
53
+ client: pg.Client,
54
+ id: string,
55
+ def: {
56
+ slug: string;
57
+ name: string;
58
+ version?: string;
59
+ description?: string;
60
+ category: string;
61
+ states?: unknown[];
62
+ transitions?: unknown[];
63
+ fields?: unknown[];
64
+ roles?: unknown[];
65
+ metadata?: Record<string, unknown>;
66
+ experience?: unknown;
67
+ tags?: Array<{ tag_name: string }>;
68
+ },
69
+ parentId: string | null,
70
+ ) {
71
+ const experienceJson = def.experience ? JSON.stringify(def.experience) : null;
72
+ await client.query(
73
+ `INSERT INTO workflow_definitions (
74
+ id, slug, name, version, description, category,
75
+ states, transitions, fields, roles,
76
+ metadata, experience, view,
77
+ visibility, publish_status, is_immutable,
78
+ owner_type, is_primary_variant,
79
+ sub_workflow_version_strategy,
80
+ instantiation_count, active_instance_count,
81
+ fork_count, rating_sum, rating_count,
82
+ featured, allows_forks, allows_sub_workflow_contributions,
83
+ tenant_id, inline_tags,
84
+ parent_definition_id,
85
+ created_at, updated_at
86
+ ) VALUES (
87
+ $1, $2, $3, $4, $5, $6,
88
+ $7, $8, $9, $10,
89
+ $11, $12, $12,
90
+ 'PUBLIC'::"WorkflowVisibility",
91
+ 'PUBLISHED'::"WorkflowPublishStatus",
92
+ false,
93
+ 'SYSTEM'::"WorkflowOwnerType",
94
+ true,
95
+ 'LATEST'::"WorkflowVersionStrategy",
96
+ 0, 0,
97
+ 0, 0, 0,
98
+ false, true, false,
99
+ 'default', '[]'::jsonb,
100
+ $13,
101
+ NOW(), NOW()
102
+ )`,
103
+ [
104
+ id,
105
+ def.slug,
106
+ def.name,
107
+ def.version || '1.0.0',
108
+ def.description || null,
109
+ def.category || 'workflow',
110
+ JSON.stringify(def.states || []),
111
+ JSON.stringify(def.transitions || []),
112
+ JSON.stringify(def.fields || []),
113
+ JSON.stringify(def.roles || []),
114
+ JSON.stringify(def.metadata || {}),
115
+ experienceJson,
116
+ parentId,
117
+ ],
118
+ );
119
+ }
120
+
121
+ // ── Main ─────────────────────────────────────────────────────────────────────
122
+
123
+ async function main() {
124
+ // 1. Read source files
125
+ console.log('Reading uber-app example files...');
126
+ const files = readAllFiles(UBER_APP_DIR);
127
+ const fileCount = Object.keys(files).length;
128
+ console.log(` ${fileCount} files loaded\n`);
129
+
130
+ // 2. Compile
131
+ console.log('Compiling project...');
132
+ const result = compileProject(files);
133
+
134
+ if (result.errors.length > 0) {
135
+ console.warn(`\n ${result.errors.length} compilation error(s):`);
136
+ for (const err of result.errors) {
137
+ console.warn(` ${err.file}: ${err.message}`);
138
+ }
139
+ console.log();
140
+ }
141
+ if (result.warnings.length > 0) {
142
+ console.warn(` ${result.warnings.length} warning(s)\n`);
143
+ }
144
+
145
+ const parentIR = result.ir;
146
+ const children = result.childDefinitions;
147
+
148
+ console.log(` Parent blueprint: ${parentIR.slug} (${parentIR.category})`);
149
+ console.log(` Child definitions: ${children.length}`);
150
+ for (const child of children) {
151
+ console.log(` - ${child.slug} (${child.category}) — ${child.states?.length || 0} states, ${child.fields?.length || 0} fields`);
152
+ }
153
+ console.log();
154
+
155
+ // 3. Connect to database
156
+ const databaseUrl = readDatabaseUrl();
157
+ console.log('Connecting to database...');
158
+ const client = new pg.Client({ connectionString: databaseUrl });
159
+ await client.connect();
160
+ console.log(' Connected.\n');
161
+
162
+ try {
163
+ // 4. Delete any existing definitions with these slugs (idempotent re-runs)
164
+ const allDefs = [parentIR, ...children];
165
+ const allSlugs = allDefs.map(d => d.slug);
166
+
167
+ console.log('Cleaning up existing definitions...');
168
+ const deleteResult = await client.query(
169
+ `DELETE FROM workflow_definitions WHERE slug = ANY($1) RETURNING slug`,
170
+ [allSlugs],
171
+ );
172
+ if (deleteResult.rowCount && deleteResult.rowCount > 0) {
173
+ console.log(` Removed ${deleteResult.rowCount} existing row(s)\n`);
174
+ } else {
175
+ console.log(' None found (fresh insert)\n');
176
+ }
177
+
178
+ // 5. Generate IDs
179
+ const idMap: Record<string, string> = {};
180
+ for (const def of allDefs) {
181
+ idMap[def.slug] = randomUUID();
182
+ }
183
+
184
+ const parentId = idMap[parentIR.slug];
185
+ const childIds = children.map(c => idMap[c.slug]);
186
+
187
+ // 6. Attach child IDs to parent metadata
188
+ const parentMeta = { ...(parentIR.metadata as Record<string, unknown> || {}) };
189
+ parentMeta.childDefinitionIds = childIds;
190
+ parentMeta.childSlugs = children.map(c => c.slug);
191
+
192
+ // 7. Insert parent blueprint (with composed experience from compiler)
193
+ console.log('Inserting definitions...');
194
+ const parentExperience = (parentIR as any).experience || null;
195
+ await insertDefinition(client, parentId, {
196
+ ...parentIR,
197
+ metadata: parentMeta,
198
+ experience: parentExperience,
199
+ }, null);
200
+ const expLabel = parentExperience ? ' [+experience]' : '';
201
+ console.log(` + ${parentIR.slug} (${parentIR.category})${expLabel} → ${parentId}`);
202
+
203
+ // 8. Insert children with parent_definition_id (with experience from compiler)
204
+ for (const child of children) {
205
+ const childExperience = (child as any).experience || null;
206
+ const childExpLabel = childExperience ? ' [+experience]' : '';
207
+ await insertDefinition(client, idMap[child.slug], {
208
+ ...child,
209
+ experience: childExperience,
210
+ }, parentId);
211
+ console.log(` + ${child.slug} (${child.category})${childExpLabel} → ${idMap[child.slug]}`);
212
+ }
213
+
214
+ // 9. Set child_definitions array on parent
215
+ await client.query(
216
+ `UPDATE workflow_definitions SET child_definitions = $1 WHERE id = $2`,
217
+ [childIds, parentId],
218
+ );
219
+
220
+ // 10. Print summary
221
+ console.log('\n=== Seed Summary ===');
222
+ console.log(`Parent: ${parentIR.slug} → ${parentId}`);
223
+ console.log(` category: ${parentIR.category}`);
224
+ console.log(` states: ${parentIR.states?.length || 0}`);
225
+ console.log(` transitions: ${parentIR.transitions?.length || 0}`);
226
+ console.log(` fields: ${parentIR.fields?.length || 0}`);
227
+ console.log(` roles: ${parentIR.roles?.length || 0}`);
228
+ console.log(` experience: ${parentExperience ? 'yes' : 'none'}`);
229
+ console.log(` children: ${childIds.length}`);
230
+ console.log(` page experiences: ${Object.keys(result.pageExperiences).length}`);
231
+ console.log();
232
+
233
+ for (const child of children) {
234
+ const ce = (child as any).experience;
235
+ console.log(`Child: ${child.slug} → ${idMap[child.slug]}`);
236
+ console.log(` category: ${child.category}, states: ${child.states?.length || 0}, fields: ${child.fields?.length || 0}, experience: ${ce ? 'yes' : 'none'}`);
237
+ }
238
+
239
+ console.log(`\nTotal: ${allDefs.length} definitions inserted.`);
240
+ } finally {
241
+ await client.end();
242
+ }
243
+ }
244
+
245
+ main().catch((err) => {
246
+ console.error('Seed failed:', err.message || err);
247
+ process.exit(1);
248
+ });
@@ -0,0 +1,119 @@
1
+ #!/usr/bin/env npx tsx
2
+ /**
3
+ * Uber App Validation Script — Phase 6
4
+ *
5
+ * Loads the Uber example app, compiles all files, and prints a report.
6
+ * Usage: npx tsx packages/react-compiler/scripts/validate-uber.ts
7
+ */
8
+
9
+ import * as fs from 'fs';
10
+ import * as path from 'path';
11
+ import { compileProject } from '../src/project-compiler';
12
+ import { compileModels } from '../src/model-compiler';
13
+ import { extractRoutes } from '../src/route-extractor';
14
+ import { compileActions } from '../src/action-compiler';
15
+
16
+ const UBER_APP_DIR = path.resolve(__dirname, '../examples/uber-app');
17
+
18
+ function readAllFiles(dir: string, prefix = ''): Record<string, string> {
19
+ const result: Record<string, string> = {};
20
+ const entries = fs.readdirSync(dir, { withFileTypes: true });
21
+ for (const entry of entries) {
22
+ const relPath = prefix ? prefix + '/' + entry.name : entry.name;
23
+ const absPath = path.join(dir, entry.name);
24
+ if (entry.isDirectory()) {
25
+ Object.assign(result, readAllFiles(absPath, relPath));
26
+ } else if (/\.(ts|tsx)$/.test(entry.name)) {
27
+ result[relPath] = fs.readFileSync(absPath, 'utf-8');
28
+ }
29
+ }
30
+ return result;
31
+ }
32
+
33
+ function filterFiles(files: Record<string, string>, prefix: string): Record<string, string> {
34
+ const result: Record<string, string> = {};
35
+ for (const [k, v] of Object.entries(files)) {
36
+ if (k.startsWith(prefix)) result[k] = v;
37
+ }
38
+ return result;
39
+ }
40
+
41
+ // ---------------------------------------------------------------------------
42
+ // Main
43
+ // ---------------------------------------------------------------------------
44
+
45
+ console.log('=== Uber App Validation Report ===\n');
46
+
47
+ const allFiles = readAllFiles(UBER_APP_DIR);
48
+ const fileCount = Object.keys(allFiles).length;
49
+ console.log('Files discovered: ' + fileCount);
50
+
51
+ // Models
52
+ const modelFiles = filterFiles(allFiles, 'models/');
53
+ const modelResults = compileModels(modelFiles);
54
+ console.log('\nModels compiled: ' + modelResults.size);
55
+ for (const [filename, r] of modelResults) {
56
+ console.log(' ' + r.interfaceName + ': ' + r.fieldNames.length + ' fields, ' + r.transitionNames.length + ' transitions, ' + r.stateNames.length + ' states, fieldOptions=' + r.hasFieldOptions);
57
+ }
58
+
59
+ // Routes
60
+ const appFiles = filterFiles(allFiles, 'app/');
61
+ const routeResult = extractRoutes(appFiles);
62
+ console.log('\nRoutes extracted: ' + routeResult.routes.length);
63
+ for (const route of routeResult.routes) {
64
+ console.log(' ' + route.path + ' -> ' + route.stateName + ' (' + route.sourceFile + ')');
65
+ }
66
+
67
+ // Actions
68
+ const actionFiles = filterFiles(allFiles, 'actions/');
69
+ const actionResult = compileActions(actionFiles, { blueprintSlug: 'uber-rideshare' });
70
+ console.log('\nActions registered: ' + actionResult.actions.length);
71
+ for (const action of actionResult.actions) {
72
+ console.log(' ' + action.actionId + ' (' + (action.async ? 'async' : 'sync') + ') -> ' + action.endpoint);
73
+ }
74
+ if (actionResult.errors.length > 0) {
75
+ console.log(' Errors: ' + actionResult.errors.length);
76
+ for (const err of actionResult.errors) {
77
+ console.log(' ' + err.file + ': ' + err.message);
78
+ }
79
+ }
80
+
81
+ // Full project compilation
82
+ console.log('\n--- Full ProjectCompiler ---');
83
+ const result = compileProject(allFiles);
84
+ console.log('Parent slug: ' + result.ir.slug);
85
+ console.log('Parent name: ' + result.ir.name);
86
+ console.log('Parent version: ' + result.ir.version);
87
+ console.log('Child definitions: ' + result.childDefinitions.length);
88
+ console.log('Route table entries: ' + result.routeTable.length);
89
+ console.log('Server actions: ' + result.serverActions.length);
90
+ console.log('Errors: ' + result.errors.length);
91
+ console.log('Warnings: ' + result.warnings.length);
92
+
93
+ const meta = result.ir.metadata as Record<string, unknown>;
94
+ const comp = meta?.composition as Record<string, number> | undefined;
95
+ if (comp) {
96
+ console.log('\nComposition:');
97
+ console.log(' Workflows: ' + comp.workflowCount);
98
+ console.log(' Models: ' + comp.modelCount);
99
+ console.log(' Actions: ' + comp.serverActionCount);
100
+ console.log(' Routes: ' + comp.routeCount);
101
+ console.log(' Total files: ' + comp.totalFiles);
102
+ }
103
+
104
+ // Errors detail
105
+ if (result.errors.length > 0) {
106
+ console.log('\nErrors:');
107
+ for (const err of result.errors) {
108
+ console.log(' [' + err.file + '] ' + err.message);
109
+ }
110
+ }
111
+
112
+ // Summary
113
+ const pass = result.ir.slug === 'uber-rideshare'
114
+ && modelResults.size === 6
115
+ && routeResult.routes.length === 11
116
+ && actionResult.actions.length >= 10;
117
+
118
+ console.log('\n=== ' + (pass ? 'PASS' : 'FAIL') + ' ===');
119
+ process.exit(pass ? 0 : 1);