@modern-js/app-tools 2.0.0-beta.3 → 2.0.0-beta.6
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/CHANGELOG.md +619 -0
- package/bin/modern.js +3 -0
- package/dist/js/modern/analyze/Builder.js +39 -0
- package/dist/js/modern/analyze/constants.js +48 -18
- package/dist/js/modern/analyze/generateCode.js +264 -225
- package/dist/js/modern/analyze/getBundleEntry.js +34 -32
- package/dist/js/modern/analyze/getClientRoutes/getRoutes.js +99 -52
- package/dist/js/modern/analyze/getClientRoutes/getRoutesLegacy.js +89 -47
- package/dist/js/modern/analyze/getClientRoutes/index.js +6 -2
- package/dist/js/modern/analyze/getClientRoutes/utils.js +23 -10
- package/dist/js/modern/analyze/getFileSystemEntry.js +52 -23
- package/dist/js/modern/analyze/getHtmlTemplate.js +89 -49
- package/dist/js/modern/analyze/getServerRoutes.js +122 -126
- package/dist/js/modern/analyze/index.js +204 -161
- package/dist/js/modern/analyze/isDefaultExportFunction.js +30 -16
- package/dist/js/modern/analyze/makeLegalIdentifier.js +10 -11
- package/dist/js/modern/analyze/nestedRoutes.js +118 -65
- package/dist/js/modern/analyze/templates.js +170 -81
- package/dist/js/modern/analyze/utils.js +104 -67
- package/dist/js/modern/builder/builderPlugins/compatModern.js +128 -109
- package/dist/js/modern/builder/index.js +120 -89
- package/dist/js/modern/builder/loaders/routerLoader.js +9 -12
- package/dist/js/modern/builder/loaders/serverModuleLoader.js +4 -1
- package/dist/js/modern/builder/share.js +23 -21
- package/dist/js/modern/builder/webpackPlugins/htmlAsyncChunkPlugin.js +23 -22
- package/dist/js/modern/builder/webpackPlugins/htmlBottomTemplate.js +31 -27
- package/dist/js/modern/builder/webpackPlugins/routerPlugin.js +100 -84
- package/dist/js/modern/commands/build.js +67 -42
- package/dist/js/modern/commands/deploy.js +27 -4
- package/dist/js/modern/commands/dev.js +81 -34
- package/dist/js/modern/commands/index.js +1 -1
- package/dist/js/modern/commands/inspect.js +30 -5
- package/dist/js/modern/commands/serve.js +54 -0
- package/dist/js/modern/config/default.js +112 -145
- package/dist/js/modern/config/index.js +8 -2
- package/dist/js/modern/config/initial/createHtmlConfig.js +5 -2
- package/dist/js/modern/config/initial/createOutputConfig.js +10 -13
- package/dist/js/modern/config/initial/createSourceConfig.js +10 -3
- package/dist/js/modern/config/initial/createToolsConfig.js +7 -6
- package/dist/js/modern/config/initial/index.js +9 -4
- package/dist/js/modern/config/initial/inits.js +109 -73
- package/dist/js/modern/config/initial/transformNormalizedConfig.js +11 -4
- package/dist/js/modern/defineConfig.js +26 -11
- package/dist/js/modern/exports/server.js +4 -1
- package/dist/js/modern/hooks.js +16 -4
- package/dist/js/modern/index.js +178 -90
- package/dist/js/modern/initialize/index.js +100 -52
- package/dist/js/modern/locale/en.js +20 -21
- package/dist/js/modern/locale/index.js +6 -6
- package/dist/js/modern/locale/zh.js +21 -22
- package/dist/js/modern/schema/Schema.js +6 -5
- package/dist/js/modern/schema/index.js +53 -100
- package/dist/js/modern/schema/legacy.js +96 -231
- package/dist/js/modern/types/config/index.js +0 -1
- package/dist/js/modern/types/index.js +0 -1
- package/dist/js/modern/types/legacyConfig/output.js +0 -1
- package/dist/js/modern/utils/commands.js +10 -2
- package/dist/js/modern/utils/config.js +102 -41
- package/dist/js/modern/utils/createFileWatcher.js +84 -51
- package/dist/js/modern/utils/createServer.js +63 -17
- package/dist/js/modern/utils/getServerInternalPlugins.js +58 -0
- package/dist/js/modern/utils/getSpecifiedEntries.js +46 -19
- package/dist/js/modern/utils/language.js +6 -3
- package/dist/js/modern/utils/printInstructions.js +27 -8
- package/dist/js/modern/utils/restart.js +43 -16
- package/dist/js/modern/utils/routes.js +29 -12
- package/dist/js/node/analyze/Builder.js +64 -0
- package/dist/js/node/analyze/constants.js +86 -39
- package/dist/js/node/analyze/generateCode.js +285 -239
- package/dist/js/node/analyze/getBundleEntry.js +62 -44
- package/dist/js/node/analyze/getClientRoutes/getRoutes.js +138 -77
- package/dist/js/node/analyze/getClientRoutes/getRoutesLegacy.js +130 -74
- package/dist/js/node/analyze/getClientRoutes/index.js +27 -16
- package/dist/js/node/analyze/getClientRoutes/utils.js +51 -21
- package/dist/js/node/analyze/getFileSystemEntry.js +82 -39
- package/dist/js/node/analyze/getHtmlTemplate.js +120 -61
- package/dist/js/node/analyze/getServerRoutes.js +145 -137
- package/dist/js/node/analyze/index.js +233 -174
- package/dist/js/node/analyze/isDefaultExportFunction.js +59 -26
- package/dist/js/node/analyze/makeLegalIdentifier.js +31 -15
- package/dist/js/node/analyze/nestedRoutes.js +150 -79
- package/dist/js/node/analyze/templates.js +198 -90
- package/dist/js/node/analyze/utils.js +136 -81
- package/dist/js/node/builder/builderPlugins/compatModern.js +158 -122
- package/dist/js/node/builder/index.js +142 -98
- package/dist/js/node/builder/loaders/routerLoader.js +29 -18
- package/dist/js/node/builder/loaders/serverModuleLoader.js +24 -7
- package/dist/js/node/builder/share.js +50 -26
- package/dist/js/node/builder/webpackPlugins/htmlAsyncChunkPlugin.js +43 -26
- package/dist/js/node/builder/webpackPlugins/htmlBottomTemplate.js +51 -31
- package/dist/js/node/builder/webpackPlugins/routerPlugin.js +120 -90
- package/dist/js/node/commands/build.js +91 -52
- package/dist/js/node/commands/deploy.js +49 -10
- package/dist/js/node/commands/dev.js +105 -48
- package/dist/js/node/commands/index.js +19 -38
- package/dist/js/node/commands/inspect.js +52 -11
- package/dist/js/node/commands/serve.js +83 -0
- package/dist/js/node/config/default.js +131 -149
- package/dist/js/node/config/index.js +31 -28
- package/dist/js/node/config/initial/createHtmlConfig.js +26 -6
- package/dist/js/node/config/initial/createOutputConfig.js +31 -17
- package/dist/js/node/config/initial/createSourceConfig.js +31 -7
- package/dist/js/node/config/initial/createToolsConfig.js +28 -10
- package/dist/js/node/config/initial/index.js +34 -17
- package/dist/js/node/config/initial/inits.js +130 -81
- package/dist/js/node/config/initial/transformNormalizedConfig.js +40 -16
- package/dist/js/node/defineConfig.js +46 -17
- package/dist/js/node/exports/server.js +25 -10
- package/dist/js/node/hooks.js +53 -29
- package/dist/js/node/index.js +213 -129
- package/dist/js/node/initialize/index.js +117 -61
- package/dist/js/node/locale/en.js +40 -25
- package/dist/js/node/locale/index.js +31 -14
- package/dist/js/node/locale/zh.js +41 -26
- package/dist/js/node/schema/Schema.js +27 -10
- package/dist/js/node/schema/index.js +84 -114
- package/dist/js/node/schema/legacy.js +119 -240
- 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 -16
- 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 -38
- 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 -5
- 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/commands.js +31 -6
- package/dist/js/node/utils/config.js +125 -51
- package/dist/js/node/utils/createFileWatcher.js +109 -61
- package/dist/js/node/utils/createServer.js +92 -25
- package/dist/js/node/utils/getServerInternalPlugins.js +79 -0
- package/dist/js/node/utils/getSpecifiedEntries.js +68 -25
- package/dist/js/node/utils/language.js +28 -8
- package/dist/js/node/utils/printInstructions.js +51 -16
- package/dist/js/node/utils/restart.js +65 -21
- package/dist/js/node/utils/routes.js +58 -19
- package/dist/js/node/utils/types.js +15 -0
- package/dist/js/treeshaking/analyze/Builder.js +199 -0
- package/dist/js/treeshaking/analyze/constants.js +37 -18
- package/dist/js/treeshaking/analyze/generateCode.js +597 -407
- package/dist/js/treeshaking/analyze/getBundleEntry.js +55 -63
- package/dist/js/treeshaking/analyze/getClientRoutes/getRoutes.js +217 -168
- package/dist/js/treeshaking/analyze/getClientRoutes/getRoutesLegacy.js +215 -169
- package/dist/js/treeshaking/analyze/getClientRoutes/index.js +3 -2
- package/dist/js/treeshaking/analyze/getClientRoutes/utils.js +19 -20
- package/dist/js/treeshaking/analyze/getFileSystemEntry.js +97 -86
- package/dist/js/treeshaking/analyze/getHtmlTemplate.js +298 -125
- package/dist/js/treeshaking/analyze/getServerRoutes.js +210 -147
- package/dist/js/treeshaking/analyze/index.js +575 -305
- package/dist/js/treeshaking/analyze/isDefaultExportFunction.js +45 -26
- package/dist/js/treeshaking/analyze/makeLegalIdentifier.js +13 -16
- package/dist/js/treeshaking/analyze/nestedRoutes.js +419 -201
- package/dist/js/treeshaking/analyze/templates.js +438 -236
- package/dist/js/treeshaking/analyze/utils.js +367 -153
- package/dist/js/treeshaking/builder/builderPlugins/compatModern.js +285 -199
- package/dist/js/treeshaking/builder/index.js +365 -165
- package/dist/js/treeshaking/builder/loaders/routerLoader.js +11 -12
- package/dist/js/treeshaking/builder/loaders/serverModuleLoader.js +3 -2
- package/dist/js/treeshaking/builder/share.js +38 -44
- package/dist/js/treeshaking/builder/webpackPlugins/htmlAsyncChunkPlugin.js +108 -44
- package/dist/js/treeshaking/builder/webpackPlugins/htmlBottomTemplate.js +70 -39
- package/dist/js/treeshaking/builder/webpackPlugins/routerPlugin.js +334 -112
- package/dist/js/treeshaking/commands/build.js +286 -88
- package/dist/js/treeshaking/commands/deploy.js +153 -25
- package/dist/js/treeshaking/commands/dev.js +313 -131
- package/dist/js/treeshaking/commands/index.js +1 -1
- package/dist/js/treeshaking/commands/inspect.js +147 -32
- package/dist/js/treeshaking/commands/serve.js +199 -0
- package/dist/js/treeshaking/config/default.js +207 -198
- package/dist/js/treeshaking/config/index.js +3 -2
- package/dist/js/treeshaking/config/initial/createHtmlConfig.js +19 -31
- package/dist/js/treeshaking/config/initial/createOutputConfig.js +41 -70
- package/dist/js/treeshaking/config/initial/createSourceConfig.js +41 -40
- package/dist/js/treeshaking/config/initial/createToolsConfig.js +23 -38
- package/dist/js/treeshaking/config/initial/index.js +10 -9
- package/dist/js/treeshaking/config/initial/inits.js +205 -106
- package/dist/js/treeshaking/config/initial/transformNormalizedConfig.js +31 -34
- package/dist/js/treeshaking/defineConfig.js +60 -13
- package/dist/js/treeshaking/exports/server.js +2 -1
- package/dist/js/treeshaking/hooks.js +31 -25
- package/dist/js/treeshaking/index.js +681 -256
- package/dist/js/treeshaking/initialize/index.js +292 -113
- package/dist/js/treeshaking/locale/en.js +34 -33
- package/dist/js/treeshaking/locale/index.js +5 -5
- package/dist/js/treeshaking/locale/zh.js +34 -33
- package/dist/js/treeshaking/schema/Schema.js +267 -69
- package/dist/js/treeshaking/schema/index.js +171 -121
- package/dist/js/treeshaking/schema/legacy.js +323 -256
- 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 +0 -1
- 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 +0 -1
- 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 -1
- 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/commands.js +10 -5
- package/dist/js/treeshaking/utils/config.js +295 -117
- package/dist/js/treeshaking/utils/createFileWatcher.js +278 -118
- package/dist/js/treeshaking/utils/createServer.js +252 -67
- package/dist/js/treeshaking/utils/getServerInternalPlugins.js +210 -0
- package/dist/js/treeshaking/utils/getSpecifiedEntries.js +182 -55
- package/dist/js/treeshaking/utils/language.js +6 -5
- package/dist/js/treeshaking/utils/printInstructions.js +151 -29
- package/dist/js/treeshaking/utils/restart.js +184 -42
- package/dist/js/treeshaking/utils/routes.js +151 -27
- package/dist/js/treeshaking/utils/types.js +1 -0
- package/dist/types/analyze/Builder.d.ts +8 -0
- package/dist/types/analyze/constants.d.ts +10 -1
- package/dist/types/analyze/index.d.ts +2 -0
- package/dist/types/analyze/templates.d.ts +3 -1
- package/dist/types/analyze/utils.d.ts +2 -1
- package/dist/types/builder/builderPlugins/compatModern.d.ts +2 -1
- package/dist/types/builder/index.d.ts +3 -3
- package/dist/types/builder/webpackPlugins/routerPlugin.d.ts +1 -7
- package/dist/types/commands/index.d.ts +1 -1
- package/dist/types/commands/{start.d.ts → serve.d.ts} +0 -0
- package/dist/types/defineConfig.d.ts +1 -0
- package/dist/types/index.d.ts +7 -1
- package/dist/types/initialize/index.d.ts +2 -0
- package/dist/types/locale/en.d.ts +1 -1
- package/dist/types/locale/index.d.ts +2 -2
- package/dist/types/locale/zh.d.ts +1 -1
- package/dist/types/types/config/dev.d.ts +2 -2
- package/dist/types/types/config/index.d.ts +4 -0
- package/dist/types/types/config/output.d.ts +0 -1
- package/dist/types/types/config/source.d.ts +2 -0
- package/dist/types/types/config/tools.d.ts +2 -0
- package/dist/types/types/hooks.d.ts +8 -0
- package/dist/types/types/legacyConfig/dev.d.ts +1 -0
- package/dist/types/types/legacyConfig/output.d.ts +1 -1
- package/dist/types/types/legacyConfig/source.d.ts +1 -0
- package/dist/types/types/legacyConfig/tools.d.ts +1 -0
- package/dist/types/utils/commands.d.ts +2 -1
- package/dist/types/utils/config.d.ts +1 -0
- package/dist/types/utils/createServer.d.ts +1 -0
- package/dist/types/utils/getServerInternalPlugins.d.ts +2 -0
- package/dist/types/utils/restart.d.ts +1 -1
- package/package.json +26 -22
- package/dist/js/modern/commands/start.js +0 -30
- package/dist/js/node/commands/start.js +0 -38
- package/dist/js/treeshaking/commands/start.js +0 -69
|
@@ -1,69 +1,61 @@
|
|
|
1
|
-
import path from
|
|
2
|
-
import { ensureAbsolutePath, fs, findExists, MAIN_ENTRY_NAME } from
|
|
1
|
+
import path from "path";
|
|
2
|
+
import { ensureAbsolutePath, fs, findExists, MAIN_ENTRY_NAME } from "@modern-js/utils";
|
|
3
3
|
import { getFileSystemEntry } from "./getFileSystemEntry";
|
|
4
4
|
import { JS_EXTENSIONS } from "./constants";
|
|
5
|
-
var ensureExtensions = function
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
5
|
+
var ensureExtensions = function(file) {
|
|
6
|
+
if (!path.extname(file)) {
|
|
7
|
+
return findExists(JS_EXTENSIONS.map(function(ext) {
|
|
8
|
+
return "".concat(file).concat(ext);
|
|
9
|
+
})) || file;
|
|
10
|
+
}
|
|
11
|
+
return file;
|
|
12
|
+
};
|
|
13
|
+
var ifAlreadyExists = function(entrypoints, checked) {
|
|
14
|
+
return entrypoints.some(function(entrypoint) {
|
|
15
|
+
if (ensureExtensions(entrypoint.entry) === ensureExtensions(checked.entry)) {
|
|
16
|
+
checked.entryName = entrypoint.entryName;
|
|
17
|
+
return true;
|
|
18
|
+
}
|
|
19
|
+
if (entrypoint.entry.startsWith(checked.entry) || checked.entry.startsWith(entrypoint.entry)) {
|
|
20
|
+
throw new Error("Entry configuration conflicts\n Your configuration: ".concat(checked.entry, ".\n Default entrypoint: ").concat(entrypoint.entry, "\n Please reset source.entries or set source.disableDefaultEntries to disable the default entry rules."));
|
|
21
|
+
}
|
|
22
|
+
return false;
|
|
23
|
+
});
|
|
12
24
|
};
|
|
13
|
-
var
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
25
|
+
var getBundleEntry = function(appContext, config) {
|
|
26
|
+
var appDirectory = appContext.appDirectory, packageName = appContext.packageName;
|
|
27
|
+
var _source = config.source, disableDefaultEntries = _source.disableDefaultEntries, entries = _source.entries, entriesDir = _source.entriesDir;
|
|
28
|
+
var defaults = disableDefaultEntries ? [] : getFileSystemEntry(appContext, config);
|
|
29
|
+
if (entries) {
|
|
30
|
+
Object.keys(entries).forEach(function(name) {
|
|
31
|
+
var value = entries[name];
|
|
32
|
+
var entrypoint = typeof value === "string" ? {
|
|
33
|
+
entryName: name,
|
|
34
|
+
entry: ensureAbsolutePath(appDirectory, value),
|
|
35
|
+
isAutoMount: true,
|
|
36
|
+
fileSystemRoutes: fs.statSync(ensureAbsolutePath(appDirectory, value)).isDirectory() ? {} : void 0
|
|
37
|
+
} : {
|
|
38
|
+
entryName: name,
|
|
39
|
+
entry: ensureAbsolutePath(appDirectory, value.entry),
|
|
40
|
+
isAutoMount: !value.disableMount,
|
|
41
|
+
fileSystemRoutes: value.enableFileSystemRoutes ? {} : void 0
|
|
42
|
+
};
|
|
43
|
+
if (entrypoint.fileSystemRoutes) {
|
|
44
|
+
entrypoint.nestedRoutesEntry = entrypoint.entry;
|
|
45
|
+
}
|
|
46
|
+
if (!ifAlreadyExists(defaults, entrypoint)) {
|
|
47
|
+
defaults.push(entrypoint);
|
|
48
|
+
}
|
|
49
|
+
});
|
|
19
50
|
}
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
51
|
+
if (!disableDefaultEntries) {
|
|
52
|
+
var entriesDirAbs = ensureAbsolutePath(appDirectory, entriesDir || "");
|
|
53
|
+
var found = defaults.find(function(param) {
|
|
54
|
+
var entryName = param.entryName, entry = param.entry, _nestedRoutesEntry = param.nestedRoutesEntry, nestedRoutesEntry = _nestedRoutesEntry === void 0 ? "" : _nestedRoutesEntry;
|
|
55
|
+
return entryName === packageName || path.dirname(entry) === entriesDirAbs || path.dirname(nestedRoutesEntry) === entriesDirAbs;
|
|
56
|
+
});
|
|
57
|
+
found && (found.entryName = MAIN_ENTRY_NAME);
|
|
23
58
|
}
|
|
24
|
-
return
|
|
25
|
-
});
|
|
59
|
+
return defaults;
|
|
26
60
|
};
|
|
27
|
-
export
|
|
28
|
-
var appDirectory = appContext.appDirectory,
|
|
29
|
-
packageName = appContext.packageName;
|
|
30
|
-
var _config$source = config.source,
|
|
31
|
-
disableDefaultEntries = _config$source.disableDefaultEntries,
|
|
32
|
-
entries = _config$source.entries,
|
|
33
|
-
entriesDir = _config$source.entriesDir;
|
|
34
|
-
var defaults = disableDefaultEntries ? [] : getFileSystemEntry(appContext, config);
|
|
35
|
-
|
|
36
|
-
// merge entrypoints from user config with directory convention.
|
|
37
|
-
if (entries) {
|
|
38
|
-
Object.keys(entries).forEach(function (name) {
|
|
39
|
-
var value = entries[name];
|
|
40
|
-
var entrypoint = typeof value === 'string' ? {
|
|
41
|
-
entryName: name,
|
|
42
|
-
entry: ensureAbsolutePath(appDirectory, value),
|
|
43
|
-
isAutoMount: true,
|
|
44
|
-
fileSystemRoutes: fs.statSync(ensureAbsolutePath(appDirectory, value)).isDirectory() ? {} : undefined
|
|
45
|
-
} : {
|
|
46
|
-
entryName: name,
|
|
47
|
-
entry: ensureAbsolutePath(appDirectory, value.entry),
|
|
48
|
-
isAutoMount: !value.disableMount,
|
|
49
|
-
fileSystemRoutes: value.enableFileSystemRoutes ? {} : undefined
|
|
50
|
-
};
|
|
51
|
-
if (!ifAlreadyExists(defaults, entrypoint)) {
|
|
52
|
-
defaults.push(entrypoint);
|
|
53
|
-
}
|
|
54
|
-
});
|
|
55
|
-
}
|
|
56
|
-
if (!disableDefaultEntries) {
|
|
57
|
-
// find main entry point which server route is '/'.
|
|
58
|
-
var entriesDirAbs = ensureAbsolutePath(appDirectory, entriesDir || '');
|
|
59
|
-
var found = defaults.find(function (_ref) {
|
|
60
|
-
var entryName = _ref.entryName,
|
|
61
|
-
entry = _ref.entry,
|
|
62
|
-
_ref$nestedRoutesEntr = _ref.nestedRoutesEntry,
|
|
63
|
-
nestedRoutesEntry = _ref$nestedRoutesEntr === void 0 ? '' : _ref$nestedRoutesEntr;
|
|
64
|
-
return entryName === packageName || path.dirname(entry) === entriesDirAbs || path.dirname(nestedRoutesEntry) === entriesDirAbs;
|
|
65
|
-
});
|
|
66
|
-
found && (found.entryName = MAIN_ENTRY_NAME);
|
|
67
|
-
}
|
|
68
|
-
return defaults;
|
|
69
|
-
};
|
|
61
|
+
export { getBundleEntry };
|
|
@@ -1,184 +1,233 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
1
|
+
function _defineProperty(obj, key, value) {
|
|
2
|
+
if (key in obj) {
|
|
3
|
+
Object.defineProperty(obj, key, {
|
|
4
|
+
value: value,
|
|
5
|
+
enumerable: true,
|
|
6
|
+
configurable: true,
|
|
7
|
+
writable: true
|
|
8
|
+
});
|
|
9
|
+
} else {
|
|
10
|
+
obj[key] = value;
|
|
11
|
+
}
|
|
12
|
+
return obj;
|
|
13
|
+
}
|
|
14
|
+
function _objectSpread(target) {
|
|
15
|
+
for(var i = 1; i < arguments.length; i++){
|
|
16
|
+
var source = arguments[i] != null ? arguments[i] : {};
|
|
17
|
+
var ownKeys = Object.keys(source);
|
|
18
|
+
if (typeof Object.getOwnPropertySymbols === "function") {
|
|
19
|
+
ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {
|
|
20
|
+
return Object.getOwnPropertyDescriptor(source, sym).enumerable;
|
|
21
|
+
}));
|
|
22
|
+
}
|
|
23
|
+
ownKeys.forEach(function(key) {
|
|
24
|
+
_defineProperty(target, key, source[key]);
|
|
25
|
+
});
|
|
26
|
+
}
|
|
27
|
+
return target;
|
|
28
|
+
}
|
|
29
|
+
function ownKeys(object, enumerableOnly) {
|
|
30
|
+
var keys = Object.keys(object);
|
|
31
|
+
if (Object.getOwnPropertySymbols) {
|
|
32
|
+
var symbols = Object.getOwnPropertySymbols(object);
|
|
33
|
+
if (enumerableOnly) {
|
|
34
|
+
symbols = symbols.filter(function(sym) {
|
|
35
|
+
return Object.getOwnPropertyDescriptor(object, sym).enumerable;
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
keys.push.apply(keys, symbols);
|
|
39
|
+
}
|
|
40
|
+
return keys;
|
|
41
|
+
}
|
|
42
|
+
function _objectSpreadProps(target, source) {
|
|
43
|
+
source = source != null ? source : {};
|
|
44
|
+
if (Object.getOwnPropertyDescriptors) {
|
|
45
|
+
Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
|
|
46
|
+
} else {
|
|
47
|
+
ownKeys(Object(source)).forEach(function(key) {
|
|
48
|
+
Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
return target;
|
|
52
|
+
}
|
|
53
|
+
import path from "path";
|
|
54
|
+
import { fs } from "@modern-js/utils";
|
|
5
55
|
import { makeLegalIdentifier } from "../makeLegalIdentifier";
|
|
6
56
|
import { FILE_SYSTEM_ROUTES_COMPONENTS_DIR, FILE_SYSTEM_ROUTES_DYNAMIC_REGEXP, FILE_SYSTEM_ROUTES_INDEX, FILE_SYSTEM_ROUTES_LAYOUT } from "../constants";
|
|
7
57
|
import { replaceWithAlias } from "../utils";
|
|
8
58
|
import { debug, findLayout, shouldSkip, getRouteWeight } from "./utils";
|
|
9
|
-
var compName = function
|
|
10
|
-
|
|
11
|
-
|
|
59
|
+
var compName = function(srcDirectory, filePath) {
|
|
60
|
+
var legalCompName = makeLegalIdentifier(path.relative(srcDirectory, filePath));
|
|
61
|
+
return "Comp_".concat(legalCompName);
|
|
12
62
|
};
|
|
13
|
-
var layoutNameAbbr = function
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
63
|
+
var layoutNameAbbr = function(filePath) {
|
|
64
|
+
var prefix = "L_";
|
|
65
|
+
var dirName = path.dirname(filePath).split("/").pop() || "";
|
|
66
|
+
return "".concat(prefix).concat(makeLegalIdentifier(dirName));
|
|
17
67
|
};
|
|
18
68
|
var parents = [];
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
var
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
type: 'page'
|
|
45
|
-
};
|
|
46
|
-
parent = route;
|
|
47
|
-
resetParent = true;
|
|
48
|
-
routes.push(route);
|
|
49
|
-
parents.push(route);
|
|
50
|
-
routes = route.children;
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
var _iterator = _createForOfIteratorHelper(fs.readdirSync(dir)),
|
|
54
|
-
_step;
|
|
55
|
-
try {
|
|
56
|
-
for (_iterator.s(); !(_step = _iterator.n()).done;) {
|
|
57
|
-
var relative = _step.value;
|
|
58
|
-
var filePath = path.join(dir, relative);
|
|
59
|
-
if (!shouldSkip(filePath)) {
|
|
60
|
-
var filename = path.basename(filePath, path.extname(filePath));
|
|
61
|
-
var _alias = replaceWithAlias(srcDirectory, filePath, srcAlias);
|
|
62
|
-
var _componentName = compName(srcDirectory, filePath);
|
|
63
|
-
var dynamicRouteMatched = FILE_SYSTEM_ROUTES_DYNAMIC_REGEXP.exec(filename);
|
|
64
|
-
if (dynamicRouteMatched) {
|
|
65
|
-
if (hasDynamicRoute) {
|
|
66
|
-
throw new Error("Can't set two dynamic route in one directory: ".concat(dir));
|
|
67
|
-
} else {
|
|
68
|
-
hasDynamicRoute = true;
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
var _route = {
|
|
72
|
-
path: "".concat(basePath).concat(dynamicRouteMatched ? ":".concat(dynamicRouteMatched[1]).concat(dynamicRouteMatched[2]) : filename),
|
|
73
|
-
_component: _alias,
|
|
74
|
-
component: _componentName,
|
|
75
|
-
parent: parent,
|
|
76
|
-
type: 'page'
|
|
77
|
-
};
|
|
78
|
-
if (fs.statSync(filePath).isDirectory()) {
|
|
79
|
-
recursiveReadDir({
|
|
80
|
-
dir: filePath,
|
|
81
|
-
routes: routes,
|
|
82
|
-
basePath: "".concat(_route.path, "/"),
|
|
83
|
-
srcDirectory: srcDirectory,
|
|
84
|
-
srcAlias: srcAlias
|
|
85
|
-
});
|
|
86
|
-
continue;
|
|
87
|
-
}
|
|
88
|
-
if (filename === FILE_SYSTEM_ROUTES_LAYOUT) {
|
|
89
|
-
continue;
|
|
69
|
+
var recursiveReadDir = function(param) {
|
|
70
|
+
var dir = param.dir, routes = param.routes, _basePath = param.basePath, basePath = _basePath === void 0 ? "/" : _basePath, srcDirectory = param.srcDirectory, srcAlias = param.srcAlias;
|
|
71
|
+
var hasDynamicRoute = false;
|
|
72
|
+
var resetParent = false;
|
|
73
|
+
var parent = parents[parents.length - 1];
|
|
74
|
+
var layout = findLayout(dir);
|
|
75
|
+
if (layout) {
|
|
76
|
+
if (basePath === "/") {
|
|
77
|
+
throw new Error("should use _app instead of _layout in ".concat(dir));
|
|
78
|
+
} else {
|
|
79
|
+
var alias = replaceWithAlias(srcDirectory, layout, srcAlias);
|
|
80
|
+
var componentName = compName(srcDirectory, layout);
|
|
81
|
+
var route = {
|
|
82
|
+
path: "".concat(basePath.substring(0, basePath.length - 1)),
|
|
83
|
+
children: [],
|
|
84
|
+
_component: alias,
|
|
85
|
+
component: componentName,
|
|
86
|
+
parent: parent,
|
|
87
|
+
type: "page"
|
|
88
|
+
};
|
|
89
|
+
parent = route;
|
|
90
|
+
resetParent = true;
|
|
91
|
+
routes.push(route);
|
|
92
|
+
parents.push(route);
|
|
93
|
+
routes = route.children;
|
|
90
94
|
}
|
|
91
|
-
|
|
92
|
-
|
|
95
|
+
}
|
|
96
|
+
var _iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = undefined;
|
|
97
|
+
try {
|
|
98
|
+
for(var _iterator = fs.readdirSync(dir)[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true){
|
|
99
|
+
var relative = _step.value;
|
|
100
|
+
var filePath = path.join(dir, relative);
|
|
101
|
+
if (!shouldSkip(filePath)) {
|
|
102
|
+
var filename = path.basename(filePath, path.extname(filePath));
|
|
103
|
+
var alias1 = replaceWithAlias(srcDirectory, filePath, srcAlias);
|
|
104
|
+
var componentName1 = compName(srcDirectory, filePath);
|
|
105
|
+
var dynamicRouteMatched = FILE_SYSTEM_ROUTES_DYNAMIC_REGEXP.exec(filename);
|
|
106
|
+
if (dynamicRouteMatched) {
|
|
107
|
+
if (hasDynamicRoute) {
|
|
108
|
+
throw new Error("Can't set two dynamic route in one directory: ".concat(dir));
|
|
109
|
+
} else {
|
|
110
|
+
hasDynamicRoute = true;
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
var route1 = {
|
|
114
|
+
path: "".concat(basePath).concat(dynamicRouteMatched ? ":".concat(dynamicRouteMatched[1]).concat(dynamicRouteMatched[2]) : filename),
|
|
115
|
+
_component: alias1,
|
|
116
|
+
component: componentName1,
|
|
117
|
+
parent: parent,
|
|
118
|
+
type: "page"
|
|
119
|
+
};
|
|
120
|
+
if (fs.statSync(filePath).isDirectory()) {
|
|
121
|
+
recursiveReadDir({
|
|
122
|
+
dir: filePath,
|
|
123
|
+
routes: routes,
|
|
124
|
+
basePath: "".concat(route1.path, "/"),
|
|
125
|
+
srcDirectory: srcDirectory,
|
|
126
|
+
srcAlias: srcAlias
|
|
127
|
+
});
|
|
128
|
+
continue;
|
|
129
|
+
}
|
|
130
|
+
if (filename === FILE_SYSTEM_ROUTES_LAYOUT) {
|
|
131
|
+
continue;
|
|
132
|
+
}
|
|
133
|
+
if (filename === FILE_SYSTEM_ROUTES_INDEX) {
|
|
134
|
+
route1.path = basePath === "/" ? basePath : "".concat(basePath.substring(0, basePath.length - 1));
|
|
135
|
+
}
|
|
136
|
+
if (filename === "404" && basePath === "/") {
|
|
137
|
+
route1.path = "*";
|
|
138
|
+
}
|
|
139
|
+
routes.push(route1);
|
|
140
|
+
}
|
|
93
141
|
}
|
|
94
|
-
|
|
95
|
-
|
|
142
|
+
} catch (err) {
|
|
143
|
+
_didIteratorError = true;
|
|
144
|
+
_iteratorError = err;
|
|
145
|
+
} finally{
|
|
146
|
+
try {
|
|
147
|
+
if (!_iteratorNormalCompletion && _iterator.return != null) {
|
|
148
|
+
_iterator.return();
|
|
149
|
+
}
|
|
150
|
+
} finally{
|
|
151
|
+
if (_didIteratorError) {
|
|
152
|
+
throw _iteratorError;
|
|
153
|
+
}
|
|
96
154
|
}
|
|
97
|
-
routes.push(_route);
|
|
98
|
-
}
|
|
99
155
|
}
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
} finally {
|
|
103
|
-
_iterator.f();
|
|
104
|
-
}
|
|
105
|
-
if (resetParent) {
|
|
106
|
-
parents.pop();
|
|
107
|
-
}
|
|
108
|
-
};
|
|
109
|
-
/* eslint-enable no-param-reassign */
|
|
110
|
-
|
|
111
|
-
var normalizeNestedRoutes = function normalizeNestedRoutes(nested, internalComponentsDir, internalDirectory, internalDirAlias) {
|
|
112
|
-
var flat = function flat(routes) {
|
|
113
|
-
return routes.reduce(function (memo, route) {
|
|
114
|
-
return memo.concat(Array.isArray(route.children) ? flat(route.children) : [route]);
|
|
115
|
-
}, []);
|
|
116
|
-
};
|
|
117
|
-
var generate = function generate(route) {
|
|
118
|
-
var codes = [];
|
|
119
|
-
var lastComponent = route.component;
|
|
120
|
-
var imports = ["import React from 'react';", "import ".concat(lastComponent, " from '").concat(route._component, "'")];
|
|
121
|
-
|
|
122
|
-
// eslint-disable-next-line no-param-reassign, no-cond-assign
|
|
123
|
-
while (route = route.parent) {
|
|
124
|
-
var layoutComponent = route.component;
|
|
125
|
-
var layoutComponentAbbr = layoutNameAbbr(route._component);
|
|
126
|
-
imports.push("import ".concat(layoutComponent, " from '").concat(route._component, "';"));
|
|
127
|
-
var currentComponent = "".concat(layoutComponentAbbr, "_").concat(lastComponent);
|
|
128
|
-
codes.push("const ".concat(currentComponent, " = props => <").concat(layoutComponent, " Component={").concat(lastComponent, "} {...props} />;"));
|
|
129
|
-
lastComponent = currentComponent;
|
|
156
|
+
if (resetParent) {
|
|
157
|
+
parents.pop();
|
|
130
158
|
}
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
159
|
+
};
|
|
160
|
+
var normalizeNestedRoutes = function(nested, internalComponentsDir, internalDirectory, internalDirAlias) {
|
|
161
|
+
var flat = function(routes) {
|
|
162
|
+
return routes.reduce(function(memo, route) {
|
|
163
|
+
return memo.concat(Array.isArray(route.children) ? flat(route.children) : [
|
|
164
|
+
route
|
|
165
|
+
]);
|
|
166
|
+
}, []);
|
|
167
|
+
};
|
|
168
|
+
var generate = function(route) {
|
|
169
|
+
var codes = [];
|
|
170
|
+
var lastComponent = route.component;
|
|
171
|
+
var imports = [
|
|
172
|
+
"import React from 'react';",
|
|
173
|
+
"import ".concat(lastComponent, " from '").concat(route._component, "'")
|
|
174
|
+
];
|
|
175
|
+
while(route = route.parent){
|
|
176
|
+
var layoutComponent = route.component;
|
|
177
|
+
var layoutComponentAbbr = layoutNameAbbr(route._component);
|
|
178
|
+
imports.push("import ".concat(layoutComponent, " from '").concat(route._component, "';"));
|
|
179
|
+
var currentComponent = "".concat(layoutComponentAbbr, "_").concat(lastComponent);
|
|
180
|
+
codes.push("const ".concat(currentComponent, " = props => <").concat(layoutComponent, " Component={").concat(lastComponent, "} {...props} />;"));
|
|
181
|
+
lastComponent = currentComponent;
|
|
182
|
+
}
|
|
183
|
+
var file = path.resolve(internalComponentsDir, "".concat(lastComponent, ".jsx"));
|
|
184
|
+
fs.outputFileSync(file, "".concat(imports.join("\n"), "\n").concat(codes.join("\n"), "\nexport default ").concat(lastComponent));
|
|
185
|
+
return {
|
|
186
|
+
component: lastComponent,
|
|
187
|
+
_component: replaceWithAlias(internalDirectory, file, internalDirAlias)
|
|
188
|
+
};
|
|
136
189
|
};
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
190
|
+
var normalized = flat(nested).map(function(route) {
|
|
191
|
+
return route.parent ? _objectSpreadProps(_objectSpread({}, route, generate(route)), {
|
|
192
|
+
parent: void 0
|
|
193
|
+
}) : _objectSpreadProps(_objectSpread({}, route), {
|
|
194
|
+
parent: void 0
|
|
195
|
+
});
|
|
143
196
|
});
|
|
144
|
-
|
|
145
|
-
return normalized;
|
|
197
|
+
return normalized;
|
|
146
198
|
};
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
internalDirAlias = _ref2.internalDirAlias;
|
|
153
|
-
var entry = entrypoint.entry,
|
|
154
|
-
entryName = entrypoint.entryName;
|
|
155
|
-
if (!fs.existsSync(entry)) {
|
|
156
|
-
throw new Error("generate file system routes error, ".concat(entry, " directory not found."));
|
|
157
|
-
}
|
|
158
|
-
if (!(fs.existsSync(entry) && fs.statSync(entry).isDirectory())) {
|
|
159
|
-
throw new Error("generate file system routes error, ".concat(entry, " should be directory."));
|
|
160
|
-
}
|
|
161
|
-
var routes = [];
|
|
162
|
-
recursiveReadDir({
|
|
163
|
-
dir: entry,
|
|
164
|
-
routes: routes,
|
|
165
|
-
basePath: '/',
|
|
166
|
-
srcDirectory: srcDirectory,
|
|
167
|
-
srcAlias: srcAlias
|
|
168
|
-
});
|
|
169
|
-
var internalComponentsDir = path.resolve(internalDirectory, "".concat(entryName, "/").concat(FILE_SYSTEM_ROUTES_COMPONENTS_DIR));
|
|
170
|
-
fs.emptyDirSync(internalComponentsDir);
|
|
171
|
-
routes = normalizeNestedRoutes(routes, internalComponentsDir, internalDirectory, internalDirAlias);
|
|
172
|
-
parents.length = 0;
|
|
173
|
-
|
|
174
|
-
// FIXME: support more situations
|
|
175
|
-
routes.sort(function (a, b) {
|
|
176
|
-
var delta = getRouteWeight(a.path) - getRouteWeight(b.path);
|
|
177
|
-
if (delta === 0) {
|
|
178
|
-
return a.path.length - b.path.length;
|
|
199
|
+
var getClientRoutes = function(param) {
|
|
200
|
+
var entrypoint = param.entrypoint, srcDirectory = param.srcDirectory, srcAlias = param.srcAlias, internalDirectory = param.internalDirectory, internalDirAlias = param.internalDirAlias;
|
|
201
|
+
var entryName = entrypoint.entryName, pageRoutesEntry = entrypoint.pageRoutesEntry;
|
|
202
|
+
if (!pageRoutesEntry) {
|
|
203
|
+
return [];
|
|
179
204
|
}
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
205
|
+
if (!fs.existsSync(pageRoutesEntry)) {
|
|
206
|
+
throw new Error("generate file system routes error, ".concat(pageRoutesEntry, " directory not found."));
|
|
207
|
+
}
|
|
208
|
+
if (!(fs.existsSync(pageRoutesEntry) && fs.statSync(pageRoutesEntry).isDirectory())) {
|
|
209
|
+
throw new Error("generate file system routes error, ".concat(pageRoutesEntry, " should be directory."));
|
|
210
|
+
}
|
|
211
|
+
var routes = [];
|
|
212
|
+
recursiveReadDir({
|
|
213
|
+
dir: pageRoutesEntry,
|
|
214
|
+
routes: routes,
|
|
215
|
+
basePath: "/",
|
|
216
|
+
srcDirectory: srcDirectory,
|
|
217
|
+
srcAlias: srcAlias
|
|
218
|
+
});
|
|
219
|
+
var internalComponentsDir = path.resolve(internalDirectory, "".concat(entryName, "/").concat(FILE_SYSTEM_ROUTES_COMPONENTS_DIR));
|
|
220
|
+
fs.emptyDirSync(internalComponentsDir);
|
|
221
|
+
routes = normalizeNestedRoutes(routes, internalComponentsDir, internalDirectory, internalDirAlias);
|
|
222
|
+
parents.length = 0;
|
|
223
|
+
routes.sort(function(a, b) {
|
|
224
|
+
var delta = getRouteWeight(a.path) - getRouteWeight(b.path);
|
|
225
|
+
if (delta === 0) {
|
|
226
|
+
return a.path.length - b.path.length;
|
|
227
|
+
}
|
|
228
|
+
return delta;
|
|
229
|
+
});
|
|
230
|
+
debug("fileSystem routes: %o", routes);
|
|
231
|
+
return routes;
|
|
232
|
+
};
|
|
233
|
+
export { getClientRoutes };
|