@modern-js/app-tools 2.31.2 → 2.31.3-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.
- package/LICENSE +1 -1
- package/dist/cjs/analyze/constants.js +11 -5
- package/dist/cjs/analyze/nestedRoutes.js +28 -1
- package/dist/cjs/analyze/templates.js +10 -7
- package/dist/cjs/builder/shared/builderPlugins/adapterSSR.js +1 -1
- package/dist/cjs/builder/shared/bundlerPlugins/RouterPlugin.js +24 -22
- package/dist/cjs/index.js +16 -0
- package/dist/esm/analyze/constants.js +11 -5
- package/dist/esm/analyze/nestedRoutes.js +31 -2
- package/dist/esm/analyze/templates.js +10 -7
- package/dist/esm/builder/shared/builderPlugins/adapterSSR.js +1 -1
- package/dist/esm/builder/shared/bundlerPlugins/RouterPlugin.js +24 -22
- package/dist/esm/index.js +42 -1
- package/dist/esm-node/analyze/constants.js +11 -5
- package/dist/esm-node/analyze/nestedRoutes.js +28 -1
- package/dist/esm-node/analyze/templates.js +10 -7
- package/dist/esm-node/builder/shared/builderPlugins/adapterSSR.js +1 -1
- package/dist/esm-node/builder/shared/bundlerPlugins/RouterPlugin.js +24 -22
- package/dist/esm-node/index.js +17 -1
- package/dist/js/modern/analyze/constants.js +54 -0
- package/dist/js/modern/analyze/generateCode.js +247 -0
- package/dist/js/modern/analyze/getBundleEntry.js +71 -0
- package/dist/js/modern/analyze/getClientRoutes/getRoutes.js +220 -0
- package/dist/js/modern/analyze/getClientRoutes/getRoutesLegacy.js +216 -0
- package/dist/js/modern/analyze/getClientRoutes/index.js +6 -0
- package/dist/js/modern/analyze/getClientRoutes/utils.js +31 -0
- package/dist/js/modern/analyze/getFileSystemEntry.js +109 -0
- package/dist/js/modern/analyze/getHtmlTemplate.js +115 -0
- package/dist/js/modern/analyze/getServerRoutes.js +175 -0
- package/dist/js/modern/analyze/index.js +332 -0
- package/dist/js/modern/analyze/isDefaultExportFunction.js +42 -0
- package/dist/js/modern/analyze/makeLegalIdentifier.js +13 -0
- package/dist/js/modern/analyze/nestedRoutes.js +157 -0
- package/dist/js/modern/analyze/templates.js +334 -0
- package/dist/js/modern/analyze/utils.js +141 -0
- package/dist/js/modern/builder/builderPlugins/compatModern.js +233 -0
- package/dist/js/modern/builder/index.js +159 -0
- package/dist/js/modern/builder/loaders/routerLoader.js +17 -0
- package/dist/js/modern/builder/loaders/serverModuleLoader.js +7 -0
- package/dist/js/modern/builder/share.js +46 -0
- package/dist/js/modern/builder/webpackPlugins/htmlAsyncChunkPlugin.js +30 -0
- package/dist/js/modern/builder/webpackPlugins/htmlBottomTemplate.js +37 -0
- package/dist/js/modern/builder/webpackPlugins/routerPlugin.js +113 -0
- package/dist/js/modern/commands/build.js +91 -0
- package/dist/js/modern/commands/deploy.js +28 -0
- package/dist/js/modern/commands/dev.js +109 -0
- package/dist/js/modern/commands/index.js +3 -0
- package/dist/js/modern/commands/inspect.js +38 -0
- package/dist/js/modern/commands/serve.js +54 -0
- package/dist/js/modern/config/default.js +175 -0
- package/dist/js/modern/config/index.js +8 -0
- package/dist/js/modern/config/initial/createHtmlConfig.js +35 -0
- package/dist/js/modern/config/initial/createOutputConfig.js +68 -0
- package/dist/js/modern/config/initial/createSourceConfig.js +39 -0
- package/dist/js/modern/config/initial/createToolsConfig.js +42 -0
- package/dist/js/modern/config/initial/index.js +16 -0
- package/dist/js/modern/config/initial/inits.js +152 -0
- package/dist/js/modern/config/initial/transformNormalizedConfig.js +47 -0
- package/dist/js/modern/defineConfig.js +27 -0
- package/dist/js/modern/exports/server.js +4 -0
- package/dist/js/modern/hooks.js +35 -0
- package/dist/js/modern/index.js +211 -0
- package/dist/js/modern/initialize/index.js +124 -0
- package/dist/js/modern/locale/en.js +36 -0
- package/dist/js/modern/locale/index.js +9 -0
- package/dist/js/modern/locale/zh.js +36 -0
- package/dist/js/modern/schema/Schema.js +40 -0
- package/dist/js/modern/schema/index.js +88 -0
- package/dist/js/modern/schema/legacy.js +148 -0
- package/dist/js/modern/types/config/deploy.js +0 -0
- package/dist/js/modern/types/config/dev.js +0 -0
- package/dist/js/modern/types/config/experiments.js +0 -0
- package/dist/js/modern/types/config/html.js +0 -0
- package/dist/js/modern/types/config/index.js +1 -0
- package/dist/js/modern/types/config/output.js +0 -0
- package/dist/js/modern/types/config/performance.js +0 -0
- package/dist/js/modern/types/config/security.js +0 -0
- package/dist/js/modern/types/config/source.js +0 -0
- package/dist/js/modern/types/config/tools.js +0 -0
- package/dist/js/modern/types/hooks.js +0 -0
- package/dist/js/modern/types/index.js +3 -0
- package/dist/js/modern/types/legacyConfig/deploy.js +0 -0
- package/dist/js/modern/types/legacyConfig/dev.js +0 -0
- package/dist/js/modern/types/legacyConfig/index.js +0 -0
- package/dist/js/modern/types/legacyConfig/output.js +0 -0
- package/dist/js/modern/types/legacyConfig/source.js +0 -0
- package/dist/js/modern/types/legacyConfig/tools.js +0 -0
- package/dist/js/modern/utils/config.js +128 -0
- package/dist/js/modern/utils/createServer.js +75 -0
- package/dist/js/modern/utils/env.js +15 -0
- package/dist/js/modern/utils/generateWatchFiles.js +55 -0
- package/dist/js/modern/utils/getSelectedEntries.js +58 -0
- package/dist/js/modern/utils/getServerInternalPlugins.js +58 -0
- package/dist/js/modern/utils/language.js +8 -0
- package/dist/js/modern/utils/printInstructions.js +31 -0
- package/dist/js/modern/utils/restart.js +44 -0
- package/dist/js/modern/utils/routes.js +30 -0
- package/dist/js/modern/utils/types.js +0 -0
- package/dist/js/node/analyze/constants.js +98 -0
- package/dist/js/node/analyze/generateCode.js +271 -0
- package/dist/js/node/analyze/getBundleEntry.js +95 -0
- package/dist/js/node/analyze/getClientRoutes/getRoutes.js +242 -0
- package/dist/js/node/analyze/getClientRoutes/getRoutesLegacy.js +238 -0
- package/dist/js/node/analyze/getClientRoutes/index.js +30 -0
- package/dist/js/node/analyze/getClientRoutes/utils.js +58 -0
- package/dist/js/node/analyze/getFileSystemEntry.js +131 -0
- package/dist/js/node/analyze/getHtmlTemplate.js +144 -0
- package/dist/js/node/analyze/getServerRoutes.js +194 -0
- package/dist/js/node/analyze/index.js +339 -0
- package/dist/js/node/analyze/isDefaultExportFunction.js +71 -0
- package/dist/js/node/analyze/makeLegalIdentifier.js +36 -0
- package/dist/js/node/analyze/nestedRoutes.js +184 -0
- package/dist/js/node/analyze/templates.js +365 -0
- package/dist/js/node/analyze/utils.js +172 -0
- package/dist/js/node/builder/builderPlugins/compatModern.js +258 -0
- package/dist/js/node/builder/index.js +177 -0
- package/dist/js/node/builder/loaders/routerLoader.js +38 -0
- package/dist/js/node/builder/loaders/serverModuleLoader.js +28 -0
- package/dist/js/node/builder/share.js +75 -0
- package/dist/js/node/builder/webpackPlugins/htmlAsyncChunkPlugin.js +53 -0
- package/dist/js/node/builder/webpackPlugins/htmlBottomTemplate.js +60 -0
- package/dist/js/node/builder/webpackPlugins/routerPlugin.js +135 -0
- package/dist/js/node/commands/build.js +112 -0
- package/dist/js/node/commands/deploy.js +51 -0
- package/dist/js/node/commands/dev.js +126 -0
- package/dist/js/node/commands/index.js +19 -0
- package/dist/js/node/commands/inspect.js +61 -0
- package/dist/js/node/commands/serve.js +83 -0
- package/dist/js/node/config/default.js +197 -0
- package/dist/js/node/config/index.js +34 -0
- package/dist/js/node/config/initial/createHtmlConfig.js +58 -0
- package/dist/js/node/config/initial/createOutputConfig.js +91 -0
- package/dist/js/node/config/initial/createSourceConfig.js +62 -0
- package/dist/js/node/config/initial/createToolsConfig.js +65 -0
- package/dist/js/node/config/initial/index.js +41 -0
- package/dist/js/node/config/initial/inits.js +175 -0
- package/dist/js/node/config/initial/transformNormalizedConfig.js +70 -0
- package/dist/js/node/defineConfig.js +49 -0
- package/dist/js/node/exports/server.js +27 -0
- package/dist/js/node/hooks.js +54 -0
- package/dist/js/node/index.js +235 -0
- package/dist/js/node/initialize/index.js +134 -0
- package/dist/js/node/locale/en.js +59 -0
- package/dist/js/node/locale/index.js +33 -0
- package/dist/js/node/locale/zh.js +59 -0
- package/dist/js/node/schema/Schema.js +63 -0
- package/dist/js/node/schema/index.js +118 -0
- package/dist/js/node/schema/legacy.js +169 -0
- package/dist/js/node/types/config/deploy.js +15 -0
- package/dist/js/node/types/config/dev.js +15 -0
- package/dist/js/node/types/config/experiments.js +15 -0
- package/dist/js/node/types/config/html.js +15 -0
- package/dist/js/node/types/config/index.js +17 -0
- package/dist/js/node/types/config/output.js +15 -0
- package/dist/js/node/types/config/performance.js +15 -0
- package/dist/js/node/types/config/security.js +15 -0
- package/dist/js/node/types/config/source.js +15 -0
- package/dist/js/node/types/config/tools.js +15 -0
- package/dist/js/node/types/hooks.js +15 -0
- package/dist/js/node/types/index.js +19 -0
- package/dist/js/node/types/legacyConfig/deploy.js +15 -0
- package/dist/js/node/types/legacyConfig/dev.js +15 -0
- package/dist/js/node/types/legacyConfig/index.js +15 -0
- package/dist/js/node/types/legacyConfig/output.js +15 -0
- package/dist/js/node/types/legacyConfig/source.js +15 -0
- package/dist/js/node/types/legacyConfig/tools.js +15 -0
- package/dist/js/node/utils/config.js +153 -0
- package/dist/js/node/utils/createServer.js +106 -0
- package/dist/js/node/utils/env.js +38 -0
- package/dist/js/node/utils/generateWatchFiles.js +85 -0
- package/dist/js/node/utils/getSelectedEntries.js +81 -0
- package/dist/js/node/utils/getServerInternalPlugins.js +79 -0
- package/dist/js/node/utils/language.js +31 -0
- package/dist/js/node/utils/printInstructions.js +54 -0
- package/dist/js/node/utils/restart.js +67 -0
- package/dist/js/node/utils/routes.js +59 -0
- package/dist/js/node/utils/types.js +15 -0
- package/dist/js/treeshaking/analyze/constants.js +40 -0
- package/dist/js/treeshaking/analyze/generateCode.js +485 -0
- package/dist/js/treeshaking/analyze/getBundleEntry.js +62 -0
- package/dist/js/treeshaking/analyze/getClientRoutes/getRoutes.js +233 -0
- package/dist/js/treeshaking/analyze/getClientRoutes/getRoutesLegacy.js +231 -0
- package/dist/js/treeshaking/analyze/getClientRoutes/index.js +3 -0
- package/dist/js/treeshaking/analyze/getClientRoutes/utils.js +23 -0
- package/dist/js/treeshaking/analyze/getFileSystemEntry.js +107 -0
- package/dist/js/treeshaking/analyze/getHtmlTemplate.js +302 -0
- package/dist/js/treeshaking/analyze/getServerRoutes.js +222 -0
- package/dist/js/treeshaking/analyze/index.js +697 -0
- package/dist/js/treeshaking/analyze/isDefaultExportFunction.js +47 -0
- package/dist/js/treeshaking/analyze/makeLegalIdentifier.js +13 -0
- package/dist/js/treeshaking/analyze/nestedRoutes.js +384 -0
- package/dist/js/treeshaking/analyze/templates.js +468 -0
- package/dist/js/treeshaking/analyze/utils.js +374 -0
- package/dist/js/treeshaking/builder/builderPlugins/compatModern.js +304 -0
- package/dist/js/treeshaking/builder/index.js +374 -0
- package/dist/js/treeshaking/builder/loaders/routerLoader.js +13 -0
- package/dist/js/treeshaking/builder/loaders/serverModuleLoader.js +5 -0
- package/dist/js/treeshaking/builder/share.js +40 -0
- package/dist/js/treeshaking/builder/webpackPlugins/htmlAsyncChunkPlugin.js +110 -0
- package/dist/js/treeshaking/builder/webpackPlugins/htmlBottomTemplate.js +72 -0
- package/dist/js/treeshaking/builder/webpackPlugins/routerPlugin.js +343 -0
- package/dist/js/treeshaking/commands/build.js +291 -0
- package/dist/js/treeshaking/commands/deploy.js +154 -0
- package/dist/js/treeshaking/commands/dev.js +301 -0
- package/dist/js/treeshaking/commands/index.js +3 -0
- package/dist/js/treeshaking/commands/inspect.js +149 -0
- package/dist/js/treeshaking/commands/serve.js +199 -0
- package/dist/js/treeshaking/config/default.js +210 -0
- package/dist/js/treeshaking/config/index.js +3 -0
- package/dist/js/treeshaking/config/initial/createHtmlConfig.js +19 -0
- package/dist/js/treeshaking/config/initial/createOutputConfig.js +41 -0
- package/dist/js/treeshaking/config/initial/createSourceConfig.js +42 -0
- package/dist/js/treeshaking/config/initial/createToolsConfig.js +23 -0
- package/dist/js/treeshaking/config/initial/index.js +12 -0
- package/dist/js/treeshaking/config/initial/inits.js +209 -0
- package/dist/js/treeshaking/config/initial/transformNormalizedConfig.js +35 -0
- package/dist/js/treeshaking/defineConfig.js +61 -0
- package/dist/js/treeshaking/exports/server.js +2 -0
- package/dist/js/treeshaking/hooks.js +29 -0
- package/dist/js/treeshaking/index.js +706 -0
- package/dist/js/treeshaking/initialize/index.js +276 -0
- package/dist/js/treeshaking/locale/en.js +38 -0
- package/dist/js/treeshaking/locale/index.js +9 -0
- package/dist/js/treeshaking/locale/zh.js +38 -0
- package/dist/js/treeshaking/schema/Schema.js +273 -0
- package/dist/js/treeshaking/schema/index.js +181 -0
- package/dist/js/treeshaking/schema/legacy.js +337 -0
- package/dist/js/treeshaking/types/config/deploy.js +1 -0
- package/dist/js/treeshaking/types/config/dev.js +1 -0
- package/dist/js/treeshaking/types/config/experiments.js +1 -0
- package/dist/js/treeshaking/types/config/html.js +1 -0
- package/dist/js/treeshaking/types/config/index.js +1 -0
- package/dist/js/treeshaking/types/config/output.js +1 -0
- package/dist/js/treeshaking/types/config/performance.js +1 -0
- package/dist/js/treeshaking/types/config/security.js +1 -0
- package/dist/js/treeshaking/types/config/source.js +1 -0
- package/dist/js/treeshaking/types/config/tools.js +1 -0
- package/dist/js/treeshaking/types/hooks.js +1 -0
- package/dist/js/treeshaking/types/index.js +3 -0
- package/dist/js/treeshaking/types/legacyConfig/deploy.js +1 -0
- package/dist/js/treeshaking/types/legacyConfig/dev.js +1 -0
- package/dist/js/treeshaking/types/legacyConfig/index.js +1 -0
- package/dist/js/treeshaking/types/legacyConfig/output.js +1 -0
- package/dist/js/treeshaking/types/legacyConfig/source.js +1 -0
- package/dist/js/treeshaking/types/legacyConfig/tools.js +1 -0
- package/dist/js/treeshaking/utils/config.js +302 -0
- package/dist/js/treeshaking/utils/createServer.js +258 -0
- package/dist/js/treeshaking/utils/env.js +13 -0
- package/dist/js/treeshaking/utils/generateWatchFiles.js +214 -0
- package/dist/js/treeshaking/utils/getSelectedEntries.js +186 -0
- package/dist/js/treeshaking/utils/getServerInternalPlugins.js +210 -0
- package/dist/js/treeshaking/utils/language.js +6 -0
- package/dist/js/treeshaking/utils/printInstructions.js +152 -0
- package/dist/js/treeshaking/utils/restart.js +187 -0
- package/dist/js/treeshaking/utils/routes.js +153 -0
- package/dist/js/treeshaking/utils/types.js +1 -0
- package/dist/types/analyze/constants.d.ts +10 -4
- package/dist/types/defineConfig.d.ts +1 -1
- package/package.json +16 -16
@@ -132,12 +132,13 @@ export const fileSystemRoutes = async ({ routes, ssrMode, nestedRoutesEntry, ent
|
|
132
132
|
import loadable, { lazy as loadableLazy } from "@modern-js/runtime/loadable"
|
133
133
|
`;
|
134
134
|
let rootLayoutCode = ``;
|
135
|
-
const getDataLoaderPath = (loaderId) => {
|
135
|
+
const getDataLoaderPath = (loaderId, clientData) => {
|
136
136
|
if (!ssrMode) {
|
137
137
|
return "";
|
138
138
|
}
|
139
|
+
const clientDataStr = clientData ? `&clientData=${clientData}` : "";
|
139
140
|
if (nestedRoutesEntry) {
|
140
|
-
return `?mapFile=${slash(loadersMapFile)}&loaderId=${loaderId}`;
|
141
|
+
return `?mapFile=${slash(loadersMapFile)}&loaderId=${loaderId}${clientDataStr}`;
|
141
142
|
}
|
142
143
|
return "";
|
143
144
|
};
|
@@ -162,15 +163,17 @@ export const fileSystemRoutes = async ({ routes, ssrMode, nestedRoutesEntry, ent
|
|
162
163
|
errors.push(route.error);
|
163
164
|
error = `error_${errors.length - 1}`;
|
164
165
|
}
|
165
|
-
if (route.loader) {
|
166
|
+
if (route.loader || route.data) {
|
166
167
|
loaders.push(route.loader);
|
167
168
|
const loaderId = loaders.length - 1;
|
168
169
|
loader = `loader_${loaderId}`;
|
169
170
|
loadersMap[loader] = {
|
170
171
|
routeId: route.id,
|
171
|
-
filePath: route.loader,
|
172
|
-
|
172
|
+
filePath: route.data || route.loader,
|
173
|
+
clientData: Boolean(route.clientData),
|
174
|
+
inline: Boolean(route.data)
|
173
175
|
};
|
176
|
+
loader = `loader_${loaderId}`;
|
174
177
|
}
|
175
178
|
if (typeof route.config === "string") {
|
176
179
|
configs.push(route.config);
|
@@ -269,10 +272,10 @@ export const fileSystemRoutes = async ({ routes, ssrMode, nestedRoutesEntry, ent
|
|
269
272
|
let importLoadersCode = "";
|
270
273
|
for (const [key, loaderInfo] of Object.entries(loadersMap)) {
|
271
274
|
if (loaderInfo.inline) {
|
272
|
-
importLoadersCode += `import { loader as ${key} } from "${slash(loaderInfo.filePath)}${getDataLoaderPath(key)}";
|
275
|
+
importLoadersCode += `import { loader as ${key} } from "${slash(loaderInfo.filePath)}${getDataLoaderPath(key, loaderInfo.clientData)}";
|
273
276
|
`;
|
274
277
|
} else {
|
275
|
-
importLoadersCode += `import ${key} from "${slash(loaderInfo.filePath)}${getDataLoaderPath(key)}";
|
278
|
+
importLoadersCode += `import ${key} from "${slash(loaderInfo.filePath)}${getDataLoaderPath(key, loaderInfo.clientData)}";
|
276
279
|
`;
|
277
280
|
}
|
278
281
|
}
|
@@ -143,6 +143,6 @@ function applySSRDataLoader(chain, options) {
|
|
143
143
|
const { appDirectory } = appContext;
|
144
144
|
const { entriesDir = "./src" } = normalizedConfig.source;
|
145
145
|
const absolutePath = path.resolve(appDirectory, entriesDir).split(path.sep).join("(\\\\|/)");
|
146
|
-
const reg = new RegExp(`${absolutePath}.*\\.loader\\.[t|j]
|
146
|
+
const reg = new RegExp(`${absolutePath}.*\\.(loader|data|data.client)\\.[t|j]sx?$`);
|
147
147
|
chain.module.rule("ssr-data-loader").test(reg).use("data-loader").loader(require.resolve("@modern-js/plugin-data-loader/loader")).end();
|
148
148
|
}
|
@@ -154,28 +154,30 @@ export class RouterPlugin {
|
|
154
154
|
const oldHtml = compilation.assets[htmlName];
|
155
155
|
const { enableInlineRouteManifests, disableFilenameHash, staticJsDir, scriptLoading, nonce } = this;
|
156
156
|
const nonceAttr = nonce ? `nonce="${nonce}"` : "";
|
157
|
-
if (
|
158
|
-
|
159
|
-
|
160
|
-
|
161
|
-
|
162
|
-
|
163
|
-
|
164
|
-
|
165
|
-
|
166
|
-
|
167
|
-
|
168
|
-
|
169
|
-
|
170
|
-
|
171
|
-
|
172
|
-
|
173
|
-
|
174
|
-
|
175
|
-
|
176
|
-
|
177
|
-
|
178
|
-
|
157
|
+
if (oldHtml) {
|
158
|
+
if (enableInlineRouteManifests) {
|
159
|
+
compilation.updateAsset(
|
160
|
+
htmlName,
|
161
|
+
new RawSource(oldHtml.source().toString().replace(placeholder, `<script ${nonceAttr}>${injectedContent}</script>`)),
|
162
|
+
// FIXME: The arguments third of updatgeAsset is a optional function in webpack.
|
163
|
+
void 0
|
164
|
+
);
|
165
|
+
} else {
|
166
|
+
const scriptPath = `${staticJsDir}/${ROUTE_MANIFEST_HOLDER}-${entryName}${disableFilenameHash ? ".js" : `.${generateContentHash(injectedContent)}.js`}`;
|
167
|
+
const scriptUrl = `${publicPath}${scriptPath}`;
|
168
|
+
const scriptLoadingAttr = (
|
169
|
+
// eslint-disable-next-line no-nested-ternary
|
170
|
+
scriptLoading === "defer" ? scriptLoading : scriptLoading === "module" ? `type="module"` : ""
|
171
|
+
);
|
172
|
+
const script = `<script ${scriptLoadingAttr} ${nonceAttr} src="${scriptUrl}"></script>`;
|
173
|
+
compilation.updateAsset(
|
174
|
+
htmlName,
|
175
|
+
new RawSource(oldHtml.source().toString().replace(placeholder, script)),
|
176
|
+
// FIXME: The arguments third of updatgeAsset is a optional function in webpack.
|
177
|
+
void 0
|
178
|
+
);
|
179
|
+
compilation.emitAsset(scriptPath, new RawSource(injectedContent));
|
180
|
+
}
|
179
181
|
}
|
180
182
|
}
|
181
183
|
if (prevManifestAsset) {
|
package/dist/esm-node/index.js
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
import path from "path";
|
2
2
|
import { lintPlugin } from "@modern-js/plugin-lint";
|
3
|
-
import { cleanRequireCache, emptyDir, getCommand, getArgv } from "@modern-js/utils";
|
3
|
+
import { cleanRequireCache, emptyDir, getCommand, getArgv, fs, NESTED_ROUTE_SPEC_FILE } from "@modern-js/utils";
|
4
4
|
import { castArray } from "@modern-js/utils/lodash";
|
5
5
|
import { getLocaleLanguage } from "@modern-js/plugin-i18n/language-detector";
|
6
6
|
import analyzePlugin from "./analyze";
|
@@ -89,6 +89,7 @@ export const appTools = (options = {
|
|
89
89
|
...appContext,
|
90
90
|
toolsType: "app-tools"
|
91
91
|
});
|
92
|
+
const nestedRoutes = {};
|
92
93
|
const locale = getLocaleLanguage();
|
93
94
|
i18n.changeLanguage({
|
94
95
|
locale
|
@@ -174,6 +175,21 @@ export const appTools = (options = {
|
|
174
175
|
cleanRequireCache([
|
175
176
|
require.resolve("./analyze")
|
176
177
|
]);
|
178
|
+
},
|
179
|
+
async modifyFileSystemRoutes({ entrypoint, routes }) {
|
180
|
+
nestedRoutes[entrypoint.entryName] = routes;
|
181
|
+
return {
|
182
|
+
entrypoint,
|
183
|
+
routes
|
184
|
+
};
|
185
|
+
},
|
186
|
+
async beforeGenerateRoutes({ entrypoint, code }) {
|
187
|
+
const { distDirectory } = api.useAppContext();
|
188
|
+
await fs.outputJSON(path.resolve(distDirectory, NESTED_ROUTE_SPEC_FILE), nestedRoutes);
|
189
|
+
return {
|
190
|
+
entrypoint,
|
191
|
+
code
|
192
|
+
};
|
177
193
|
}
|
178
194
|
};
|
179
195
|
}
|
@@ -0,0 +1,54 @@
|
|
1
|
+
const JS_EXTENSIONS = [".js", ".ts", ".jsx", ".tsx"];
|
2
|
+
const INDEX_FILE_NAME = "index";
|
3
|
+
const APP_FILE_NAME = "App";
|
4
|
+
const PAGES_DIR_NAME = "pages";
|
5
|
+
const NESTED_ROUTES_DIR = "routes";
|
6
|
+
const FILE_SYSTEM_ROUTES_FILE_NAME = "routes.js";
|
7
|
+
const LOADER_EXPORT_NAME = "loader";
|
8
|
+
const TEMP_LOADERS_DIR = "__loaders__";
|
9
|
+
const ENTRY_POINT_FILE_NAME = "index.js";
|
10
|
+
const ENTRY_BOOTSTRAP_FILE_NAME = "bootstrap.js";
|
11
|
+
const FILE_SYSTEM_ROUTES_DYNAMIC_REGEXP = /^\[(\S+)\]([*+?]?)$/;
|
12
|
+
const FILE_SYSTEM_ROUTES_LAYOUT = "_layout";
|
13
|
+
const FILE_SYSTEM_ROUTES_GLOBAL_LAYOUT = "_app";
|
14
|
+
const FILE_SYSTEM_ROUTES_INDEX = "index";
|
15
|
+
const FILE_SYSTEM_ROUTES_IGNORED_REGEX = /\.(d|test|spec|e2e)\.(js|jsx|ts|tsx)$/;
|
16
|
+
const HTML_PARTIALS_FOLDER = "html";
|
17
|
+
const HTML_PARTIALS_EXTENSIONS = [".htm", ".html", ".ejs"];
|
18
|
+
const FILE_SYSTEM_ROUTES_COMPONENTS_DIR = "internal_components";
|
19
|
+
const NESTED_ROUTE = {
|
20
|
+
LAYOUT_FILE: "layout",
|
21
|
+
LAYOUT_LOADER_FILE: "layout.loader",
|
22
|
+
PAGE_FILE: "page",
|
23
|
+
PAGE_LOADER_FILE: "page.loader",
|
24
|
+
LOADING_FILE: "loading",
|
25
|
+
ERROR_FILE: "error",
|
26
|
+
LOADER_FILE: "loader"
|
27
|
+
};
|
28
|
+
const APP_CONFIG_NAME = "config";
|
29
|
+
const APP_INIT_EXPORTED = "init";
|
30
|
+
const APP_INIT_IMPORTED = "appInit";
|
31
|
+
export {
|
32
|
+
APP_CONFIG_NAME,
|
33
|
+
APP_FILE_NAME,
|
34
|
+
APP_INIT_EXPORTED,
|
35
|
+
APP_INIT_IMPORTED,
|
36
|
+
ENTRY_BOOTSTRAP_FILE_NAME,
|
37
|
+
ENTRY_POINT_FILE_NAME,
|
38
|
+
FILE_SYSTEM_ROUTES_COMPONENTS_DIR,
|
39
|
+
FILE_SYSTEM_ROUTES_DYNAMIC_REGEXP,
|
40
|
+
FILE_SYSTEM_ROUTES_FILE_NAME,
|
41
|
+
FILE_SYSTEM_ROUTES_GLOBAL_LAYOUT,
|
42
|
+
FILE_SYSTEM_ROUTES_IGNORED_REGEX,
|
43
|
+
FILE_SYSTEM_ROUTES_INDEX,
|
44
|
+
FILE_SYSTEM_ROUTES_LAYOUT,
|
45
|
+
HTML_PARTIALS_EXTENSIONS,
|
46
|
+
HTML_PARTIALS_FOLDER,
|
47
|
+
INDEX_FILE_NAME,
|
48
|
+
JS_EXTENSIONS,
|
49
|
+
LOADER_EXPORT_NAME,
|
50
|
+
NESTED_ROUTE,
|
51
|
+
NESTED_ROUTES_DIR,
|
52
|
+
PAGES_DIR_NAME,
|
53
|
+
TEMP_LOADERS_DIR
|
54
|
+
};
|
@@ -0,0 +1,247 @@
|
|
1
|
+
var __async = (__this, __arguments, generator) => {
|
2
|
+
return new Promise((resolve, reject) => {
|
3
|
+
var fulfilled = (value) => {
|
4
|
+
try {
|
5
|
+
step(generator.next(value));
|
6
|
+
} catch (e) {
|
7
|
+
reject(e);
|
8
|
+
}
|
9
|
+
};
|
10
|
+
var rejected = (value) => {
|
11
|
+
try {
|
12
|
+
step(generator.throw(value));
|
13
|
+
} catch (e) {
|
14
|
+
reject(e);
|
15
|
+
}
|
16
|
+
};
|
17
|
+
var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
|
18
|
+
step((generator = generator.apply(__this, __arguments)).next());
|
19
|
+
});
|
20
|
+
};
|
21
|
+
import path from "path";
|
22
|
+
import { fs, getEntryOptions, logger } from "@modern-js/utils";
|
23
|
+
import {
|
24
|
+
useResolvedConfigContext
|
25
|
+
} from "@modern-js/core";
|
26
|
+
import * as templates from "./templates";
|
27
|
+
import { getClientRoutes, getClientRoutesLegacy } from "./getClientRoutes";
|
28
|
+
import {
|
29
|
+
FILE_SYSTEM_ROUTES_FILE_NAME,
|
30
|
+
ENTRY_POINT_FILE_NAME,
|
31
|
+
ENTRY_BOOTSTRAP_FILE_NAME
|
32
|
+
} from "./constants";
|
33
|
+
import { getDefaultImports, getServerLoadersFile } from "./utils";
|
34
|
+
import { walk } from "./nestedRoutes";
|
35
|
+
const createImportSpecifier = (specifiers) => {
|
36
|
+
let defaults = "";
|
37
|
+
const named = [];
|
38
|
+
for (const { local, imported } of specifiers) {
|
39
|
+
if (local && imported) {
|
40
|
+
named.push(`${imported} as ${local}`);
|
41
|
+
} else if (local) {
|
42
|
+
defaults = local;
|
43
|
+
} else {
|
44
|
+
named.push(imported);
|
45
|
+
}
|
46
|
+
}
|
47
|
+
if (defaults && named.length) {
|
48
|
+
return `${defaults}, { ${named.join(", ")} }`;
|
49
|
+
} else if (defaults) {
|
50
|
+
return defaults;
|
51
|
+
} else {
|
52
|
+
return `{ ${named.join(", ")} }`;
|
53
|
+
}
|
54
|
+
};
|
55
|
+
const createImportStatements = (statements) => {
|
56
|
+
var _a, _b;
|
57
|
+
const deDuplicated = [];
|
58
|
+
const seen = /* @__PURE__ */ new Map();
|
59
|
+
for (const { value, specifiers, initialize } of statements) {
|
60
|
+
if (!seen.has(value)) {
|
61
|
+
deDuplicated.push({
|
62
|
+
value,
|
63
|
+
specifiers,
|
64
|
+
initialize
|
65
|
+
});
|
66
|
+
seen.set(value, specifiers);
|
67
|
+
} else {
|
68
|
+
seen.get(value).push(...specifiers);
|
69
|
+
const modifyIndex = deDuplicated.findIndex((v) => v.value === value);
|
70
|
+
const originInitialize = (_b = (_a = deDuplicated[modifyIndex]) == null ? void 0 : _a.initialize) != null ? _b : "";
|
71
|
+
deDuplicated[modifyIndex].initialize = originInitialize.concat(
|
72
|
+
`
|
73
|
+
${initialize || ""}`
|
74
|
+
);
|
75
|
+
}
|
76
|
+
}
|
77
|
+
return deDuplicated.map(
|
78
|
+
({ value, specifiers, initialize }) => `import ${createImportSpecifier(specifiers)} from '${value}';
|
79
|
+
${initialize || ""}`
|
80
|
+
).join("\n");
|
81
|
+
};
|
82
|
+
const generateCode = (appContext, config, entrypoints, api) => __async(void 0, null, function* () {
|
83
|
+
var _a, _b, _c;
|
84
|
+
const {
|
85
|
+
internalDirectory,
|
86
|
+
srcDirectory,
|
87
|
+
internalDirAlias,
|
88
|
+
internalSrcAlias,
|
89
|
+
packageName
|
90
|
+
} = appContext;
|
91
|
+
const hookRunners = api.useHookRunners();
|
92
|
+
const isV5 = typeof ((_a = config.runtime) == null ? void 0 : _a.router) !== "boolean" && ((_c = (_b = config == null ? void 0 : config.runtime) == null ? void 0 : _b.router) == null ? void 0 : _c.mode) === "react-router-5";
|
93
|
+
const { mountId } = config.html;
|
94
|
+
const getRoutes = isV5 ? getClientRoutesLegacy : getClientRoutes;
|
95
|
+
yield Promise.all(entrypoints.map(generateEntryCode));
|
96
|
+
function generateEntryCode(entrypoint) {
|
97
|
+
return __async(this, null, function* () {
|
98
|
+
const { entryName, isAutoMount, customBootstrap, fileSystemRoutes } = entrypoint;
|
99
|
+
if (isAutoMount) {
|
100
|
+
if (fileSystemRoutes) {
|
101
|
+
let initialRoutes = [];
|
102
|
+
let nestedRoute = null;
|
103
|
+
if (entrypoint.entry) {
|
104
|
+
initialRoutes = getRoutes({
|
105
|
+
entrypoint,
|
106
|
+
srcDirectory,
|
107
|
+
srcAlias: internalSrcAlias,
|
108
|
+
internalDirectory,
|
109
|
+
internalDirAlias
|
110
|
+
});
|
111
|
+
}
|
112
|
+
if (entrypoint.nestedRoutesEntry) {
|
113
|
+
if (!isV5) {
|
114
|
+
nestedRoute = yield walk(
|
115
|
+
entrypoint.nestedRoutesEntry,
|
116
|
+
entrypoint.nestedRoutesEntry,
|
117
|
+
{
|
118
|
+
name: internalSrcAlias,
|
119
|
+
basename: srcDirectory
|
120
|
+
},
|
121
|
+
entrypoint.entryName
|
122
|
+
);
|
123
|
+
if (nestedRoute) {
|
124
|
+
initialRoutes.unshift(nestedRoute);
|
125
|
+
}
|
126
|
+
} else {
|
127
|
+
logger.error("Nested routes is not supported in legacy mode.");
|
128
|
+
process.exit(1);
|
129
|
+
}
|
130
|
+
}
|
131
|
+
const { routes } = yield hookRunners.modifyFileSystemRoutes({
|
132
|
+
entrypoint,
|
133
|
+
routes: initialRoutes
|
134
|
+
});
|
135
|
+
const config2 = useResolvedConfigContext();
|
136
|
+
const ssr = getEntryOptions(
|
137
|
+
entryName,
|
138
|
+
config2.server.ssr,
|
139
|
+
config2.server.ssrByEntries,
|
140
|
+
packageName
|
141
|
+
);
|
142
|
+
let mode;
|
143
|
+
if (ssr) {
|
144
|
+
mode = typeof ssr === "object" ? ssr.mode || "string" : "string";
|
145
|
+
} else {
|
146
|
+
mode = false;
|
147
|
+
}
|
148
|
+
if (mode === "stream") {
|
149
|
+
const hasPageRoute = routes.some(
|
150
|
+
(route) => "type" in route && route.type === "page"
|
151
|
+
);
|
152
|
+
if (hasPageRoute) {
|
153
|
+
logger.error(
|
154
|
+
"Streaming ssr is not supported when pages dir exists"
|
155
|
+
);
|
156
|
+
process.exit(1);
|
157
|
+
}
|
158
|
+
}
|
159
|
+
const { code: code2 } = yield hookRunners.beforeGenerateRoutes({
|
160
|
+
entrypoint,
|
161
|
+
code: yield templates.fileSystemRoutes({
|
162
|
+
routes,
|
163
|
+
ssrMode: mode,
|
164
|
+
nestedRoutesEntry: entrypoint.nestedRoutesEntry,
|
165
|
+
entryName: entrypoint.entryName,
|
166
|
+
internalDirectory
|
167
|
+
})
|
168
|
+
});
|
169
|
+
if (entrypoint.nestedRoutesEntry && mode) {
|
170
|
+
const routesServerFile = getServerLoadersFile(
|
171
|
+
internalDirectory,
|
172
|
+
entryName
|
173
|
+
);
|
174
|
+
const code3 = templates.routesForServer({
|
175
|
+
routes
|
176
|
+
});
|
177
|
+
yield fs.ensureFile(routesServerFile);
|
178
|
+
yield fs.writeFile(routesServerFile, code3);
|
179
|
+
}
|
180
|
+
fs.outputFileSync(
|
181
|
+
path.resolve(
|
182
|
+
internalDirectory,
|
183
|
+
`./${entryName}/${FILE_SYSTEM_ROUTES_FILE_NAME}`
|
184
|
+
),
|
185
|
+
code2,
|
186
|
+
"utf8"
|
187
|
+
);
|
188
|
+
}
|
189
|
+
const { imports: importStatements } = yield hookRunners.modifyEntryImports({
|
190
|
+
entrypoint,
|
191
|
+
imports: getDefaultImports({
|
192
|
+
entrypoint,
|
193
|
+
srcDirectory,
|
194
|
+
internalSrcAlias,
|
195
|
+
internalDirAlias,
|
196
|
+
internalDirectory
|
197
|
+
})
|
198
|
+
});
|
199
|
+
const { plugins } = yield hookRunners.modifyEntryRuntimePlugins({
|
200
|
+
entrypoint,
|
201
|
+
plugins: []
|
202
|
+
});
|
203
|
+
const { code: renderFunction } = yield hookRunners.modifyEntryRenderFunction({
|
204
|
+
entrypoint,
|
205
|
+
code: templates.renderFunction({
|
206
|
+
plugins,
|
207
|
+
customBootstrap,
|
208
|
+
fileSystemRoutes
|
209
|
+
})
|
210
|
+
});
|
211
|
+
const { exportStatement } = yield hookRunners.modifyEntryExport({
|
212
|
+
entrypoint,
|
213
|
+
exportStatement: "export default AppWrapper;"
|
214
|
+
});
|
215
|
+
const code = templates.index({
|
216
|
+
mountId,
|
217
|
+
imports: createImportStatements(importStatements),
|
218
|
+
renderFunction,
|
219
|
+
exportStatement
|
220
|
+
});
|
221
|
+
const entryFile = path.resolve(
|
222
|
+
internalDirectory,
|
223
|
+
`./${entryName}/${ENTRY_POINT_FILE_NAME}`
|
224
|
+
);
|
225
|
+
entrypoint.entry = entryFile;
|
226
|
+
if (config.source.enableAsyncEntry) {
|
227
|
+
const { code: asyncEntryCode } = yield hookRunners.modifyAsyncEntry({
|
228
|
+
entrypoint,
|
229
|
+
code: `import('./${ENTRY_BOOTSTRAP_FILE_NAME}');`
|
230
|
+
});
|
231
|
+
fs.outputFileSync(entryFile, asyncEntryCode, "utf8");
|
232
|
+
const bootstrapFile = path.resolve(
|
233
|
+
internalDirectory,
|
234
|
+
`./${entryName}/${ENTRY_BOOTSTRAP_FILE_NAME}`
|
235
|
+
);
|
236
|
+
fs.outputFileSync(bootstrapFile, code, "utf8");
|
237
|
+
} else {
|
238
|
+
fs.outputFileSync(entryFile, code, "utf8");
|
239
|
+
}
|
240
|
+
}
|
241
|
+
});
|
242
|
+
}
|
243
|
+
});
|
244
|
+
export {
|
245
|
+
createImportStatements,
|
246
|
+
generateCode
|
247
|
+
};
|
@@ -0,0 +1,71 @@
|
|
1
|
+
import path from "path";
|
2
|
+
import {
|
3
|
+
ensureAbsolutePath,
|
4
|
+
fs,
|
5
|
+
findExists,
|
6
|
+
MAIN_ENTRY_NAME
|
7
|
+
} from "@modern-js/utils";
|
8
|
+
import { getFileSystemEntry } from "./getFileSystemEntry";
|
9
|
+
import { JS_EXTENSIONS } from "./constants";
|
10
|
+
const ensureExtensions = (file) => {
|
11
|
+
if (!path.extname(file)) {
|
12
|
+
return findExists(JS_EXTENSIONS.map((ext) => `${file}${ext}`)) || file;
|
13
|
+
}
|
14
|
+
return file;
|
15
|
+
};
|
16
|
+
const ifAlreadyExists = (entrypoints, checked) => entrypoints.some((entrypoint) => {
|
17
|
+
if (ensureExtensions(entrypoint.entry) === ensureExtensions(checked.entry)) {
|
18
|
+
checked.entryName = entrypoint.entryName;
|
19
|
+
return true;
|
20
|
+
}
|
21
|
+
if (entrypoint.entry.startsWith(checked.entry) || checked.entry.startsWith(entrypoint.entry)) {
|
22
|
+
throw new Error(
|
23
|
+
`Entry configuration conflicts
|
24
|
+
Your configuration: ${checked.entry}.
|
25
|
+
Default entrypoint: ${entrypoint.entry}
|
26
|
+
Please reset source.entries or set source.disableDefaultEntries to disable the default entry rules.`
|
27
|
+
);
|
28
|
+
}
|
29
|
+
return false;
|
30
|
+
});
|
31
|
+
const getBundleEntry = (appContext, config) => {
|
32
|
+
const { appDirectory, packageName } = appContext;
|
33
|
+
const {
|
34
|
+
source: { disableDefaultEntries, entries, entriesDir }
|
35
|
+
} = config;
|
36
|
+
const defaults = disableDefaultEntries ? [] : getFileSystemEntry(appContext, config);
|
37
|
+
if (entries) {
|
38
|
+
Object.keys(entries).forEach((name) => {
|
39
|
+
const value = entries[name];
|
40
|
+
const entrypoint = typeof value === "string" ? {
|
41
|
+
entryName: name,
|
42
|
+
entry: ensureAbsolutePath(appDirectory, value),
|
43
|
+
isAutoMount: true,
|
44
|
+
fileSystemRoutes: fs.statSync(ensureAbsolutePath(appDirectory, value)).isDirectory() ? {} : void 0
|
45
|
+
} : {
|
46
|
+
entryName: name,
|
47
|
+
entry: ensureAbsolutePath(appDirectory, value.entry),
|
48
|
+
isAutoMount: !value.disableMount,
|
49
|
+
customBootstrap: value.customBootstrap && ensureAbsolutePath(appDirectory, value.customBootstrap),
|
50
|
+
fileSystemRoutes: fs.statSync(ensureAbsolutePath(appDirectory, value.entry)).isDirectory() ? {} : void 0
|
51
|
+
};
|
52
|
+
if (entrypoint.fileSystemRoutes) {
|
53
|
+
entrypoint.nestedRoutesEntry = entrypoint.entry;
|
54
|
+
}
|
55
|
+
if (!ifAlreadyExists(defaults, entrypoint)) {
|
56
|
+
defaults.push(entrypoint);
|
57
|
+
}
|
58
|
+
});
|
59
|
+
}
|
60
|
+
if (!disableDefaultEntries) {
|
61
|
+
const entriesDirAbs = ensureAbsolutePath(appDirectory, entriesDir || "");
|
62
|
+
const found = defaults.find(
|
63
|
+
({ entryName, entry, nestedRoutesEntry = "" }) => entryName === packageName || path.dirname(entry) === entriesDirAbs || path.dirname(nestedRoutesEntry) === entriesDirAbs
|
64
|
+
);
|
65
|
+
found && (found.entryName = MAIN_ENTRY_NAME);
|
66
|
+
}
|
67
|
+
return defaults;
|
68
|
+
};
|
69
|
+
export {
|
70
|
+
getBundleEntry
|
71
|
+
};
|