@modern-js/app-tools 2.5.1-alpha.0 → 2.5.1-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/dist/cjs/analyze/generateCode.js +19 -13
- package/dist/cjs/analyze/getBundleEntry.js +1 -1
- package/dist/cjs/builder/builder-webpack/builderPlugins/compatModern.js +3 -3
- package/dist/cjs/builder/builder-webpack/index.js +11 -5
- package/dist/cjs/builder/generator/getBuilderTargets.js +1 -1
- package/dist/cjs/commands/dev.js +12 -14
- package/dist/cjs/commands/serve.js +17 -0
- package/dist/cjs/config/legacy/createToolsConfig.js +1 -4
- package/dist/esm/analyze/generateCode.js +37 -26
- package/dist/esm/analyze/getBundleEntry.js +2 -2
- package/dist/esm/builder/builder-webpack/builderPlugins/compatModern.js +2 -2
- package/dist/esm/builder/builder-webpack/index.js +11 -7
- package/dist/esm/builder/generator/getBuilderTargets.js +1 -1
- package/dist/esm/commands/dev.js +9 -8
- package/dist/esm/commands/serve.js +6 -1
- package/dist/esm/config/legacy/createToolsConfig.js +1 -4
- package/dist/esm-node/analyze/generateCode.js +20 -14
- package/dist/esm-node/analyze/getBundleEntry.js +2 -3
- package/dist/esm-node/builder/builder-webpack/builderPlugins/compatModern.js +2 -2
- package/dist/esm-node/builder/builder-webpack/index.js +12 -6
- package/dist/esm-node/builder/generator/getBuilderTargets.js +1 -1
- package/dist/esm-node/commands/dev.js +12 -14
- package/dist/esm-node/commands/serve.js +18 -1
- package/dist/esm-node/config/legacy/createToolsConfig.js +1 -4
- package/dist/js/modern/analyze/constants.js +3 -1
- package/dist/js/modern/analyze/getServerRoutes.js +5 -2
- package/dist/js/modern/analyze/index.js +47 -46
- package/dist/js/modern/analyze/nestedRoutes.js +32 -3
- package/dist/js/modern/analyze/templates.js +4 -10
- package/dist/js/modern/builder/builder-rspack/index.js +8 -0
- package/dist/js/modern/builder/builder-webpack/builderPlugins/compatModern.js +41 -0
- package/dist/js/modern/builder/builder-webpack/index.js +93 -0
- package/dist/js/modern/builder/{webpackPlugins/routerPlugin.js → builder-webpack/webpackPlugins/RouterPlugin.js} +4 -1
- package/dist/js/modern/builder/builder-webpack/webpackPlugins/index.js +1 -0
- package/dist/js/modern/builder/generator/createBuilderOptions.js +24 -0
- package/dist/js/modern/builder/generator/createBuilderProviderConfig.js +39 -0
- package/dist/js/modern/builder/generator/getBuilderTargets.js +21 -0
- package/dist/js/modern/builder/generator/index.js +53 -0
- package/dist/js/modern/builder/index.js +13 -133
- package/dist/js/modern/builder/{builderPlugins/compatModern.js → shared/builderPlugins/adapterModern.js} +102 -116
- package/dist/js/modern/builder/shared/bundlerPlugins/HtmlAsyncChunkPlugin.js +27 -0
- package/dist/js/modern/builder/shared/bundlerPlugins/HtmlBottomTemplate.js +34 -0
- package/dist/js/modern/builder/shared/index.js +3 -0
- package/dist/js/modern/builder/shared/types.js +0 -0
- package/dist/js/modern/config/default.js +2 -2
- package/dist/js/modern/config/index.js +3 -8
- package/dist/js/modern/config/initialize/index.js +12 -0
- package/dist/js/modern/config/{initial → initialize}/inits.js +4 -2
- package/dist/js/modern/config/{initial/transformNormalizedConfig.js → legacy/index.js} +4 -0
- package/dist/js/modern/index.js +18 -8
- package/dist/js/modern/initialize/index.js +36 -28
- package/dist/js/modern/locale/zh.js +1 -1
- package/dist/js/modern/types/utils.js +0 -0
- package/dist/js/node/analyze/constants.js +3 -1
- package/dist/js/node/analyze/getServerRoutes.js +3 -1
- package/dist/js/node/analyze/index.js +48 -47
- package/dist/js/node/analyze/nestedRoutes.js +32 -3
- package/dist/js/node/analyze/templates.js +4 -10
- package/dist/js/node/{config/initial → builder/builder-rspack}/index.js +9 -19
- package/dist/js/node/builder/builder-webpack/builderPlugins/compatModern.js +64 -0
- package/dist/js/node/builder/builder-webpack/index.js +118 -0
- package/dist/js/node/builder/{webpackPlugins/routerPlugin.js → builder-webpack/webpackPlugins/RouterPlugin.js} +10 -5
- package/dist/js/node/builder/builder-webpack/webpackPlugins/index.js +17 -0
- package/dist/js/node/builder/generator/createBuilderOptions.js +47 -0
- package/dist/js/node/builder/generator/createBuilderProviderConfig.js +60 -0
- package/dist/js/node/builder/generator/getBuilderTargets.js +39 -0
- package/dist/js/node/builder/generator/index.js +82 -0
- package/dist/js/node/builder/index.js +14 -123
- package/dist/js/node/builder/{builderPlugins/compatModern.js → shared/builderPlugins/adapterModern.js} +107 -120
- package/dist/js/node/builder/{webpackPlugins/htmlAsyncChunkPlugin.js → shared/bundlerPlugins/HtmlAsyncChunkPlugin.js} +17 -20
- package/dist/js/node/builder/{webpackPlugins/htmlBottomTemplate.js → shared/bundlerPlugins/HtmlBottomTemplate.js} +21 -24
- package/dist/js/node/builder/{share.js → shared/createCopyPattern.js} +3 -3
- package/dist/js/node/builder/shared/index.js +19 -0
- package/dist/js/node/builder/shared/types.js +15 -0
- package/dist/js/node/config/default.js +2 -2
- package/dist/js/node/config/index.js +4 -19
- package/dist/js/node/{builder/loaders/routerLoader.js → config/initialize/index.js} +14 -17
- package/dist/js/node/config/{initial → initialize}/inits.js +4 -2
- package/dist/js/node/config/{initial/transformNormalizedConfig.js → legacy/index.js} +8 -3
- package/dist/js/node/index.js +18 -8
- package/dist/js/node/initialize/index.js +35 -28
- package/dist/js/node/locale/zh.js +1 -1
- package/dist/js/node/types/utils.js +15 -0
- package/dist/js/treeshaking/analyze/constants.js +3 -1
- package/dist/js/treeshaking/analyze/generateCode.js +14 -14
- package/dist/js/treeshaking/analyze/getBundleEntry.js +2 -2
- package/dist/js/treeshaking/analyze/getClientRoutes/getRoutes.js +1 -1
- package/dist/js/treeshaking/analyze/getClientRoutes/getRoutesLegacy.js +1 -1
- package/dist/js/treeshaking/analyze/getFileSystemEntry.js +1 -1
- package/dist/js/treeshaking/analyze/getServerRoutes.js +8 -6
- package/dist/js/treeshaking/analyze/index.js +142 -137
- package/dist/js/treeshaking/analyze/nestedRoutes.js +29 -4
- package/dist/js/treeshaking/analyze/templates.js +10 -13
- package/dist/js/treeshaking/analyze/utils.js +3 -3
- package/dist/js/treeshaking/builder/builder-rspack/index.js +6 -0
- package/dist/js/treeshaking/builder/builder-webpack/builderPlugins/compatModern.js +64 -0
- package/dist/js/treeshaking/builder/builder-webpack/index.js +301 -0
- package/dist/js/treeshaking/builder/{webpackPlugins/routerPlugin.js → builder-webpack/webpackPlugins/RouterPlugin.js} +6 -3
- package/dist/js/treeshaking/builder/builder-webpack/webpackPlugins/index.js +1 -0
- package/dist/js/treeshaking/builder/generator/createBuilderOptions.js +41 -0
- package/dist/js/treeshaking/builder/generator/createBuilderProviderConfig.js +70 -0
- package/dist/js/treeshaking/builder/generator/getBuilderTargets.js +16 -0
- package/dist/js/treeshaking/builder/generator/index.js +199 -0
- package/dist/js/treeshaking/builder/index.js +29 -228
- package/dist/js/treeshaking/builder/{builderPlugins/compatModern.js → shared/builderPlugins/adapterModern.js} +138 -142
- package/dist/js/treeshaking/builder/{webpackPlugins/htmlBottomTemplate.js → shared/bundlerPlugins/HtmlBottomTemplate.js} +2 -2
- package/dist/js/treeshaking/builder/shared/index.js +3 -0
- package/dist/js/treeshaking/builder/shared/types.js +1 -0
- package/dist/js/treeshaking/commands/dev.js +2 -2
- package/dist/js/treeshaking/commands/serve.js +2 -2
- package/dist/js/treeshaking/config/default.js +2 -2
- package/dist/js/treeshaking/config/index.js +3 -3
- package/dist/js/treeshaking/config/initialize/index.js +10 -0
- package/dist/js/treeshaking/config/{initial → initialize}/inits.js +6 -4
- package/dist/js/treeshaking/config/legacy/createHtmlConfig.js +19 -0
- package/dist/js/treeshaking/config/{initial → legacy}/createOutputConfig.js +1 -1
- package/dist/js/treeshaking/config/{initial → legacy}/createSourceConfig.js +1 -1
- package/dist/js/treeshaking/config/{initial → legacy}/createToolsConfig.js +1 -1
- package/dist/js/treeshaking/config/{initial/transformNormalizedConfig.js → legacy/index.js} +4 -1
- package/dist/js/treeshaking/index.js +19 -12
- package/dist/js/treeshaking/initialize/index.js +36 -28
- package/dist/js/treeshaking/locale/zh.js +1 -1
- package/dist/js/treeshaking/types/utils.js +1 -0
- package/dist/js/treeshaking/utils/config.js +2 -2
- package/dist/js/treeshaking/utils/getServerInternalPlugins.js +2 -2
- package/dist/types/builder/builder-webpack/builderPlugins/compatModern.d.ts +7 -1
- package/package.json +6 -6
- package/dist/js/modern/builder/loaders/routerLoader.js +0 -17
- package/dist/js/modern/builder/webpackPlugins/htmlAsyncChunkPlugin.js +0 -30
- package/dist/js/modern/builder/webpackPlugins/htmlBottomTemplate.js +0 -37
- package/dist/js/modern/config/initial/index.js +0 -16
- package/dist/js/treeshaking/builder/loaders/routerLoader.js +0 -13
- package/dist/js/treeshaking/config/initial/createHtmlConfig.js +0 -19
- package/dist/js/treeshaking/config/initial/index.js +0 -12
- /package/dist/js/modern/builder/{share.js → shared/createCopyPattern.js} +0 -0
- /package/dist/js/modern/builder/{loaders → shared/loaders}/serverModuleLoader.js +0 -0
- /package/dist/js/modern/config/{initial → legacy}/createHtmlConfig.js +0 -0
- /package/dist/js/modern/config/{initial → legacy}/createOutputConfig.js +0 -0
- /package/dist/js/modern/config/{initial → legacy}/createSourceConfig.js +0 -0
- /package/dist/js/modern/config/{initial → legacy}/createToolsConfig.js +0 -0
- /package/dist/js/node/builder/{loaders → shared/loaders}/serverModuleLoader.js +0 -0
- /package/dist/js/node/config/{initial → legacy}/createHtmlConfig.js +0 -0
- /package/dist/js/node/config/{initial → legacy}/createOutputConfig.js +0 -0
- /package/dist/js/node/config/{initial → legacy}/createSourceConfig.js +0 -0
- /package/dist/js/node/config/{initial → legacy}/createToolsConfig.js +0 -0
- /package/dist/js/treeshaking/builder/{webpackPlugins/htmlAsyncChunkPlugin.js → shared/bundlerPlugins/HtmlAsyncChunkPlugin.js} +0 -0
- /package/dist/js/treeshaking/builder/{share.js → shared/createCopyPattern.js} +0 -0
- /package/dist/js/treeshaking/builder/{loaders → shared/loaders}/serverModuleLoader.js +0 -0
package/dist/js/node/index.js
CHANGED
|
@@ -127,7 +127,9 @@ const buildCommand = (program, api) => __async(void 0, null, function* () {
|
|
|
127
127
|
}
|
|
128
128
|
}
|
|
129
129
|
});
|
|
130
|
-
var src_default = (
|
|
130
|
+
var src_default = (options = {
|
|
131
|
+
bundler: "webpack"
|
|
132
|
+
}) => ({
|
|
131
133
|
name: "@modern-js/app-tools",
|
|
132
134
|
post: [
|
|
133
135
|
"@modern-js/plugin-initialize",
|
|
@@ -140,7 +142,15 @@ var src_default = () => ({
|
|
|
140
142
|
"@modern-js/plugin-polyfill"
|
|
141
143
|
],
|
|
142
144
|
registerHook: import_hooks.hooks,
|
|
143
|
-
usePlugins: [
|
|
145
|
+
usePlugins: [
|
|
146
|
+
(0, import_initialize.default)({
|
|
147
|
+
bundler: (options == null ? void 0 : options.bundler) === "experimental-rspack" ? "rspack" : "webpack"
|
|
148
|
+
}),
|
|
149
|
+
(0, import_analyze.default)({
|
|
150
|
+
bundler: (options == null ? void 0 : options.bundler) === "experimental-rspack" ? "rspack" : "webpack"
|
|
151
|
+
}),
|
|
152
|
+
(0, import_plugin_lint.default)()
|
|
153
|
+
],
|
|
144
154
|
setup: (api) => {
|
|
145
155
|
const locale = (0, import_language.getLocaleLanguage)();
|
|
146
156
|
import_locale.i18n.changeLanguage({ locale });
|
|
@@ -159,19 +169,19 @@ var src_default = () => ({
|
|
|
159
169
|
program.command("deploy").usage("[options]").option(
|
|
160
170
|
"-c --config <config>",
|
|
161
171
|
import_locale.i18n.t(import_locale.localeKeys.command.shared.config)
|
|
162
|
-
).description(import_locale.i18n.t(import_locale.localeKeys.command.deploy.describe)).action((
|
|
172
|
+
).description(import_locale.i18n.t(import_locale.localeKeys.command.deploy.describe)).action((options2) => __async(this, null, function* () {
|
|
163
173
|
const { build } = yield Promise.resolve().then(() => __toESM(require("./commands/build")));
|
|
164
174
|
yield build(api);
|
|
165
175
|
const { deploy } = yield Promise.resolve().then(() => __toESM(require("./commands/deploy")));
|
|
166
|
-
yield deploy(api,
|
|
176
|
+
yield deploy(api, options2);
|
|
167
177
|
process.exit(0);
|
|
168
178
|
}));
|
|
169
179
|
program.command("new").usage("[options]").description(import_locale.i18n.t(import_locale.localeKeys.command.new.describe)).option("--lang <lang>", import_locale.i18n.t(import_locale.localeKeys.command.new.lang)).option("-d, --debug", import_locale.i18n.t(import_locale.localeKeys.command.new.debug), false).option(
|
|
170
180
|
"-c, --config <config>",
|
|
171
181
|
import_locale.i18n.t(import_locale.localeKeys.command.new.config)
|
|
172
|
-
).option("--dist-tag <tag>", import_locale.i18n.t(import_locale.localeKeys.command.new.distTag)).option("--registry", import_locale.i18n.t(import_locale.localeKeys.command.new.registry)).action((
|
|
182
|
+
).option("--dist-tag <tag>", import_locale.i18n.t(import_locale.localeKeys.command.new.distTag)).option("--registry", import_locale.i18n.t(import_locale.localeKeys.command.new.registry)).action((options2) => __async(this, null, function* () {
|
|
173
183
|
const { MWANewAction } = yield Promise.resolve().then(() => __toESM(require("@modern-js/new-action")));
|
|
174
|
-
yield MWANewAction(__spreadProps(__spreadValues({},
|
|
184
|
+
yield MWANewAction(__spreadProps(__spreadValues({}, options2), { locale: options2.lang || locale }));
|
|
175
185
|
}));
|
|
176
186
|
program.command("inspect").description("inspect internal webpack config").option(
|
|
177
187
|
`--env <env>`,
|
|
@@ -184,9 +194,9 @@ var src_default = () => ({
|
|
|
184
194
|
).option("--verbose", import_locale.i18n.t(import_locale.localeKeys.command.inspect.verbose)).option(
|
|
185
195
|
"-c --config <config>",
|
|
186
196
|
import_locale.i18n.t(import_locale.localeKeys.command.shared.config)
|
|
187
|
-
).action((
|
|
197
|
+
).action((options2) => __async(this, null, function* () {
|
|
188
198
|
const { inspect } = yield Promise.resolve().then(() => __toESM(require("./commands/inspect")));
|
|
189
|
-
inspect(api,
|
|
199
|
+
inspect(api, options2);
|
|
190
200
|
}));
|
|
191
201
|
upgradeModel.defineCommand(program.command("upgrade"));
|
|
192
202
|
});
|
|
@@ -59,15 +59,16 @@ __export(initialize_exports, {
|
|
|
59
59
|
module.exports = __toCommonJS(initialize_exports);
|
|
60
60
|
var import_utils = require("@modern-js/utils");
|
|
61
61
|
var import_schema = require("../schema");
|
|
62
|
-
var import_transformNormalizedConfig = require("../config/initial/transformNormalizedConfig");
|
|
63
62
|
var import_config = require("../config");
|
|
64
|
-
var initialize_default = (
|
|
63
|
+
var initialize_default = ({
|
|
64
|
+
bundler
|
|
65
|
+
}) => ({
|
|
65
66
|
name: "@modern-js/plugin-initialize",
|
|
66
67
|
setup(api) {
|
|
67
68
|
const config = () => {
|
|
68
69
|
const appContext = api.useAppContext();
|
|
69
70
|
const userConfig = api.useConfigContext();
|
|
70
|
-
return (0, import_config.checkIsLegacyConfig)(userConfig) ? (0, import_config.createLegacyDefaultConfig)(appContext) : (0, import_config.createDefaultConfig)(appContext);
|
|
71
|
+
return (0, import_config.checkIsLegacyConfig)(userConfig) ? (0, import_config.createLegacyDefaultConfig)(appContext) : (0, import_config.createDefaultConfig)(appContext, bundler);
|
|
71
72
|
};
|
|
72
73
|
const validateSchema = () => {
|
|
73
74
|
const userConfig = api.useConfigContext();
|
|
@@ -91,36 +92,42 @@ var initialize_default = () => ({
|
|
|
91
92
|
)
|
|
92
93
|
});
|
|
93
94
|
api.setAppContext(appContext);
|
|
94
|
-
const normalizedConfig = (0, import_config.checkIsLegacyConfig)(resolved) ? (0,
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
}
|
|
95
|
+
const normalizedConfig = (0, import_config.checkIsLegacyConfig)(resolved) ? (0, import_config.transformNormalizedConfig)(resolved) : resolved;
|
|
96
|
+
resolved._raw = userConfig;
|
|
97
|
+
resolved.server = __spreadProps(__spreadValues({}, normalizedConfig.server || {}), {
|
|
98
|
+
port
|
|
99
|
+
});
|
|
100
|
+
resolved.autoLoadPlugins = normalizedConfig.autoLoadPlugins || false;
|
|
101
|
+
stabilizeConfig(resolved, normalizedConfig, [
|
|
102
|
+
"source",
|
|
103
|
+
"bff",
|
|
104
|
+
"dev",
|
|
105
|
+
"html",
|
|
106
|
+
"output",
|
|
107
|
+
"tools",
|
|
108
|
+
"testing",
|
|
109
|
+
"plugins",
|
|
110
|
+
"builderPlugins",
|
|
111
|
+
"runtime",
|
|
112
|
+
"runtimeByEntries",
|
|
113
|
+
"deploy",
|
|
114
|
+
"performance"
|
|
115
|
+
]);
|
|
116
|
+
if (bundler === "webpack") {
|
|
117
|
+
resolved.security = normalizedConfig.security || {};
|
|
118
|
+
resolved.experiments = normalizedConfig.experiments;
|
|
119
|
+
}
|
|
120
|
+
return { resolved };
|
|
119
121
|
});
|
|
120
122
|
}
|
|
121
123
|
};
|
|
122
124
|
}
|
|
123
125
|
});
|
|
126
|
+
function stabilizeConfig(resolve, config, keys) {
|
|
127
|
+
keys.forEach((key) => {
|
|
128
|
+
resolve[key] = config[key] || {};
|
|
129
|
+
});
|
|
130
|
+
}
|
|
124
131
|
function getServerPort(config) {
|
|
125
132
|
return __async(this, null, function* () {
|
|
126
133
|
const prodPort = config.server.port || 8080;
|
|
@@ -39,7 +39,7 @@ const ZH_LOCALE = {
|
|
|
39
39
|
serve: { describe: "应用启动命令" },
|
|
40
40
|
deploy: { describe: "部署应用命令" },
|
|
41
41
|
new: {
|
|
42
|
-
describe: "
|
|
42
|
+
describe: "Web App 项目中执行生成器",
|
|
43
43
|
debug: "开启 Debug 模式,打印调试日志信息",
|
|
44
44
|
config: "生成器运行默认配置(JSON 字符串)",
|
|
45
45
|
distTag: "生成器使用特殊的 npm Tag 版本",
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
3
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
4
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
5
|
+
var __copyProps = (to, from, except, desc) => {
|
|
6
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
7
|
+
for (let key of __getOwnPropNames(from))
|
|
8
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
9
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
10
|
+
}
|
|
11
|
+
return to;
|
|
12
|
+
};
|
|
13
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
14
|
+
var utils_exports = {};
|
|
15
|
+
module.exports = __toCommonJS(utils_exports);
|
|
@@ -32,7 +32,9 @@ var NESTED_ROUTE = {
|
|
|
32
32
|
PAGE_LOADER_FILE: "page.loader",
|
|
33
33
|
LOADING_FILE: "loading",
|
|
34
34
|
ERROR_FILE: "error",
|
|
35
|
-
LOADER_FILE: "loader"
|
|
35
|
+
LOADER_FILE: "loader",
|
|
36
|
+
SPLATE_FILE: "$",
|
|
37
|
+
SPLATE_LOADER_FILE: "$.loader"
|
|
36
38
|
};
|
|
37
39
|
var APP_CONFIG_NAME = "config";
|
|
38
40
|
var APP_INIT_EXPORTED = "init";
|
|
@@ -161,7 +161,7 @@ var createImportSpecifier = function(specifiers) {
|
|
|
161
161
|
var _iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = undefined;
|
|
162
162
|
try {
|
|
163
163
|
for(var _iterator = specifiers[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true){
|
|
164
|
-
var
|
|
164
|
+
var _step_value = _step.value, local = _step_value.local, imported = _step_value.imported;
|
|
165
165
|
if (local && imported) {
|
|
166
166
|
named.push("".concat(imported, " as ").concat(local));
|
|
167
167
|
} else if (local) {
|
|
@@ -198,7 +198,7 @@ var createImportStatements = function(statements) {
|
|
|
198
198
|
var _iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = undefined;
|
|
199
199
|
try {
|
|
200
200
|
var _loop = function() {
|
|
201
|
-
var
|
|
201
|
+
var _step_value = _step.value, value = _step_value.value, specifiers = _step_value.specifiers, initialize = _step_value.initialize;
|
|
202
202
|
if (!seen.has(value)) {
|
|
203
203
|
deDuplicated.push({
|
|
204
204
|
value: value,
|
|
@@ -207,14 +207,14 @@ var createImportStatements = function(statements) {
|
|
|
207
207
|
});
|
|
208
208
|
seen.set(value, specifiers);
|
|
209
209
|
} else {
|
|
210
|
-
var
|
|
211
|
-
var
|
|
212
|
-
(
|
|
210
|
+
var _seen_get;
|
|
211
|
+
var _deDuplicated_modifyIndex;
|
|
212
|
+
(_seen_get = seen.get(value)).push.apply(_seen_get, _toConsumableArray(specifiers));
|
|
213
213
|
var modifyIndex = deDuplicated.findIndex(function(v) {
|
|
214
214
|
return v.value === value;
|
|
215
215
|
});
|
|
216
|
-
var
|
|
217
|
-
var originInitialize = (
|
|
216
|
+
var _deDuplicated_modifyIndex_initialize;
|
|
217
|
+
var originInitialize = (_deDuplicated_modifyIndex_initialize = (_deDuplicated_modifyIndex = deDuplicated[modifyIndex]) === null || _deDuplicated_modifyIndex === void 0 ? void 0 : _deDuplicated_modifyIndex.initialize) !== null && _deDuplicated_modifyIndex_initialize !== void 0 ? _deDuplicated_modifyIndex_initialize : "";
|
|
218
218
|
deDuplicated[modifyIndex].initialize = originInitialize.concat("\n".concat(initialize || ""));
|
|
219
219
|
}
|
|
220
220
|
};
|
|
@@ -240,13 +240,13 @@ var createImportStatements = function(statements) {
|
|
|
240
240
|
};
|
|
241
241
|
var generateCode = function() {
|
|
242
242
|
var _ref = _asyncToGenerator(function(appContext, config, entrypoints, api) {
|
|
243
|
-
var
|
|
243
|
+
var _config_runtime, _config_runtime1, _config_runtime_router, internalDirectory, srcDirectory, internalDirAlias, internalSrcAlias, packageName, hookRunners, isV5, mountId, getRoutes;
|
|
244
244
|
function generateEntryCode(entrypoint) {
|
|
245
245
|
return _generateEntryCode.apply(this, arguments);
|
|
246
246
|
}
|
|
247
247
|
function _generateEntryCode() {
|
|
248
248
|
_generateEntryCode = _asyncToGenerator(function(entrypoint) {
|
|
249
|
-
var entryName, isAutoMount, customBootstrap, fileSystemRoutes, initialRoutes, nestedRoute, routes, config2, ssr, mode, hasPageRoute,
|
|
249
|
+
var entryName, isAutoMount, customBootstrap, fileSystemRoutes, initialRoutes, nestedRoute, routes, config2, ssr, mode, hasPageRoute, _ref, code2, _, _tmp, routesServerFile, code3, _ref1, importStatements, plugins, _ref2, renderFunction, exportStatement, code, entryFile, _ref3, asyncEntryCode, bootstrapFile;
|
|
250
250
|
return __generator(this, function(_state) {
|
|
251
251
|
switch(_state.label){
|
|
252
252
|
case 0:
|
|
@@ -346,7 +346,7 @@ var generateCode = function() {
|
|
|
346
346
|
])
|
|
347
347
|
];
|
|
348
348
|
case 6:
|
|
349
|
-
|
|
349
|
+
_ref = _state.sent(), code2 = _ref.code;
|
|
350
350
|
if (!(entrypoint.nestedRoutesEntry && mode)) return [
|
|
351
351
|
3,
|
|
352
352
|
9
|
|
@@ -386,7 +386,7 @@ var generateCode = function() {
|
|
|
386
386
|
})
|
|
387
387
|
];
|
|
388
388
|
case 11:
|
|
389
|
-
|
|
389
|
+
_ref1 = _state.sent(), importStatements = _ref1.imports;
|
|
390
390
|
return [
|
|
391
391
|
4,
|
|
392
392
|
hookRunners.modifyEntryRuntimePlugins({
|
|
@@ -408,7 +408,7 @@ var generateCode = function() {
|
|
|
408
408
|
})
|
|
409
409
|
];
|
|
410
410
|
case 13:
|
|
411
|
-
|
|
411
|
+
_ref2 = _state.sent(), renderFunction = _ref2.code;
|
|
412
412
|
return [
|
|
413
413
|
4,
|
|
414
414
|
hookRunners.modifyEntryExport({
|
|
@@ -438,7 +438,7 @@ var generateCode = function() {
|
|
|
438
438
|
})
|
|
439
439
|
];
|
|
440
440
|
case 15:
|
|
441
|
-
|
|
441
|
+
_ref3 = _state.sent(), asyncEntryCode = _ref3.code;
|
|
442
442
|
fs.outputFileSync(entryFile, asyncEntryCode, "utf8");
|
|
443
443
|
bootstrapFile = path.resolve(internalDirectory, "./".concat(entryName, "/").concat(ENTRY_BOOTSTRAP_FILE_NAME));
|
|
444
444
|
fs.outputFileSync(bootstrapFile, code, "utf8");
|
|
@@ -463,7 +463,7 @@ var generateCode = function() {
|
|
|
463
463
|
case 0:
|
|
464
464
|
internalDirectory = appContext.internalDirectory, srcDirectory = appContext.srcDirectory, internalDirAlias = appContext.internalDirAlias, internalSrcAlias = appContext.internalSrcAlias, packageName = appContext.packageName;
|
|
465
465
|
hookRunners = api.useHookRunners();
|
|
466
|
-
isV5 = typeof ((
|
|
466
|
+
isV5 = typeof ((_config_runtime = config.runtime) === null || _config_runtime === void 0 ? void 0 : _config_runtime.router) !== "boolean" && (config === null || config === void 0 ? void 0 : (_config_runtime1 = config.runtime) === null || _config_runtime1 === void 0 ? void 0 : (_config_runtime_router = _config_runtime1.router) === null || _config_runtime_router === void 0 ? void 0 : _config_runtime_router.mode) === "react-router-5";
|
|
467
467
|
mountId = config.html.mountId;
|
|
468
468
|
getRoutes = isV5 ? getClientRoutesLegacy : getClientRoutes;
|
|
469
469
|
return [
|
|
@@ -24,7 +24,7 @@ var ifAlreadyExists = function(entrypoints, checked) {
|
|
|
24
24
|
};
|
|
25
25
|
var getBundleEntry = function(appContext, config) {
|
|
26
26
|
var appDirectory = appContext.appDirectory, packageName = appContext.packageName;
|
|
27
|
-
var
|
|
27
|
+
var _config_source = config.source, disableDefaultEntries = _config_source.disableDefaultEntries, entries = _config_source.entries, entriesDir = _config_source.entriesDir;
|
|
28
28
|
var defaults = disableDefaultEntries ? [] : getFileSystemEntry(appContext, config);
|
|
29
29
|
if (entries) {
|
|
30
30
|
Object.keys(entries).forEach(function(name) {
|
|
@@ -52,7 +52,7 @@ var getBundleEntry = function(appContext, config) {
|
|
|
52
52
|
if (!disableDefaultEntries) {
|
|
53
53
|
var entriesDirAbs = ensureAbsolutePath(appDirectory, entriesDir || "");
|
|
54
54
|
var found = defaults.find(function(param) {
|
|
55
|
-
var entryName = param.entryName, entry = param.entry,
|
|
55
|
+
var entryName = param.entryName, entry = param.entry, _param_nestedRoutesEntry = param.nestedRoutesEntry, nestedRoutesEntry = _param_nestedRoutesEntry === void 0 ? "" : _param_nestedRoutesEntry;
|
|
56
56
|
return entryName === packageName || path.dirname(entry) === entriesDirAbs || path.dirname(nestedRoutesEntry) === entriesDirAbs;
|
|
57
57
|
});
|
|
58
58
|
found && (found.entryName = MAIN_ENTRY_NAME);
|
|
@@ -67,7 +67,7 @@ var layoutNameAbbr = function(filePath) {
|
|
|
67
67
|
};
|
|
68
68
|
var parents = [];
|
|
69
69
|
var recursiveReadDir = function(param) {
|
|
70
|
-
var dir = param.dir, routes = param.routes,
|
|
70
|
+
var dir = param.dir, routes = param.routes, _param_basePath = param.basePath, basePath = _param_basePath === void 0 ? "/" : _param_basePath, srcDirectory = param.srcDirectory, srcAlias = param.srcAlias;
|
|
71
71
|
var hasDynamicRoute = false;
|
|
72
72
|
var resetParent = false;
|
|
73
73
|
var parent = parents[parents.length - 1];
|
|
@@ -67,7 +67,7 @@ var layoutNameAbbr = function(filePath) {
|
|
|
67
67
|
};
|
|
68
68
|
var parents = [];
|
|
69
69
|
var recursiveReadDirLegacy = function(param) {
|
|
70
|
-
var dir = param.dir, routes = param.routes,
|
|
70
|
+
var dir = param.dir, routes = param.routes, _param_basePath = param.basePath, basePath = _param_basePath === void 0 ? "/" : _param_basePath, srcDirectory = param.srcDirectory, srcAlias = param.srcAlias;
|
|
71
71
|
var hasDynamicRoute = false;
|
|
72
72
|
var resetParent = false;
|
|
73
73
|
var parent = parents[parents.length - 1];
|
|
@@ -80,7 +80,7 @@ var scanDir = function(dirs) {
|
|
|
80
80
|
};
|
|
81
81
|
var getFileSystemEntry = function(appContext, config) {
|
|
82
82
|
var appDirectory = appContext.appDirectory;
|
|
83
|
-
var
|
|
83
|
+
var _config_source = config.source, entriesDir = _config_source.entriesDir, disableEntryDirs = _config_source.disableEntryDirs;
|
|
84
84
|
var disabledDirs = [];
|
|
85
85
|
if (disableEntryDirs && Array.isArray(disableEntryDirs)) {
|
|
86
86
|
disabledDirs = disableEntryDirs === null || disableEntryDirs === void 0 ? void 0 : disableEntryDirs.map(function(dir) {
|
|
@@ -104,7 +104,7 @@ function _unsupportedIterableToArray(o, minLen) {
|
|
|
104
104
|
}
|
|
105
105
|
import path from "path";
|
|
106
106
|
import fs from "fs";
|
|
107
|
-
import { urlJoin, isPlainObject, removeLeadingSlash, getEntryOptions, SERVER_BUNDLE_DIRECTORY, MAIN_ENTRY_NAME, removeTailSlash } from "@modern-js/utils";
|
|
107
|
+
import { urlJoin, isPlainObject, removeLeadingSlash, getEntryOptions, SERVER_BUNDLE_DIRECTORY, MAIN_ENTRY_NAME, removeTailSlash, SERVER_WORKER_BUNDLE_DIRECTORY } from "@modern-js/utils";
|
|
108
108
|
import { walkDirectory } from "./utils";
|
|
109
109
|
var applyBaseUrl = function(baseUrl, routes) {
|
|
110
110
|
if (baseUrl) {
|
|
@@ -130,8 +130,8 @@ var applyRouteOptions = function(original, routeOptions) {
|
|
|
130
130
|
var routes;
|
|
131
131
|
if (route) {
|
|
132
132
|
if (Array.isArray(route)) {
|
|
133
|
-
var
|
|
134
|
-
|
|
133
|
+
var _route_map;
|
|
134
|
+
_route_map = route.map(function(url) {
|
|
135
135
|
if (isPlainObject(url)) {
|
|
136
136
|
var urlPath = url.path, other = _objectWithoutProperties(url, [
|
|
137
137
|
"path"
|
|
@@ -144,7 +144,7 @@ var applyRouteOptions = function(original, routeOptions) {
|
|
|
144
144
|
urlPath: url
|
|
145
145
|
});
|
|
146
146
|
}
|
|
147
|
-
}), routes =
|
|
147
|
+
}), routes = _route_map, _route_map;
|
|
148
148
|
} else if (isPlainObject(route)) {
|
|
149
149
|
var urlPath = route.path, other = _objectWithoutProperties(route, [
|
|
150
150
|
"path"
|
|
@@ -169,12 +169,13 @@ var applyRouteOptions = function(original, routeOptions) {
|
|
|
169
169
|
return routes;
|
|
170
170
|
};
|
|
171
171
|
var collectHtmlRoutes = function(entrypoints, appContext, config) {
|
|
172
|
-
var disableHtmlFolder = config.html.disableHtmlFolder,
|
|
172
|
+
var disableHtmlFolder = config.html.disableHtmlFolder, _config_output = config.output, tmp = _config_output.distPath, _ref = tmp === void 0 ? {} : tmp, htmlPath = _ref.html, _config_server = config.server, baseUrl = _config_server.baseUrl, routes = _config_server.routes, ssr = _config_server.ssr, ssrByEntries = _config_server.ssrByEntries, worker = _config_server.worker;
|
|
173
173
|
var packageName = appContext.packageName;
|
|
174
174
|
var htmlRoutes = entrypoints.reduce(function(previous, param) {
|
|
175
175
|
var entryName = param.entryName;
|
|
176
176
|
var entryOptions = getEntryOptions(entryName, ssr, ssrByEntries, packageName);
|
|
177
177
|
var isSSR = Boolean(entryOptions);
|
|
178
|
+
var isWorker = Boolean(worker);
|
|
178
179
|
var resHeaders = ((routes === null || routes === void 0 ? void 0 : routes[entryName]) || {}).resHeaders;
|
|
179
180
|
var route = {
|
|
180
181
|
urlPath: "/".concat(entryName === MAIN_ENTRY_NAME ? "" : entryName),
|
|
@@ -183,6 +184,7 @@ var collectHtmlRoutes = function(entrypoints, appContext, config) {
|
|
|
183
184
|
isSPA: true,
|
|
184
185
|
isSSR: isSSR,
|
|
185
186
|
responseHeaders: resHeaders,
|
|
187
|
+
worker: isWorker ? "".concat(SERVER_WORKER_BUNDLE_DIRECTORY, "/").concat(entryName, ".js") : void 0,
|
|
186
188
|
bundle: isSSR ? "".concat(SERVER_BUNDLE_DIRECTORY, "/").concat(entryName, ".js") : void 0
|
|
187
189
|
};
|
|
188
190
|
if (routes === null || routes === void 0 ? void 0 : routes.hasOwnProperty(entryName)) {
|
|
@@ -200,7 +202,7 @@ var collectHtmlRoutes = function(entrypoints, appContext, config) {
|
|
|
200
202
|
};
|
|
201
203
|
var collectStaticRoutes = function(appContext, config) {
|
|
202
204
|
var appDirectory = appContext.appDirectory;
|
|
203
|
-
var configDir = config.source.configDir,
|
|
205
|
+
var configDir = config.source.configDir, _config_server = config.server, _config_server_publicRoutes = _config_server.publicRoutes, publicRoutes = _config_server_publicRoutes === void 0 ? {} : _config_server_publicRoutes;
|
|
204
206
|
var publicFolder = path.resolve(appDirectory, configDir || "", "public");
|
|
205
207
|
return fs.existsSync(publicFolder) ? walkDirectory(publicFolder).map(function(filePath) {
|
|
206
208
|
var urlPath = "".concat(urlJoin(toPosix(filePath).slice(toPosix(publicFolder).length)));
|