@bleedingdev/modern-js-create 3.2.0-ultramodern.12 → 3.2.0-ultramodern.121

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 (165) hide show
  1. package/README.md +167 -72
  2. package/bin/run.js +0 -0
  3. package/dist/cjs/create-package-root.cjs +63 -0
  4. package/dist/cjs/index.cjs +528 -0
  5. package/dist/cjs/locale/en.cjs +93 -0
  6. package/dist/cjs/locale/index.cjs +50 -0
  7. package/dist/cjs/locale/zh.cjs +93 -0
  8. package/dist/cjs/ultramodern-package-source.cjs +135 -0
  9. package/dist/cjs/ultramodern-workspace/add-vertical.cjs +337 -0
  10. package/dist/cjs/ultramodern-workspace/app-files.cjs +223 -0
  11. package/dist/cjs/ultramodern-workspace/contracts.cjs +836 -0
  12. package/dist/cjs/ultramodern-workspace/demo-components.cjs +422 -0
  13. package/dist/cjs/ultramodern-workspace/descriptors.cjs +222 -0
  14. package/dist/cjs/ultramodern-workspace/effect-api.cjs +952 -0
  15. package/dist/cjs/ultramodern-workspace/fs-io.cjs +191 -0
  16. package/dist/cjs/ultramodern-workspace/index.cjs +48 -0
  17. package/dist/cjs/ultramodern-workspace/locales.cjs +173 -0
  18. package/dist/cjs/ultramodern-workspace/module-federation.cjs +487 -0
  19. package/dist/cjs/ultramodern-workspace/naming.cjs +161 -0
  20. package/dist/cjs/ultramodern-workspace/package-json.cjs +406 -0
  21. package/dist/cjs/ultramodern-workspace/package-source.cjs +59 -0
  22. package/dist/cjs/ultramodern-workspace/policy.cjs +248 -0
  23. package/dist/cjs/ultramodern-workspace/public-surface.cjs +268 -0
  24. package/dist/cjs/ultramodern-workspace/routes.cjs +375 -0
  25. package/dist/cjs/ultramodern-workspace/types.cjs +61 -0
  26. package/dist/cjs/ultramodern-workspace/versions.cjs +153 -0
  27. package/dist/cjs/ultramodern-workspace/workspace-scripts.cjs +153 -0
  28. package/dist/cjs/ultramodern-workspace/write-workspace.cjs +175 -0
  29. package/dist/esm/create-package-root.js +14 -0
  30. package/dist/esm/index.js +491 -0
  31. package/dist/esm/locale/en.js +55 -0
  32. package/dist/esm/locale/index.js +9 -0
  33. package/dist/esm/locale/zh.js +55 -0
  34. package/dist/esm/ultramodern-package-source.js +63 -0
  35. package/dist/esm/ultramodern-workspace/add-vertical.js +252 -0
  36. package/dist/esm/ultramodern-workspace/app-files.js +149 -0
  37. package/dist/esm/ultramodern-workspace/contracts.js +741 -0
  38. package/dist/esm/ultramodern-workspace/demo-components.js +363 -0
  39. package/dist/esm/ultramodern-workspace/descriptors.js +133 -0
  40. package/dist/esm/ultramodern-workspace/effect-api.js +854 -0
  41. package/dist/esm/ultramodern-workspace/fs-io.js +90 -0
  42. package/dist/esm/ultramodern-workspace/index.js +3 -0
  43. package/dist/esm/ultramodern-workspace/locales.js +122 -0
  44. package/dist/esm/ultramodern-workspace/module-federation.js +415 -0
  45. package/dist/esm/ultramodern-workspace/naming.js +71 -0
  46. package/dist/esm/ultramodern-workspace/package-json.js +338 -0
  47. package/dist/esm/ultramodern-workspace/package-source.js +21 -0
  48. package/dist/esm/ultramodern-workspace/policy.js +183 -0
  49. package/dist/esm/ultramodern-workspace/public-surface.js +183 -0
  50. package/dist/esm/ultramodern-workspace/routes.js +280 -0
  51. package/dist/esm/ultramodern-workspace/types.js +16 -0
  52. package/dist/esm/ultramodern-workspace/versions.js +34 -0
  53. package/dist/esm/ultramodern-workspace/workspace-scripts.js +91 -0
  54. package/dist/esm/ultramodern-workspace/write-workspace.js +121 -0
  55. package/dist/esm-node/create-package-root.js +15 -0
  56. package/dist/esm-node/index.js +492 -0
  57. package/dist/esm-node/locale/en.js +56 -0
  58. package/dist/esm-node/locale/index.js +10 -0
  59. package/dist/esm-node/locale/zh.js +56 -0
  60. package/dist/esm-node/ultramodern-package-source.js +64 -0
  61. package/dist/esm-node/ultramodern-workspace/add-vertical.js +253 -0
  62. package/dist/esm-node/ultramodern-workspace/app-files.js +150 -0
  63. package/dist/esm-node/ultramodern-workspace/contracts.js +742 -0
  64. package/dist/esm-node/ultramodern-workspace/demo-components.js +364 -0
  65. package/dist/esm-node/ultramodern-workspace/descriptors.js +134 -0
  66. package/dist/esm-node/ultramodern-workspace/effect-api.js +855 -0
  67. package/dist/esm-node/ultramodern-workspace/fs-io.js +91 -0
  68. package/dist/esm-node/ultramodern-workspace/index.js +4 -0
  69. package/dist/esm-node/ultramodern-workspace/locales.js +123 -0
  70. package/dist/esm-node/ultramodern-workspace/module-federation.js +416 -0
  71. package/dist/esm-node/ultramodern-workspace/naming.js +72 -0
  72. package/dist/esm-node/ultramodern-workspace/package-json.js +339 -0
  73. package/dist/esm-node/ultramodern-workspace/package-source.js +22 -0
  74. package/dist/esm-node/ultramodern-workspace/policy.js +184 -0
  75. package/dist/esm-node/ultramodern-workspace/public-surface.js +184 -0
  76. package/dist/esm-node/ultramodern-workspace/routes.js +281 -0
  77. package/dist/esm-node/ultramodern-workspace/types.js +17 -0
  78. package/dist/esm-node/ultramodern-workspace/versions.js +35 -0
  79. package/dist/esm-node/ultramodern-workspace/workspace-scripts.js +92 -0
  80. package/dist/esm-node/ultramodern-workspace/write-workspace.js +122 -0
  81. package/dist/types/create-package-root.d.ts +1 -0
  82. package/dist/types/locale/en.d.ts +8 -9
  83. package/dist/types/locale/index.d.ts +109 -2
  84. package/dist/types/locale/zh.d.ts +8 -9
  85. package/dist/types/ultramodern-package-source.d.ts +28 -0
  86. package/dist/types/ultramodern-workspace/add-vertical.d.ts +19 -0
  87. package/dist/types/ultramodern-workspace/app-files.d.ts +14 -0
  88. package/dist/types/ultramodern-workspace/contracts.d.ts +21 -0
  89. package/dist/types/ultramodern-workspace/demo-components.d.ts +9 -0
  90. package/dist/types/ultramodern-workspace/descriptors.d.ts +39 -0
  91. package/dist/types/ultramodern-workspace/effect-api.d.ts +73 -0
  92. package/dist/types/ultramodern-workspace/fs-io.d.ts +18 -0
  93. package/dist/types/ultramodern-workspace/index.d.ts +4 -0
  94. package/dist/types/ultramodern-workspace/locales.d.ts +183 -0
  95. package/dist/types/ultramodern-workspace/module-federation.d.ts +16 -0
  96. package/dist/types/ultramodern-workspace/naming.d.ts +16 -0
  97. package/dist/types/ultramodern-workspace/package-json.d.ts +12 -0
  98. package/dist/types/ultramodern-workspace/package-source.d.ts +2 -0
  99. package/dist/types/ultramodern-workspace/policy.d.ts +60 -0
  100. package/dist/types/ultramodern-workspace/public-surface.d.ts +37 -0
  101. package/dist/types/ultramodern-workspace/routes.d.ts +25 -0
  102. package/dist/types/ultramodern-workspace/types.d.ts +95 -0
  103. package/dist/types/ultramodern-workspace/versions.d.ts +38 -0
  104. package/dist/types/ultramodern-workspace/workspace-scripts.d.ts +10 -0
  105. package/dist/types/ultramodern-workspace/write-workspace.d.ts +4 -0
  106. package/package.json +34 -15
  107. package/template-workspace/.agents/agent-reference-repos.json +24 -0
  108. package/template-workspace/.agents/skills-lock.json +19 -0
  109. package/template-workspace/.codex/hooks.json +16 -0
  110. package/template-workspace/.github/renovate.json +29 -0
  111. package/template-workspace/.github/workflows/ultramodern-workspace-gates.yml.handlebars +67 -0
  112. package/template-workspace/.gitignore.handlebars +5 -0
  113. package/template-workspace/.mise.toml.handlebars +3 -0
  114. package/template-workspace/AGENTS.md.handlebars +87 -0
  115. package/template-workspace/README.md.handlebars +132 -11
  116. package/template-workspace/lefthook.yml +24 -0
  117. package/template-workspace/oxfmt.config.ts +1 -0
  118. package/template-workspace/oxlint.config.ts +1 -0
  119. package/template-workspace/pnpm-workspace.yaml.handlebars +40 -0
  120. package/template-workspace/scripts/bootstrap-agent-skills.mjs +184 -21
  121. package/template-workspace/scripts/setup-agent-reference-repos.mjs +370 -0
  122. package/templates/app/shell-frame.tsx +49 -0
  123. package/templates/app/ultramodern-route-head.tsx.handlebars +142 -0
  124. package/templates/packages/shared-contracts-index.ts +466 -0
  125. package/templates/workspace-scripts/assert-mf-types.mjs.handlebars +69 -0
  126. package/templates/workspace-scripts/check-ultramodern-i18n-boundaries.mjs +9 -0
  127. package/templates/workspace-scripts/generate-public-surface-assets.mjs +529 -0
  128. package/templates/workspace-scripts/proof-cloudflare-version.mjs +125 -0
  129. package/templates/workspace-scripts/ultramodern-cloudflare-proof.mjs +851 -0
  130. package/templates/workspace-scripts/ultramodern-performance-readiness.config.mjs +7 -0
  131. package/templates/workspace-scripts/ultramodern-performance-readiness.mjs +223 -0
  132. package/templates/workspace-scripts/validate-ultramodern-workspace.mjs.handlebars +593 -0
  133. package/dist/index.js +0 -2626
  134. package/dist/types/ultramodern-workspace.d.ts +0 -20
  135. package/template/.agents/skills-lock.json +0 -34
  136. package/template/.browserslistrc +0 -4
  137. package/template/.github/workflows/ultramodern-gates.yml.handlebars +0 -30
  138. package/template/.gitignore.handlebars +0 -30
  139. package/template/.nvmrc +0 -2
  140. package/template/AGENTS.md +0 -25
  141. package/template/README.md +0 -79
  142. package/template/api/effect/index.ts.handlebars +0 -23
  143. package/template/api/lambda/hello.ts.handlebars +0 -6
  144. package/template/config/public/locales/cs/translation.json +0 -39
  145. package/template/config/public/locales/en/translation.json +0 -39
  146. package/template/modern.config.ts.handlebars +0 -53
  147. package/template/oxfmt.config.ts +0 -8
  148. package/template/oxlint.config.ts +0 -12
  149. package/template/package.json.handlebars +0 -67
  150. package/template/postcss.config.mjs.handlebars +0 -6
  151. package/template/scripts/bootstrap-agent-skills.mjs +0 -95
  152. package/template/scripts/check-i18n-strings.mjs +0 -83
  153. package/template/scripts/validate-ultramodern.mjs.handlebars +0 -178
  154. package/template/shared/effect/api.ts.handlebars +0 -17
  155. package/template/src/modern-app-env.d.ts +0 -1
  156. package/template/src/modern.runtime.ts.handlebars +0 -23
  157. package/template/src/routes/index.css.handlebars +0 -129
  158. package/template/src/routes/layout.tsx.handlebars +0 -9
  159. package/template/src/routes/page.tsx.handlebars +0 -155
  160. package/template/tailwind.config.ts.handlebars +0 -10
  161. package/template/tsconfig.json +0 -120
  162. package/template-workspace/AGENTS.md +0 -50
  163. package/template-workspace/pnpm-workspace.yaml +0 -17
  164. package/template-workspace/scripts/check-i18n-strings.mjs +0 -83
  165. package/template-workspace/scripts/validate-ultramodern-workspace.mjs.handlebars +0 -433
@@ -0,0 +1,7 @@
1
+ /** @type {import('../packages/shared-contracts/src/index.ts').UltramodernPerformanceReadinessDiagnosticsConfig} */
2
+ export default {
3
+ enabled: true,
4
+ failOn: 'framework-invariant',
5
+ reportPath:
6
+ '.codex/reports/performance-readiness/ultramodern-performance-readiness.json',
7
+ };
@@ -0,0 +1,223 @@
1
+ import fs from 'node:fs';
2
+ import path from 'node:path';
3
+ import { pathToFileURL } from 'node:url';
4
+
5
+ const root = process.cwd();
6
+ const defaultReportPath =
7
+ '.codex/reports/performance-readiness/ultramodern-performance-readiness.json';
8
+ const configPath = 'scripts/ultramodern-performance-readiness.config.mjs';
9
+ const optOutEnv = 'ULTRAMODERN_PERFORMANCE_READINESS_DIAGNOSTICS';
10
+ const signalIds = [
11
+ 'bfcache',
12
+ 'core-web-vitals-rum',
13
+ 'duplicate-prefetch-warmup',
14
+ 'cache-policy-sanity',
15
+ 'save-data-behavior',
16
+ 'cloudflare-ssr-cache-hints',
17
+ ];
18
+
19
+ const readText = relativePath =>
20
+ fs.readFileSync(path.join(root, relativePath), 'utf-8');
21
+ const readJson = relativePath => JSON.parse(readText(relativePath));
22
+ const exists = relativePath => fs.existsSync(path.join(root, relativePath));
23
+ const assert = (condition, message) => {
24
+ if (!condition) {
25
+ throw new Error(message);
26
+ }
27
+ };
28
+
29
+ const normalizeConfig = value => ({
30
+ enabled: value?.enabled !== false,
31
+ failOn: value?.failOn === 'never' ? 'never' : 'framework-invariant',
32
+ reportPath:
33
+ typeof value?.reportPath === 'string' && value.reportPath.length > 0
34
+ ? value.reportPath
35
+ : defaultReportPath,
36
+ });
37
+
38
+ const loadConfig = async () => {
39
+ if (!exists(configPath)) {
40
+ return normalizeConfig({});
41
+ }
42
+
43
+ const moduleUrl = pathToFileURL(path.join(root, configPath)).href;
44
+ const module = await import(moduleUrl);
45
+ return normalizeConfig(module.default ?? {});
46
+ };
47
+
48
+ const writeReport = (reportPath, report) => {
49
+ const absoluteReportPath = path.join(root, reportPath);
50
+ fs.mkdirSync(path.dirname(absoluteReportPath), { recursive: true });
51
+ fs.writeFileSync(absoluteReportPath, `${JSON.stringify(report, null, 2)}\n`);
52
+ };
53
+
54
+ const createSignal = (id, status, evidence) => ({
55
+ id,
56
+ severity: 'diagnostic',
57
+ status,
58
+ evidence,
59
+ });
60
+
61
+ const unique = values => new Set(values).size === values.length;
62
+
63
+ const appGeneratedFiles = app => [
64
+ `${app.path}/modern.config.ts`,
65
+ `${app.path}/module-federation.config.ts`,
66
+ `${app.path}/src/modern.runtime.ts`,
67
+ `${app.path}/src/routes/ultramodern-route-metadata.ts`,
68
+ `${app.path}/src/routes/ultramodern-route-head.tsx`,
69
+ ].filter(exists);
70
+
71
+ const assertPass = (signal, failOn) => {
72
+ if (failOn === 'framework-invariant') {
73
+ assert(signal.status === 'pass', `${signal.id} readiness invariant failed`);
74
+ }
75
+ };
76
+
77
+ const evaluateApp = (app, contract, failOn) => {
78
+ const files = appGeneratedFiles(app);
79
+ const generatedSource = files.map(readText).join('\n');
80
+ const localisedUrls = Object.values(app.routes?.localisedUrls ?? {}).flatMap(
81
+ value =>
82
+ value && typeof value === 'object'
83
+ ? Object.values(value).filter(entry => typeof entry === 'string')
84
+ : [],
85
+ );
86
+ const remotes = app.moduleFederation?.remotes ?? [];
87
+ const signals = [
88
+ createSignal(
89
+ 'bfcache',
90
+ /\b(?:beforeunload|unload)\b/u.test(generatedSource) ? 'fail' : 'pass',
91
+ [
92
+ `scanned:${files.length}`,
93
+ 'generated-files-do-not-install-unload-handlers',
94
+ ],
95
+ ),
96
+ createSignal(
97
+ 'core-web-vitals-rum',
98
+ contract.performanceReadiness?.scope ===
99
+ 'ultramodern-generated-and-framework-owned'
100
+ ? 'pass'
101
+ : 'fail',
102
+ [
103
+ 'preset-telemetry-contract',
104
+ 'runtime-rum-instrumentation-ready-without-local-collector',
105
+ ],
106
+ ),
107
+ createSignal(
108
+ 'duplicate-prefetch-warmup',
109
+ unique(localisedUrls) &&
110
+ unique(remotes.map(remote => remote.id)) &&
111
+ unique(remotes.map(remote => remote.manifestUrl))
112
+ ? 'pass'
113
+ : 'fail',
114
+ [
115
+ `localised-url-count:${localisedUrls.length}`,
116
+ `remote-count:${remotes.length}`,
117
+ ],
118
+ ),
119
+ createSignal(
120
+ 'cache-policy-sanity',
121
+ app.deploy?.cloudflare?.qualityGates?.assets
122
+ ?.cacheControlRequiredForCss === true &&
123
+ app.routes?.publicSurface?.artifactLifecycle ===
124
+ 'build-and-deploy-output'
125
+ ? 'pass'
126
+ : 'fail',
127
+ [
128
+ 'css-cache-control-required',
129
+ 'public-surface-generated-as-build-output',
130
+ ],
131
+ ),
132
+ createSignal(
133
+ 'save-data-behavior',
134
+ app.config?.plugins?.includes('tanstackRouterPlugin') &&
135
+ contract.performanceReadiness?.signals?.some(
136
+ signal => signal.id === 'save-data-behavior',
137
+ )
138
+ ? 'pass'
139
+ : 'fail',
140
+ ['framework-router-warmup-is-diagnostic-only'],
141
+ ),
142
+ createSignal(
143
+ 'cloudflare-ssr-cache-hints',
144
+ app.deploy?.cloudflare?.routes?.ssr &&
145
+ app.deploy?.cloudflare?.routes?.mfManifest &&
146
+ app.deploy?.cloudflare?.compatibilityFlags?.includes('nodejs_compat')
147
+ ? 'pass'
148
+ : 'fail',
149
+ ['ssr-route-present', 'mf-manifest-route-present', 'nodejs-compat'],
150
+ ),
151
+ ];
152
+
153
+ for (const signal of signals) {
154
+ assertPass(signal, failOn);
155
+ }
156
+
157
+ return {
158
+ id: app.id,
159
+ path: app.path,
160
+ signals,
161
+ };
162
+ };
163
+
164
+ const main = async () => {
165
+ const config = await loadConfig();
166
+ const envDisabled = process.env[optOutEnv] === 'false';
167
+ const reportPath = config.reportPath;
168
+ const disabled = envDisabled || config.enabled === false;
169
+
170
+ if (disabled) {
171
+ writeReport(reportPath, {
172
+ schemaVersion: 1,
173
+ profile: 'ultramodern-performance-readiness-diagnostics-v1',
174
+ status: 'disabled',
175
+ defaultOn: true,
176
+ optOut: envDisabled ? `${optOutEnv}=false` : `${configPath}#enabled=false`,
177
+ signals: signalIds,
178
+ apps: [],
179
+ });
180
+ console.log('UltraModern performance readiness diagnostics disabled');
181
+ return;
182
+ }
183
+
184
+ const contract = readJson('.modernjs/ultramodern-generated-contract.json');
185
+ assert(
186
+ contract.performanceReadiness?.default === 'enabled',
187
+ 'Generated contract must keep performance readiness diagnostics default-on',
188
+ );
189
+ assert(
190
+ contract.performanceReadiness?.report?.script ===
191
+ 'scripts/ultramodern-performance-readiness.mjs',
192
+ 'Generated contract must point at the performance readiness diagnostics script',
193
+ );
194
+ const contractSignalIds =
195
+ contract.performanceReadiness?.signals?.map(signal => signal.id) ?? [];
196
+ assert(
197
+ JSON.stringify(contractSignalIds) === JSON.stringify(signalIds),
198
+ 'Generated contract readiness signals changed without updating the diagnostics report shape',
199
+ );
200
+
201
+ const apps = [...(contract.apps ?? [])].sort((left, right) =>
202
+ String(left.id).localeCompare(String(right.id)),
203
+ );
204
+ assert(unique(apps.map(app => app.id)), 'Generated app ids must be unique');
205
+
206
+ const appReports = apps.map(app => evaluateApp(app, contract, config.failOn));
207
+ writeReport(reportPath, {
208
+ schemaVersion: 1,
209
+ profile: 'ultramodern-performance-readiness-diagnostics-v1',
210
+ status: 'pass',
211
+ defaultOn: true,
212
+ optOut: {
213
+ env: `${optOutEnv}=false`,
214
+ config: `${configPath}#enabled=false`,
215
+ },
216
+ failOn: config.failOn,
217
+ signals: signalIds,
218
+ apps: appReports,
219
+ });
220
+ console.log('UltraModern performance readiness diagnostics reported');
221
+ };
222
+
223
+ await main();