@modern-js/plugin-ssg 2.0.0-beta.3 → 2.0.0-beta.4
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 +36 -0
- package/dist/js/modern/global.d.js +0 -0
- package/dist/js/modern/index.js +171 -155
- package/dist/js/modern/libs/make.js +44 -27
- package/dist/js/modern/libs/output.js +7 -4
- package/dist/js/modern/libs/replace.js +45 -27
- package/dist/js/modern/libs/util.js +91 -76
- package/dist/js/modern/server/consts.js +4 -1
- package/dist/js/modern/server/index.js +31 -28
- package/dist/js/modern/server/prerender.js +32 -15
- package/dist/js/modern/server/process.js +78 -57
- package/dist/js/modern/types.js +0 -1
- package/dist/js/node/global.d.js +0 -0
- package/dist/js/node/index.js +192 -166
- package/dist/js/node/libs/make.js +66 -32
- package/dist/js/node/libs/output.js +34 -13
- package/dist/js/node/libs/replace.js +68 -33
- package/dist/js/node/libs/util.js +107 -91
- package/dist/js/node/server/consts.js +22 -7
- package/dist/js/node/server/index.js +59 -39
- package/dist/js/node/server/prerender.js +56 -22
- package/dist/js/node/server/process.js +108 -62
- package/dist/js/node/types.js +0 -5
- package/dist/js/treeshaking/global.d.js +1 -0
- package/dist/js/treeshaking/index.js +339 -0
- package/dist/js/treeshaking/libs/make.js +83 -0
- package/dist/js/treeshaking/libs/output.js +13 -0
- package/dist/js/treeshaking/libs/replace.js +115 -0
- package/dist/js/treeshaking/libs/util.js +239 -0
- package/dist/js/treeshaking/server/consts.js +2 -0
- package/dist/js/treeshaking/server/index.js +63 -0
- package/dist/js/treeshaking/server/prerender.js +97 -0
- package/dist/js/treeshaking/server/process.js +226 -0
- package/dist/js/treeshaking/types.js +1 -0
- package/dist/types/index.d.ts +2 -0
- package/dist/types/libs/util.d.ts +0 -1
- package/package.json +7 -12
package/dist/js/node/index.js
CHANGED
|
@@ -1,184 +1,210 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
Object.
|
|
4
|
-
|
|
1
|
+
var __create = Object.create;
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
6
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
7
|
+
var __export = (target, all) => {
|
|
8
|
+
for (var name in all)
|
|
9
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
10
|
+
};
|
|
11
|
+
var __copyProps = (to, from, except, desc) => {
|
|
12
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
13
|
+
for (let key of __getOwnPropNames(from))
|
|
14
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
15
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
16
|
+
}
|
|
17
|
+
return to;
|
|
18
|
+
};
|
|
19
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
20
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
21
|
+
mod
|
|
22
|
+
));
|
|
23
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
24
|
+
var stdin_exports = {};
|
|
25
|
+
__export(stdin_exports, {
|
|
26
|
+
default: () => src_default
|
|
5
27
|
});
|
|
6
|
-
exports
|
|
7
|
-
var
|
|
8
|
-
var
|
|
9
|
-
var
|
|
10
|
-
var
|
|
11
|
-
var
|
|
12
|
-
var
|
|
13
|
-
var
|
|
14
|
-
var
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
var
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
28
|
+
module.exports = __toCommonJS(stdin_exports);
|
|
29
|
+
var import_path = __toESM(require("path"));
|
|
30
|
+
var import_utils = require("@modern-js/utils");
|
|
31
|
+
var import_react_router_dom = require("react-router-dom");
|
|
32
|
+
var import_util = require("./libs/util");
|
|
33
|
+
var import_server = require("./server");
|
|
34
|
+
var import_output = require("./libs/output");
|
|
35
|
+
var import_replace = require("./libs/replace");
|
|
36
|
+
var import_make = require("./libs/make");
|
|
37
|
+
var __defProp2 = Object.defineProperty;
|
|
38
|
+
var __defProps = Object.defineProperties;
|
|
39
|
+
var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
|
|
40
|
+
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
41
|
+
var __hasOwnProp2 = Object.prototype.hasOwnProperty;
|
|
42
|
+
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
43
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp2(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
44
|
+
var __spreadValues = (a, b) => {
|
|
45
|
+
for (var prop in b || (b = {}))
|
|
46
|
+
if (__hasOwnProp2.call(b, prop))
|
|
47
|
+
__defNormalProp(a, prop, b[prop]);
|
|
48
|
+
if (__getOwnPropSymbols)
|
|
49
|
+
for (var prop of __getOwnPropSymbols(b)) {
|
|
50
|
+
if (__propIsEnum.call(b, prop))
|
|
51
|
+
__defNormalProp(a, prop, b[prop]);
|
|
52
|
+
}
|
|
53
|
+
return a;
|
|
54
|
+
};
|
|
55
|
+
var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
|
|
56
|
+
var __async = (__this, __arguments, generator) => {
|
|
57
|
+
return new Promise((resolve, reject) => {
|
|
58
|
+
var fulfilled = (value) => {
|
|
59
|
+
try {
|
|
60
|
+
step(generator.next(value));
|
|
61
|
+
} catch (e) {
|
|
62
|
+
reject(e);
|
|
63
|
+
}
|
|
64
|
+
};
|
|
65
|
+
var rejected = (value) => {
|
|
66
|
+
try {
|
|
67
|
+
step(generator.throw(value));
|
|
68
|
+
} catch (e) {
|
|
69
|
+
reject(e);
|
|
70
|
+
}
|
|
71
|
+
};
|
|
72
|
+
var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
|
|
73
|
+
step((generator = generator.apply(__this, __arguments)).next());
|
|
74
|
+
});
|
|
75
|
+
};
|
|
76
|
+
var src_default = () => ({
|
|
77
|
+
name: "@modern-js/plugin-ssg",
|
|
78
|
+
pre: ["@modern-js/plugin-server", "@modern-js/plugin-bff"],
|
|
79
|
+
setup: (api) => {
|
|
23
80
|
const agreedRouteMap = {};
|
|
24
81
|
return {
|
|
25
82
|
validateSchema() {
|
|
26
|
-
return
|
|
83
|
+
return import_utils.PLUGIN_SCHEMAS["@modern-js/plugin-ssg"];
|
|
27
84
|
},
|
|
28
|
-
modifyFileSystemRoutes({
|
|
29
|
-
entrypoint
|
|
30
|
-
routes
|
|
31
|
-
}) {
|
|
32
|
-
const {
|
|
33
|
-
entryName
|
|
34
|
-
} = entrypoint;
|
|
35
|
-
const flattedRoutes = (0, _util.flattenRoutes)(routes);
|
|
85
|
+
modifyFileSystemRoutes({ entrypoint, routes }) {
|
|
86
|
+
const { entryName } = entrypoint;
|
|
87
|
+
const flattedRoutes = (0, import_util.flattenRoutes)(routes);
|
|
36
88
|
agreedRouteMap[entryName] = flattedRoutes;
|
|
37
|
-
return {
|
|
38
|
-
entrypoint,
|
|
39
|
-
routes
|
|
40
|
-
};
|
|
89
|
+
return { entrypoint, routes };
|
|
41
90
|
},
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
appDirectory,
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
// only add entry route if entryOptions is true
|
|
95
|
-
if (entryOptions === true) {
|
|
96
|
-
ssgRoutes.push(_objectSpread(_objectSpread({}, pageRoute), {}, {
|
|
97
|
-
output: entryPath
|
|
98
|
-
}));
|
|
99
|
-
} else if (entryOptions.routes && entryOptions.routes.length > 0) {
|
|
100
|
-
// if entryOptions is object and has routes options
|
|
101
|
-
// add every route in options
|
|
91
|
+
afterBuild() {
|
|
92
|
+
return __async(this, null, function* () {
|
|
93
|
+
const resolvedConfig = api.useResolvedConfigContext();
|
|
94
|
+
const appContext = api.useAppContext();
|
|
95
|
+
const { appDirectory, entrypoints } = appContext;
|
|
96
|
+
const { output, server } = resolvedConfig;
|
|
97
|
+
const { ssg, distPath: { root: outputPath } = {} } = output;
|
|
98
|
+
const ssgOptions = Array.isArray(ssg) ? ssg.pop() : ssg;
|
|
99
|
+
if (!ssgOptions) {
|
|
100
|
+
return;
|
|
101
|
+
}
|
|
102
|
+
const buildDir = import_path.default.join(appDirectory, outputPath);
|
|
103
|
+
const routes = (0, import_util.readJSONSpec)(buildDir);
|
|
104
|
+
const pageRoutes = routes.filter((route) => !route.isApi);
|
|
105
|
+
const apiRoutes = routes.filter((route) => route.isApi);
|
|
106
|
+
if (pageRoutes.length === 0) {
|
|
107
|
+
return;
|
|
108
|
+
}
|
|
109
|
+
const intermediateOptions = (0, import_util.standardOptions)(
|
|
110
|
+
ssgOptions,
|
|
111
|
+
entrypoints,
|
|
112
|
+
pageRoutes,
|
|
113
|
+
server
|
|
114
|
+
);
|
|
115
|
+
if (!intermediateOptions) {
|
|
116
|
+
return;
|
|
117
|
+
}
|
|
118
|
+
const ssgRoutes = [];
|
|
119
|
+
pageRoutes.forEach((pageRoute) => {
|
|
120
|
+
const { entryName, entryPath } = pageRoute;
|
|
121
|
+
const agreedRoutes = agreedRouteMap[entryName];
|
|
122
|
+
let entryOptions = intermediateOptions[entryName] || intermediateOptions[pageRoute.urlPath];
|
|
123
|
+
if (!agreedRoutes) {
|
|
124
|
+
if (!entryOptions) {
|
|
125
|
+
return;
|
|
126
|
+
}
|
|
127
|
+
if (entryOptions === true) {
|
|
128
|
+
ssgRoutes.push(__spreadProps(__spreadValues({}, pageRoute), { output: entryPath }));
|
|
129
|
+
} else if (entryOptions.routes && entryOptions.routes.length > 0) {
|
|
130
|
+
const { routes: enrtyRoutes, headers } = entryOptions;
|
|
131
|
+
enrtyRoutes.forEach((route) => {
|
|
132
|
+
ssgRoutes.push((0, import_make.makeRoute)(pageRoute, route, headers));
|
|
133
|
+
});
|
|
134
|
+
}
|
|
135
|
+
} else {
|
|
136
|
+
if (!entryOptions) {
|
|
137
|
+
return;
|
|
138
|
+
}
|
|
139
|
+
if (entryOptions === true) {
|
|
140
|
+
entryOptions = { preventDefault: [], routes: [], headers: {} };
|
|
141
|
+
}
|
|
102
142
|
const {
|
|
103
|
-
|
|
143
|
+
preventDefault = [],
|
|
144
|
+
routes: userRoutes = [],
|
|
104
145
|
headers
|
|
105
146
|
} = entryOptions;
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
if (typeof route === 'string') {
|
|
132
|
-
ssgRoutes.push((0, _make.makeRoute)(pageRoute, route, headers));
|
|
133
|
-
} else if (Array.isArray(route.params)) {
|
|
134
|
-
route.params.forEach(param => {
|
|
135
|
-
ssgRoutes.push((0, _make.makeRoute)(pageRoute, _objectSpread(_objectSpread({}, route), {}, {
|
|
136
|
-
url: (0, _reactRouterDom.generatePath)(route.url, param)
|
|
137
|
-
}), headers));
|
|
138
|
-
});
|
|
139
|
-
} else {
|
|
140
|
-
ssgRoutes.push((0, _make.makeRoute)(pageRoute, route, headers));
|
|
141
|
-
}
|
|
142
|
-
});
|
|
143
|
-
} else {
|
|
144
|
-
// otherwith add all except dynamic routes
|
|
145
|
-
agreedRoutes.filter(route => !preventDefault.includes(route.path)).forEach(route => {
|
|
146
|
-
if (!(0, _util.isDynamicUrl)(route.path)) {
|
|
147
|
-
ssgRoutes.push((0, _make.makeRoute)(pageRoute, route.path, headers));
|
|
148
|
-
}
|
|
149
|
-
});
|
|
147
|
+
if (userRoutes.length > 0) {
|
|
148
|
+
userRoutes.forEach((route) => {
|
|
149
|
+
if (typeof route === "string") {
|
|
150
|
+
ssgRoutes.push((0, import_make.makeRoute)(pageRoute, route, headers));
|
|
151
|
+
} else if (Array.isArray(route.params)) {
|
|
152
|
+
route.params.forEach((param) => {
|
|
153
|
+
ssgRoutes.push(
|
|
154
|
+
(0, import_make.makeRoute)(
|
|
155
|
+
pageRoute,
|
|
156
|
+
__spreadProps(__spreadValues({}, route), { url: (0, import_react_router_dom.generatePath)(route.url, param) }),
|
|
157
|
+
headers
|
|
158
|
+
)
|
|
159
|
+
);
|
|
160
|
+
});
|
|
161
|
+
} else {
|
|
162
|
+
ssgRoutes.push((0, import_make.makeRoute)(pageRoute, route, headers));
|
|
163
|
+
}
|
|
164
|
+
});
|
|
165
|
+
} else {
|
|
166
|
+
agreedRoutes.filter((route) => !preventDefault.includes(route.path)).forEach((route) => {
|
|
167
|
+
if (!(0, import_util.isDynamicUrl)(route.path)) {
|
|
168
|
+
ssgRoutes.push((0, import_make.makeRoute)(pageRoute, route.path, headers));
|
|
169
|
+
}
|
|
170
|
+
});
|
|
171
|
+
}
|
|
150
172
|
}
|
|
173
|
+
});
|
|
174
|
+
if (ssgRoutes.length === 0) {
|
|
175
|
+
return;
|
|
151
176
|
}
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
177
|
+
ssgRoutes.forEach((ssgRoute) => {
|
|
178
|
+
if (ssgRoute.isSSR) {
|
|
179
|
+
const isOriginRoute = pageRoutes.some(
|
|
180
|
+
(pageRoute) => pageRoute.urlPath === ssgRoute.urlPath && pageRoute.entryName === ssgRoute.entryName
|
|
181
|
+
);
|
|
182
|
+
if (isOriginRoute) {
|
|
183
|
+
throw new Error(
|
|
184
|
+
`ssg can not using with ssr,url - ${ssgRoute.urlPath}, entry - ${ssgRoute.entryName} `
|
|
185
|
+
);
|
|
186
|
+
}
|
|
187
|
+
import_utils.logger.warn(
|
|
188
|
+
`new ssg route ${ssgRoute.urlPath} is using ssr now,maybe from parent route ${ssgRoute.entryName},close ssr`
|
|
189
|
+
);
|
|
163
190
|
}
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
191
|
+
ssgRoute.isSSR = false;
|
|
192
|
+
ssgRoute.output = (0, import_util.formatOutput)(ssgRoute.output);
|
|
193
|
+
});
|
|
194
|
+
const htmlAry = yield (0, import_server.createServer)(
|
|
195
|
+
api,
|
|
196
|
+
ssgRoutes,
|
|
197
|
+
pageRoutes,
|
|
198
|
+
apiRoutes,
|
|
199
|
+
resolvedConfig,
|
|
200
|
+
appDirectory
|
|
201
|
+
);
|
|
202
|
+
(0, import_output.writeHtmlFile)(htmlAry, ssgRoutes, buildDir);
|
|
203
|
+
(0, import_replace.replaceRoute)(ssgRoutes, pageRoutes);
|
|
204
|
+
(0, import_util.writeJSONSpec)(buildDir, pageRoutes.concat(apiRoutes));
|
|
205
|
+
import_utils.logger.info("ssg Compiled successfully");
|
|
168
206
|
});
|
|
169
|
-
const htmlAry = await (0, _server.createServer)(api, ssgRoutes, pageRoutes, apiRoutes, resolvedConfig, appDirectory);
|
|
170
|
-
|
|
171
|
-
// write to dist file
|
|
172
|
-
(0, _output.writeHtmlFile)(htmlAry, ssgRoutes, buildDir);
|
|
173
|
-
|
|
174
|
-
// format route info, side effect
|
|
175
|
-
(0, _replace.replaceRoute)(ssgRoutes, pageRoutes);
|
|
176
|
-
|
|
177
|
-
// write routes to spec file
|
|
178
|
-
(0, _util.writeJSONSpec)(buildDir, pageRoutes.concat(apiRoutes));
|
|
179
|
-
_utils.logger.info('ssg Compiled successfully');
|
|
180
207
|
}
|
|
181
208
|
};
|
|
182
209
|
}
|
|
183
210
|
});
|
|
184
|
-
exports.default = _default;
|
|
@@ -1,41 +1,75 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
Object.
|
|
4
|
-
|
|
1
|
+
var __create = Object.create;
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
6
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
7
|
+
var __export = (target, all) => {
|
|
8
|
+
for (var name in all)
|
|
9
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
10
|
+
};
|
|
11
|
+
var __copyProps = (to, from, except, desc) => {
|
|
12
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
13
|
+
for (let key of __getOwnPropNames(from))
|
|
14
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
15
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
16
|
+
}
|
|
17
|
+
return to;
|
|
18
|
+
};
|
|
19
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
20
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
21
|
+
mod
|
|
22
|
+
));
|
|
23
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
24
|
+
var stdin_exports = {};
|
|
25
|
+
__export(stdin_exports, {
|
|
26
|
+
makeRender: () => makeRender,
|
|
27
|
+
makeRoute: () => makeRoute
|
|
5
28
|
});
|
|
6
|
-
exports
|
|
7
|
-
|
|
8
|
-
var
|
|
9
|
-
var
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
29
|
+
module.exports = __toCommonJS(stdin_exports);
|
|
30
|
+
var import_path = __toESM(require("path"));
|
|
31
|
+
var import_normalize_path = __toESM(require("normalize-path"));
|
|
32
|
+
var __defProp2 = Object.defineProperty;
|
|
33
|
+
var __defProps = Object.defineProperties;
|
|
34
|
+
var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
|
|
35
|
+
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
36
|
+
var __hasOwnProp2 = Object.prototype.hasOwnProperty;
|
|
37
|
+
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
38
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp2(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
39
|
+
var __spreadValues = (a, b) => {
|
|
40
|
+
for (var prop in b || (b = {}))
|
|
41
|
+
if (__hasOwnProp2.call(b, prop))
|
|
42
|
+
__defNormalProp(a, prop, b[prop]);
|
|
43
|
+
if (__getOwnPropSymbols)
|
|
44
|
+
for (var prop of __getOwnPropSymbols(b)) {
|
|
45
|
+
if (__propIsEnum.call(b, prop))
|
|
46
|
+
__defNormalProp(a, prop, b[prop]);
|
|
47
|
+
}
|
|
48
|
+
return a;
|
|
49
|
+
};
|
|
50
|
+
var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
|
|
14
51
|
function makeRender(ssgRoutes, render, port) {
|
|
15
|
-
return ssgRoutes.map(
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
host: `localhost:${port}`
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
52
|
+
return ssgRoutes.map(
|
|
53
|
+
(ssgRoute) => render({
|
|
54
|
+
url: ssgRoute.urlPath,
|
|
55
|
+
headers: __spreadValues({ host: `localhost:${port}` }, ssgRoute.headers),
|
|
56
|
+
connection: {}
|
|
57
|
+
})
|
|
58
|
+
);
|
|
22
59
|
}
|
|
23
60
|
function makeRoute(baseRoute, route, headers = {}) {
|
|
24
|
-
const {
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
if (typeof route === 'string') {
|
|
29
|
-
return _objectSpread(_objectSpread({}, baseRoute), {}, {
|
|
30
|
-
urlPath: (0, _normalizePath.default)(`${urlPath}${route}`) || '/',
|
|
61
|
+
const { urlPath, entryPath } = baseRoute;
|
|
62
|
+
if (typeof route === "string") {
|
|
63
|
+
return __spreadProps(__spreadValues({}, baseRoute), {
|
|
64
|
+
urlPath: (0, import_normalize_path.default)(`${urlPath}${route}`) || "/",
|
|
31
65
|
headers,
|
|
32
|
-
output:
|
|
66
|
+
output: import_path.default.join(entryPath, `..${route === "/" ? "" : route}`)
|
|
33
67
|
});
|
|
34
68
|
} else {
|
|
35
|
-
return
|
|
36
|
-
urlPath: (0,
|
|
37
|
-
headers:
|
|
38
|
-
output: route.output ?
|
|
69
|
+
return __spreadProps(__spreadValues({}, baseRoute), {
|
|
70
|
+
urlPath: (0, import_normalize_path.default)(`${urlPath}${route.url}`) || "/",
|
|
71
|
+
headers: __spreadValues(__spreadValues({}, headers), route.headers),
|
|
72
|
+
output: route.output ? import_path.default.normalize(route.output) : import_path.default.join(entryPath, `..${route.url === "/" ? "" : route.url}`)
|
|
39
73
|
});
|
|
40
74
|
}
|
|
41
|
-
}
|
|
75
|
+
}
|
|
@@ -1,19 +1,40 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
Object.
|
|
4
|
-
|
|
1
|
+
var __create = Object.create;
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
6
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
7
|
+
var __export = (target, all) => {
|
|
8
|
+
for (var name in all)
|
|
9
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
10
|
+
};
|
|
11
|
+
var __copyProps = (to, from, except, desc) => {
|
|
12
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
13
|
+
for (let key of __getOwnPropNames(from))
|
|
14
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
15
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
16
|
+
}
|
|
17
|
+
return to;
|
|
18
|
+
};
|
|
19
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
20
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
21
|
+
mod
|
|
22
|
+
));
|
|
23
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
24
|
+
var stdin_exports = {};
|
|
25
|
+
__export(stdin_exports, {
|
|
26
|
+
writeHtmlFile: () => writeHtmlFile
|
|
5
27
|
});
|
|
6
|
-
exports
|
|
7
|
-
var
|
|
8
|
-
var
|
|
9
|
-
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
28
|
+
module.exports = __toCommonJS(stdin_exports);
|
|
29
|
+
var import_path = __toESM(require("path"));
|
|
30
|
+
var import_utils = require("@modern-js/utils");
|
|
10
31
|
function writeHtmlFile(htmlAry, ssgRoutes, baseDir) {
|
|
11
32
|
htmlAry.forEach((html, index) => {
|
|
12
33
|
const ssgRoute = ssgRoutes[index];
|
|
13
|
-
const filepath =
|
|
14
|
-
if (!
|
|
15
|
-
|
|
34
|
+
const filepath = import_path.default.join(baseDir, ssgRoute.output);
|
|
35
|
+
if (!import_utils.fs.existsSync(import_path.default.dirname(filepath))) {
|
|
36
|
+
import_utils.fs.ensureDirSync(import_path.default.dirname(filepath));
|
|
16
37
|
}
|
|
17
|
-
|
|
38
|
+
import_utils.fs.writeFileSync(filepath, html);
|
|
18
39
|
});
|
|
19
|
-
}
|
|
40
|
+
}
|