@modern-js/plugin-ssg 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 +73 -0
- package/dist/js/modern/global.d.js +0 -0
- package/dist/js/modern/index.js +168 -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 +189 -166
- package/dist/js/node/libs/make.js +69 -32
- package/dist/js/node/libs/output.js +38 -13
- package/dist/js/node/libs/replace.js +71 -33
- package/dist/js/node/libs/util.js +119 -91
- package/dist/js/node/server/consts.js +26 -7
- package/dist/js/node/server/index.js +63 -39
- package/dist/js/node/server/prerender.js +58 -22
- package/dist/js/node/server/process.js +61 -34
- package/dist/js/node/types.js +15 -5
- package/dist/js/treeshaking/global.d.js +1 -0
- package/dist/js/treeshaking/index.js +334 -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 +9 -14
|
@@ -1,44 +1,80 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
Object.
|
|
4
|
-
|
|
1
|
+
var __create = Object.create;
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __defProps = Object.defineProperties;
|
|
4
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
+
var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
|
|
6
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
7
|
+
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
8
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
9
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
10
|
+
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
11
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
12
|
+
var __spreadValues = (a, b) => {
|
|
13
|
+
for (var prop in b || (b = {}))
|
|
14
|
+
if (__hasOwnProp.call(b, prop))
|
|
15
|
+
__defNormalProp(a, prop, b[prop]);
|
|
16
|
+
if (__getOwnPropSymbols)
|
|
17
|
+
for (var prop of __getOwnPropSymbols(b)) {
|
|
18
|
+
if (__propIsEnum.call(b, prop))
|
|
19
|
+
__defNormalProp(a, prop, b[prop]);
|
|
20
|
+
}
|
|
21
|
+
return a;
|
|
22
|
+
};
|
|
23
|
+
var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
|
|
24
|
+
var __export = (target, all) => {
|
|
25
|
+
for (var name in all)
|
|
26
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
27
|
+
};
|
|
28
|
+
var __copyProps = (to, from, except, desc) => {
|
|
29
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
30
|
+
for (let key of __getOwnPropNames(from))
|
|
31
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
32
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
33
|
+
}
|
|
34
|
+
return to;
|
|
35
|
+
};
|
|
36
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
37
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
38
|
+
mod
|
|
39
|
+
));
|
|
40
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
41
|
+
var prerender_exports = {};
|
|
42
|
+
__export(prerender_exports, {
|
|
43
|
+
compile: () => compile
|
|
5
44
|
});
|
|
6
|
-
exports
|
|
7
|
-
var
|
|
8
|
-
var
|
|
9
|
-
var
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
14
|
-
const compile = requestHandler => (options, extend = {}) => new Promise((resolve, reject) => {
|
|
15
|
-
const req = _nodeMocksHttp.default.createRequest(_objectSpread(_objectSpread({}, options), {}, {
|
|
16
|
-
eventEmitter: _stream.Readable
|
|
45
|
+
module.exports = __toCommonJS(prerender_exports);
|
|
46
|
+
var import_events = __toESM(require("events"));
|
|
47
|
+
var import_stream = require("stream");
|
|
48
|
+
var import_node_mocks_http = __toESM(require("node-mocks-http"));
|
|
49
|
+
const compile = (requestHandler) => (options, extend = {}) => new Promise((resolve, reject) => {
|
|
50
|
+
const req = import_node_mocks_http.default.createRequest(__spreadProps(__spreadValues({}, options), {
|
|
51
|
+
eventEmitter: import_stream.Readable
|
|
17
52
|
}));
|
|
18
|
-
const res =
|
|
19
|
-
eventEmitter: _events.default
|
|
20
|
-
});
|
|
53
|
+
const res = import_node_mocks_http.default.createResponse({ eventEmitter: import_events.default });
|
|
21
54
|
Object.assign(req, extend);
|
|
22
55
|
const proxyRes = new Proxy(res, {
|
|
23
56
|
get(obj, prop) {
|
|
24
|
-
if (typeof prop ===
|
|
57
|
+
if (typeof prop === "symbol" && !obj[prop]) {
|
|
25
58
|
return null;
|
|
26
59
|
}
|
|
27
60
|
return obj[prop];
|
|
28
61
|
}
|
|
29
62
|
});
|
|
30
|
-
res.on(
|
|
63
|
+
res.on("finish", () => {
|
|
31
64
|
if (res.statusCode !== 200) {
|
|
32
65
|
reject(new Error(res.statusMessage));
|
|
33
66
|
} else {
|
|
34
67
|
resolve(res._getData());
|
|
35
68
|
}
|
|
36
69
|
});
|
|
37
|
-
res.on(
|
|
70
|
+
res.on("error", (e) => reject(e));
|
|
38
71
|
try {
|
|
39
72
|
requestHandler(req, proxyRes);
|
|
40
73
|
} catch (e) {
|
|
41
74
|
reject(e);
|
|
42
75
|
}
|
|
43
76
|
});
|
|
44
|
-
|
|
77
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
78
|
+
0 && (module.exports = {
|
|
79
|
+
compile
|
|
80
|
+
});
|
|
@@ -1,14 +1,48 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
var
|
|
4
|
-
var
|
|
5
|
-
var
|
|
6
|
-
var
|
|
7
|
-
var
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
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 __copyProps = (to, from, except, desc) => {
|
|
8
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
9
|
+
for (let key of __getOwnPropNames(from))
|
|
10
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
11
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
12
|
+
}
|
|
13
|
+
return to;
|
|
14
|
+
};
|
|
15
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
16
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
17
|
+
mod
|
|
18
|
+
));
|
|
19
|
+
var __async = (__this, __arguments, generator) => {
|
|
20
|
+
return new Promise((resolve, reject) => {
|
|
21
|
+
var fulfilled = (value) => {
|
|
22
|
+
try {
|
|
23
|
+
step(generator.next(value));
|
|
24
|
+
} catch (e) {
|
|
25
|
+
reject(e);
|
|
26
|
+
}
|
|
27
|
+
};
|
|
28
|
+
var rejected = (value) => {
|
|
29
|
+
try {
|
|
30
|
+
step(generator.throw(value));
|
|
31
|
+
} catch (e) {
|
|
32
|
+
reject(e);
|
|
33
|
+
}
|
|
34
|
+
};
|
|
35
|
+
var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
|
|
36
|
+
step((generator = generator.apply(__this, __arguments)).next());
|
|
37
|
+
});
|
|
38
|
+
};
|
|
39
|
+
var import_prod_server = __toESM(require("@modern-js/prod-server"));
|
|
40
|
+
var import_portfinder = __toESM(require("portfinder"));
|
|
41
|
+
var import_make = require("../libs/make");
|
|
42
|
+
var import_prerender = require("./prerender");
|
|
43
|
+
var import_consts = require("./consts");
|
|
44
|
+
process.on("message", (chunk) => __async(exports, null, function* () {
|
|
45
|
+
if (chunk === import_consts.CLOSE_SIGN) {
|
|
12
46
|
process.exit();
|
|
13
47
|
}
|
|
14
48
|
const context = JSON.parse(chunk);
|
|
@@ -21,46 +55,39 @@ process.on('message', async chunk => {
|
|
|
21
55
|
} = context;
|
|
22
56
|
let modernServer = null;
|
|
23
57
|
try {
|
|
24
|
-
const {
|
|
25
|
-
server: serverOptions
|
|
26
|
-
} = options;
|
|
27
|
-
|
|
28
|
-
// start server in default port
|
|
58
|
+
const { server: serverOptions } = options;
|
|
29
59
|
const defaultPort = Number(process.env.PORT) || serverOptions.port;
|
|
30
|
-
|
|
31
|
-
const port =
|
|
32
|
-
modernServer =
|
|
60
|
+
import_portfinder.default.basePort = defaultPort;
|
|
61
|
+
const port = yield import_portfinder.default.getPortPromise();
|
|
62
|
+
modernServer = yield (0, import_prod_server.default)({
|
|
33
63
|
pwd: appDirectory,
|
|
34
64
|
config: options,
|
|
35
65
|
routes,
|
|
36
66
|
staticGenerate: true,
|
|
37
67
|
internalPlugins: plugins
|
|
38
68
|
});
|
|
39
|
-
|
|
40
|
-
// listen just for bff request in ssr page
|
|
41
|
-
modernServer.listen(port, async err => {
|
|
69
|
+
modernServer.listen(port, (err) => __async(exports, null, function* () {
|
|
42
70
|
if (err) {
|
|
43
71
|
throw err;
|
|
44
72
|
}
|
|
45
73
|
if (!modernServer) {
|
|
46
74
|
return;
|
|
47
75
|
}
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
const htmlAry =
|
|
55
|
-
htmlAry.forEach(html => {
|
|
76
|
+
const render = (0, import_prerender.compile)(modernServer.getRequestHandler());
|
|
77
|
+
const renderPromiseAry = (0, import_make.makeRender)(
|
|
78
|
+
renderRoutes,
|
|
79
|
+
render,
|
|
80
|
+
port
|
|
81
|
+
);
|
|
82
|
+
const htmlAry = yield Promise.all(renderPromiseAry);
|
|
83
|
+
htmlAry.forEach((html) => {
|
|
56
84
|
process.send(html);
|
|
57
85
|
process.send(null);
|
|
58
86
|
});
|
|
59
87
|
modernServer.close();
|
|
60
|
-
});
|
|
88
|
+
}));
|
|
61
89
|
} catch (e) {
|
|
62
|
-
|
|
63
|
-
(_modernServer = modernServer) === null || _modernServer === void 0 ? void 0 : _modernServer.close();
|
|
90
|
+
modernServer == null ? void 0 : modernServer.close();
|
|
64
91
|
throw e;
|
|
65
92
|
}
|
|
66
|
-
});
|
|
93
|
+
}));
|
package/dist/js/node/types.js
CHANGED
|
@@ -1,5 +1,15 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
Object.
|
|
4
|
-
|
|
5
|
-
|
|
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 types_exports = {};
|
|
15
|
+
module.exports = __toCommonJS(types_exports);
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";
|
|
@@ -0,0 +1,334 @@
|
|
|
1
|
+
function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
|
|
2
|
+
try {
|
|
3
|
+
var info = gen[key](arg);
|
|
4
|
+
var value = info.value;
|
|
5
|
+
} catch (error) {
|
|
6
|
+
reject(error);
|
|
7
|
+
return;
|
|
8
|
+
}
|
|
9
|
+
if (info.done) {
|
|
10
|
+
resolve(value);
|
|
11
|
+
} else {
|
|
12
|
+
Promise.resolve(value).then(_next, _throw);
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
function _asyncToGenerator(fn) {
|
|
16
|
+
return function() {
|
|
17
|
+
var self = this, args = arguments;
|
|
18
|
+
return new Promise(function(resolve, reject) {
|
|
19
|
+
var gen = fn.apply(self, args);
|
|
20
|
+
function _next(value) {
|
|
21
|
+
asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
|
|
22
|
+
}
|
|
23
|
+
function _throw(err) {
|
|
24
|
+
asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
|
|
25
|
+
}
|
|
26
|
+
_next(undefined);
|
|
27
|
+
});
|
|
28
|
+
};
|
|
29
|
+
}
|
|
30
|
+
function _defineProperty(obj, key, value) {
|
|
31
|
+
if (key in obj) {
|
|
32
|
+
Object.defineProperty(obj, key, {
|
|
33
|
+
value: value,
|
|
34
|
+
enumerable: true,
|
|
35
|
+
configurable: true,
|
|
36
|
+
writable: true
|
|
37
|
+
});
|
|
38
|
+
} else {
|
|
39
|
+
obj[key] = value;
|
|
40
|
+
}
|
|
41
|
+
return obj;
|
|
42
|
+
}
|
|
43
|
+
function _objectSpread(target) {
|
|
44
|
+
for(var i = 1; i < arguments.length; i++){
|
|
45
|
+
var source = arguments[i] != null ? arguments[i] : {};
|
|
46
|
+
var ownKeys = Object.keys(source);
|
|
47
|
+
if (typeof Object.getOwnPropertySymbols === "function") {
|
|
48
|
+
ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {
|
|
49
|
+
return Object.getOwnPropertyDescriptor(source, sym).enumerable;
|
|
50
|
+
}));
|
|
51
|
+
}
|
|
52
|
+
ownKeys.forEach(function(key) {
|
|
53
|
+
_defineProperty(target, key, source[key]);
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
return target;
|
|
57
|
+
}
|
|
58
|
+
function ownKeys(object, enumerableOnly) {
|
|
59
|
+
var keys = Object.keys(object);
|
|
60
|
+
if (Object.getOwnPropertySymbols) {
|
|
61
|
+
var symbols = Object.getOwnPropertySymbols(object);
|
|
62
|
+
if (enumerableOnly) {
|
|
63
|
+
symbols = symbols.filter(function(sym) {
|
|
64
|
+
return Object.getOwnPropertyDescriptor(object, sym).enumerable;
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
keys.push.apply(keys, symbols);
|
|
68
|
+
}
|
|
69
|
+
return keys;
|
|
70
|
+
}
|
|
71
|
+
function _objectSpreadProps(target, source) {
|
|
72
|
+
source = source != null ? source : {};
|
|
73
|
+
if (Object.getOwnPropertyDescriptors) {
|
|
74
|
+
Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
|
|
75
|
+
} else {
|
|
76
|
+
ownKeys(Object(source)).forEach(function(key) {
|
|
77
|
+
Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
return target;
|
|
81
|
+
}
|
|
82
|
+
var __generator = this && this.__generator || function(thisArg, body) {
|
|
83
|
+
var f, y, t, g, _ = {
|
|
84
|
+
label: 0,
|
|
85
|
+
sent: function() {
|
|
86
|
+
if (t[0] & 1) throw t[1];
|
|
87
|
+
return t[1];
|
|
88
|
+
},
|
|
89
|
+
trys: [],
|
|
90
|
+
ops: []
|
|
91
|
+
};
|
|
92
|
+
return g = {
|
|
93
|
+
next: verb(0),
|
|
94
|
+
"throw": verb(1),
|
|
95
|
+
"return": verb(2)
|
|
96
|
+
}, typeof Symbol === "function" && (g[Symbol.iterator] = function() {
|
|
97
|
+
return this;
|
|
98
|
+
}), g;
|
|
99
|
+
function verb(n) {
|
|
100
|
+
return function(v) {
|
|
101
|
+
return step([
|
|
102
|
+
n,
|
|
103
|
+
v
|
|
104
|
+
]);
|
|
105
|
+
};
|
|
106
|
+
}
|
|
107
|
+
function step(op) {
|
|
108
|
+
if (f) throw new TypeError("Generator is already executing.");
|
|
109
|
+
while(_)try {
|
|
110
|
+
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
|
111
|
+
if (y = 0, t) op = [
|
|
112
|
+
op[0] & 2,
|
|
113
|
+
t.value
|
|
114
|
+
];
|
|
115
|
+
switch(op[0]){
|
|
116
|
+
case 0:
|
|
117
|
+
case 1:
|
|
118
|
+
t = op;
|
|
119
|
+
break;
|
|
120
|
+
case 4:
|
|
121
|
+
_.label++;
|
|
122
|
+
return {
|
|
123
|
+
value: op[1],
|
|
124
|
+
done: false
|
|
125
|
+
};
|
|
126
|
+
case 5:
|
|
127
|
+
_.label++;
|
|
128
|
+
y = op[1];
|
|
129
|
+
op = [
|
|
130
|
+
0
|
|
131
|
+
];
|
|
132
|
+
continue;
|
|
133
|
+
case 7:
|
|
134
|
+
op = _.ops.pop();
|
|
135
|
+
_.trys.pop();
|
|
136
|
+
continue;
|
|
137
|
+
default:
|
|
138
|
+
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {
|
|
139
|
+
_ = 0;
|
|
140
|
+
continue;
|
|
141
|
+
}
|
|
142
|
+
if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {
|
|
143
|
+
_.label = op[1];
|
|
144
|
+
break;
|
|
145
|
+
}
|
|
146
|
+
if (op[0] === 6 && _.label < t[1]) {
|
|
147
|
+
_.label = t[1];
|
|
148
|
+
t = op;
|
|
149
|
+
break;
|
|
150
|
+
}
|
|
151
|
+
if (t && _.label < t[2]) {
|
|
152
|
+
_.label = t[2];
|
|
153
|
+
_.ops.push(op);
|
|
154
|
+
break;
|
|
155
|
+
}
|
|
156
|
+
if (t[2]) _.ops.pop();
|
|
157
|
+
_.trys.pop();
|
|
158
|
+
continue;
|
|
159
|
+
}
|
|
160
|
+
op = body.call(thisArg, _);
|
|
161
|
+
} catch (e) {
|
|
162
|
+
op = [
|
|
163
|
+
6,
|
|
164
|
+
e
|
|
165
|
+
];
|
|
166
|
+
y = 0;
|
|
167
|
+
} finally{
|
|
168
|
+
f = t = 0;
|
|
169
|
+
}
|
|
170
|
+
if (op[0] & 5) throw op[1];
|
|
171
|
+
return {
|
|
172
|
+
value: op[0] ? op[1] : void 0,
|
|
173
|
+
done: true
|
|
174
|
+
};
|
|
175
|
+
}
|
|
176
|
+
};
|
|
177
|
+
import path from "path";
|
|
178
|
+
import { logger, PLUGIN_SCHEMAS } from "@modern-js/utils";
|
|
179
|
+
import { generatePath } from "react-router-dom";
|
|
180
|
+
import { flattenRoutes, formatOutput, isDynamicUrl, readJSONSpec, standardOptions, writeJSONSpec } from "./libs/util";
|
|
181
|
+
import { createServer } from "./server";
|
|
182
|
+
import { writeHtmlFile } from "./libs/output";
|
|
183
|
+
import { replaceRoute } from "./libs/replace";
|
|
184
|
+
import { makeRoute } from "./libs/make";
|
|
185
|
+
var src_default = function() {
|
|
186
|
+
return {
|
|
187
|
+
name: "@modern-js/plugin-ssg",
|
|
188
|
+
pre: [
|
|
189
|
+
"@modern-js/plugin-server",
|
|
190
|
+
"@modern-js/plugin-bff"
|
|
191
|
+
],
|
|
192
|
+
setup: function(api) {
|
|
193
|
+
var agreedRouteMap = {};
|
|
194
|
+
return {
|
|
195
|
+
validateSchema: function validateSchema() {
|
|
196
|
+
return PLUGIN_SCHEMAS["@modern-js/plugin-ssg"];
|
|
197
|
+
},
|
|
198
|
+
modifyFileSystemRoutes: function modifyFileSystemRoutes(param) {
|
|
199
|
+
var entrypoint = param.entrypoint, routes = param.routes;
|
|
200
|
+
var entryName = entrypoint.entryName;
|
|
201
|
+
var flattedRoutes = flattenRoutes(routes);
|
|
202
|
+
agreedRouteMap[entryName] = flattedRoutes;
|
|
203
|
+
return {
|
|
204
|
+
entrypoint: entrypoint,
|
|
205
|
+
routes: routes
|
|
206
|
+
};
|
|
207
|
+
},
|
|
208
|
+
afterBuild: function afterBuild() {
|
|
209
|
+
return _asyncToGenerator(function() {
|
|
210
|
+
var resolvedConfig, appContext, appDirectory, entrypoints, output, server, ssg, tmp, ref, outputPath, ssgOptions, buildDir, routes, pageRoutes, apiRoutes, intermediateOptions, ssgRoutes, htmlAry;
|
|
211
|
+
return __generator(this, function(_state) {
|
|
212
|
+
switch(_state.label){
|
|
213
|
+
case 0:
|
|
214
|
+
resolvedConfig = api.useResolvedConfigContext();
|
|
215
|
+
appContext = api.useAppContext();
|
|
216
|
+
appDirectory = appContext.appDirectory, entrypoints = appContext.entrypoints;
|
|
217
|
+
output = resolvedConfig.output, server = resolvedConfig.server;
|
|
218
|
+
ssg = output.ssg, tmp = output.distPath, ref = tmp === void 0 ? {} : tmp, outputPath = ref.root;
|
|
219
|
+
ssgOptions = (Array.isArray(ssg) ? ssg.pop() : ssg) || true;
|
|
220
|
+
buildDir = path.join(appDirectory, outputPath);
|
|
221
|
+
routes = readJSONSpec(buildDir);
|
|
222
|
+
pageRoutes = routes.filter(function(route) {
|
|
223
|
+
return !route.isApi;
|
|
224
|
+
});
|
|
225
|
+
apiRoutes = routes.filter(function(route) {
|
|
226
|
+
return route.isApi;
|
|
227
|
+
});
|
|
228
|
+
if (pageRoutes.length === 0) {
|
|
229
|
+
return [
|
|
230
|
+
2
|
|
231
|
+
];
|
|
232
|
+
}
|
|
233
|
+
intermediateOptions = standardOptions(ssgOptions, entrypoints, pageRoutes, server);
|
|
234
|
+
if (!intermediateOptions) {
|
|
235
|
+
return [
|
|
236
|
+
2
|
|
237
|
+
];
|
|
238
|
+
}
|
|
239
|
+
ssgRoutes = [];
|
|
240
|
+
pageRoutes.forEach(function(pageRoute) {
|
|
241
|
+
var entryName = pageRoute.entryName, entryPath = pageRoute.entryPath;
|
|
242
|
+
var agreedRoutes = agreedRouteMap[entryName];
|
|
243
|
+
var entryOptions = intermediateOptions[entryName] || intermediateOptions[pageRoute.urlPath];
|
|
244
|
+
if (!agreedRoutes) {
|
|
245
|
+
if (!entryOptions) {
|
|
246
|
+
return;
|
|
247
|
+
}
|
|
248
|
+
if (entryOptions === true) {
|
|
249
|
+
ssgRoutes.push(_objectSpreadProps(_objectSpread({}, pageRoute), {
|
|
250
|
+
output: entryPath
|
|
251
|
+
}));
|
|
252
|
+
} else if (entryOptions.routes && entryOptions.routes.length > 0) {
|
|
253
|
+
var enrtyRoutes = entryOptions.routes, headers = entryOptions.headers;
|
|
254
|
+
enrtyRoutes.forEach(function(route) {
|
|
255
|
+
ssgRoutes.push(makeRoute(pageRoute, route, headers));
|
|
256
|
+
});
|
|
257
|
+
}
|
|
258
|
+
} else {
|
|
259
|
+
if (!entryOptions) {
|
|
260
|
+
return;
|
|
261
|
+
}
|
|
262
|
+
if (entryOptions === true) {
|
|
263
|
+
entryOptions = {
|
|
264
|
+
preventDefault: [],
|
|
265
|
+
routes: [],
|
|
266
|
+
headers: {}
|
|
267
|
+
};
|
|
268
|
+
}
|
|
269
|
+
var _preventDefault = entryOptions.preventDefault, preventDefault = _preventDefault === void 0 ? [] : _preventDefault, tmp = entryOptions.routes, userRoutes = tmp === void 0 ? [] : tmp, headers1 = entryOptions.headers;
|
|
270
|
+
if (userRoutes.length > 0) {
|
|
271
|
+
userRoutes.forEach(function(route) {
|
|
272
|
+
if (typeof route === "string") {
|
|
273
|
+
ssgRoutes.push(makeRoute(pageRoute, route, headers1));
|
|
274
|
+
} else if (Array.isArray(route.params)) {
|
|
275
|
+
route.params.forEach(function(param) {
|
|
276
|
+
ssgRoutes.push(makeRoute(pageRoute, _objectSpreadProps(_objectSpread({}, route), {
|
|
277
|
+
url: generatePath(route.url, param)
|
|
278
|
+
}), headers1));
|
|
279
|
+
});
|
|
280
|
+
} else {
|
|
281
|
+
ssgRoutes.push(makeRoute(pageRoute, route, headers1));
|
|
282
|
+
}
|
|
283
|
+
});
|
|
284
|
+
} else {
|
|
285
|
+
agreedRoutes.filter(function(route) {
|
|
286
|
+
return !preventDefault.includes(route.path);
|
|
287
|
+
}).forEach(function(route) {
|
|
288
|
+
if (!isDynamicUrl(route.path)) {
|
|
289
|
+
ssgRoutes.push(makeRoute(pageRoute, route.path, headers1));
|
|
290
|
+
}
|
|
291
|
+
});
|
|
292
|
+
}
|
|
293
|
+
}
|
|
294
|
+
});
|
|
295
|
+
if (ssgRoutes.length === 0) {
|
|
296
|
+
return [
|
|
297
|
+
2
|
|
298
|
+
];
|
|
299
|
+
}
|
|
300
|
+
ssgRoutes.forEach(function(ssgRoute) {
|
|
301
|
+
if (ssgRoute.isSSR) {
|
|
302
|
+
var isOriginRoute = pageRoutes.some(function(pageRoute) {
|
|
303
|
+
return pageRoute.urlPath === ssgRoute.urlPath && pageRoute.entryName === ssgRoute.entryName;
|
|
304
|
+
});
|
|
305
|
+
if (isOriginRoute) {
|
|
306
|
+
throw new Error("ssg can not using with ssr,url - ".concat(ssgRoute.urlPath, ", entry - ").concat(ssgRoute.entryName, " "));
|
|
307
|
+
}
|
|
308
|
+
logger.warn("new ssg route ".concat(ssgRoute.urlPath, " is using ssr now,maybe from parent route ").concat(ssgRoute.entryName, ",close ssr"));
|
|
309
|
+
}
|
|
310
|
+
ssgRoute.isSSR = false;
|
|
311
|
+
ssgRoute.output = formatOutput(ssgRoute.output);
|
|
312
|
+
});
|
|
313
|
+
return [
|
|
314
|
+
4,
|
|
315
|
+
createServer(api, ssgRoutes, pageRoutes, apiRoutes, resolvedConfig, appDirectory)
|
|
316
|
+
];
|
|
317
|
+
case 1:
|
|
318
|
+
htmlAry = _state.sent();
|
|
319
|
+
writeHtmlFile(htmlAry, ssgRoutes, buildDir);
|
|
320
|
+
replaceRoute(ssgRoutes, pageRoutes);
|
|
321
|
+
writeJSONSpec(buildDir, pageRoutes.concat(apiRoutes));
|
|
322
|
+
logger.info("ssg Compiled successfully");
|
|
323
|
+
return [
|
|
324
|
+
2
|
|
325
|
+
];
|
|
326
|
+
}
|
|
327
|
+
});
|
|
328
|
+
})();
|
|
329
|
+
}
|
|
330
|
+
};
|
|
331
|
+
}
|
|
332
|
+
};
|
|
333
|
+
};
|
|
334
|
+
export { src_default as default };
|
|
@@ -0,0 +1,83 @@
|
|
|
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 normalize from "normalize-path";
|
|
55
|
+
function makeRender(ssgRoutes, render, port) {
|
|
56
|
+
return ssgRoutes.map(function(ssgRoute) {
|
|
57
|
+
return render({
|
|
58
|
+
url: ssgRoute.urlPath,
|
|
59
|
+
headers: _objectSpread({
|
|
60
|
+
host: "localhost:".concat(port)
|
|
61
|
+
}, ssgRoute.headers),
|
|
62
|
+
connection: {}
|
|
63
|
+
});
|
|
64
|
+
});
|
|
65
|
+
}
|
|
66
|
+
function makeRoute(baseRoute, route) {
|
|
67
|
+
var headers = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : {};
|
|
68
|
+
var urlPath = baseRoute.urlPath, entryPath = baseRoute.entryPath;
|
|
69
|
+
if (typeof route === "string") {
|
|
70
|
+
return _objectSpreadProps(_objectSpread({}, baseRoute), {
|
|
71
|
+
urlPath: normalize("".concat(urlPath).concat(route)) || "/",
|
|
72
|
+
headers: headers,
|
|
73
|
+
output: path.join(entryPath, "..".concat(route === "/" ? "" : route))
|
|
74
|
+
});
|
|
75
|
+
} else {
|
|
76
|
+
return _objectSpreadProps(_objectSpread({}, baseRoute), {
|
|
77
|
+
urlPath: normalize("".concat(urlPath).concat(route.url)) || "/",
|
|
78
|
+
headers: _objectSpread({}, headers, route.headers),
|
|
79
|
+
output: route.output ? path.normalize(route.output) : path.join(entryPath, "..".concat(route.url === "/" ? "" : route.url))
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
export { makeRender, makeRoute };
|