@modern-js/runtime 1.3.4-alpha.0 → 1.4.0

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.
Files changed (156) hide show
  1. package/CHANGELOG.md +77 -19
  2. package/dist/js/modern/cli/index.js +4 -4
  3. package/dist/js/modern/common.js +1 -0
  4. package/dist/js/modern/exports/model.js +2 -1
  5. package/dist/js/modern/exports/router.js +2 -1
  6. package/dist/js/modern/exports/server.js +0 -1
  7. package/dist/js/modern/exports/ssr.js +2 -1
  8. package/dist/js/modern/router/cli/index.js +106 -0
  9. package/dist/js/modern/router/index.js +2 -0
  10. package/dist/js/modern/router/runtime/DefaultNotFound.js +13 -0
  11. package/dist/js/modern/router/runtime/index.js +4 -0
  12. package/dist/js/modern/router/runtime/plugin.js +88 -0
  13. package/dist/js/modern/router/runtime/utils.js +108 -0
  14. package/dist/js/modern/ssr/cli/index.js +120 -0
  15. package/dist/js/modern/ssr/index.js +109 -0
  16. package/dist/js/modern/ssr/index.node.js +78 -0
  17. package/dist/js/modern/ssr/prefetch.js +58 -0
  18. package/dist/js/modern/ssr/react/index.js +2 -0
  19. package/dist/js/modern/ssr/react/nossr/index.js +13 -0
  20. package/dist/js/modern/ssr/react/prerender/index.js +104 -0
  21. package/dist/js/modern/ssr/react/prerender/type.js +0 -0
  22. package/dist/js/modern/ssr/react/prerender/util.js +99 -0
  23. package/dist/js/modern/ssr/serverRender/entry.js +179 -0
  24. package/dist/js/modern/ssr/serverRender/helmet.js +46 -0
  25. package/dist/js/modern/ssr/serverRender/index.js +29 -0
  26. package/dist/js/modern/ssr/serverRender/loadable.js +48 -0
  27. package/dist/js/modern/ssr/serverRender/measure.js +11 -0
  28. package/dist/js/modern/ssr/serverRender/reduce.js +7 -0
  29. package/dist/js/modern/ssr/serverRender/styledComponent.js +8 -0
  30. package/dist/js/modern/ssr/serverRender/template.js +90 -0
  31. package/dist/js/modern/ssr/serverRender/type.js +8 -0
  32. package/dist/js/modern/ssr/utils.js +51 -0
  33. package/dist/js/modern/state/cli/index.js +110 -0
  34. package/dist/js/modern/state/index.js +2 -0
  35. package/dist/js/modern/state/plugins.js +7 -0
  36. package/dist/js/modern/state/runtime/index.js +4 -0
  37. package/dist/js/modern/state/runtime/plugin.js +71 -0
  38. package/dist/js/modern/state/types.js +1 -0
  39. package/dist/js/node/cli/index.js +5 -5
  40. package/dist/js/node/common.js +10 -0
  41. package/dist/js/node/exports/model.js +19 -5
  42. package/dist/js/node/exports/router.js +19 -5
  43. package/dist/js/node/exports/server.js +0 -17
  44. package/dist/js/node/exports/ssr.js +19 -5
  45. package/dist/js/node/router/cli/index.js +122 -0
  46. package/dist/js/node/router/index.js +30 -0
  47. package/dist/js/node/router/runtime/DefaultNotFound.js +26 -0
  48. package/dist/js/node/router/runtime/index.js +39 -0
  49. package/dist/js/node/router/runtime/plugin.js +111 -0
  50. package/dist/js/node/router/runtime/utils.js +128 -0
  51. package/dist/js/node/ssr/cli/index.js +136 -0
  52. package/dist/js/node/ssr/index.js +138 -0
  53. package/dist/js/node/ssr/index.node.js +105 -0
  54. package/dist/js/node/ssr/prefetch.js +75 -0
  55. package/dist/js/node/ssr/react/index.js +21 -0
  56. package/dist/js/node/ssr/react/nossr/index.js +28 -0
  57. package/dist/js/node/ssr/react/prerender/index.js +121 -0
  58. package/dist/js/node/ssr/react/prerender/type.js +0 -0
  59. package/dist/js/node/ssr/react/prerender/util.js +119 -0
  60. package/dist/js/node/ssr/serverRender/entry.js +208 -0
  61. package/dist/js/node/ssr/serverRender/helmet.js +52 -0
  62. package/dist/js/node/ssr/serverRender/index.js +46 -0
  63. package/dist/js/node/ssr/serverRender/loadable.js +60 -0
  64. package/dist/js/node/ssr/serverRender/measure.js +20 -0
  65. package/dist/js/node/ssr/serverRender/reduce.js +14 -0
  66. package/dist/js/node/ssr/serverRender/styledComponent.js +18 -0
  67. package/dist/js/node/ssr/serverRender/template.js +103 -0
  68. package/dist/js/node/ssr/serverRender/type.js +15 -0
  69. package/dist/js/node/ssr/utils.js +65 -0
  70. package/dist/js/node/state/cli/index.js +127 -0
  71. package/dist/js/node/state/index.js +30 -0
  72. package/dist/js/node/state/plugins.js +35 -0
  73. package/dist/js/node/state/runtime/index.js +61 -0
  74. package/dist/js/node/state/runtime/plugin.js +101 -0
  75. package/dist/js/node/state/types.js +5 -0
  76. package/dist/js/treeshaking/cli/index.js +4 -4
  77. package/dist/js/treeshaking/common.js +3 -0
  78. package/dist/js/treeshaking/exports/model.js +2 -1
  79. package/dist/js/treeshaking/exports/router.js +2 -1
  80. package/dist/js/treeshaking/exports/server.js +0 -1
  81. package/dist/js/treeshaking/exports/ssr.js +2 -1
  82. package/dist/js/treeshaking/router/cli/index.js +100 -0
  83. package/dist/js/treeshaking/router/index.js +2 -0
  84. package/dist/js/treeshaking/router/runtime/DefaultNotFound.js +15 -0
  85. package/dist/js/treeshaking/router/runtime/index.js +4 -0
  86. package/dist/js/treeshaking/router/runtime/plugin.js +89 -0
  87. package/dist/js/treeshaking/router/runtime/utils.js +106 -0
  88. package/dist/js/treeshaking/ssr/cli/index.js +113 -0
  89. package/dist/js/treeshaking/ssr/index.js +129 -0
  90. package/dist/js/treeshaking/ssr/index.node.js +100 -0
  91. package/dist/js/treeshaking/ssr/prefetch.js +97 -0
  92. package/dist/js/treeshaking/ssr/react/index.js +2 -0
  93. package/dist/js/treeshaking/ssr/react/nossr/index.js +16 -0
  94. package/dist/js/treeshaking/ssr/react/prerender/index.js +119 -0
  95. package/dist/js/treeshaking/ssr/react/prerender/type.js +0 -0
  96. package/dist/js/treeshaking/ssr/react/prerender/util.js +115 -0
  97. package/dist/js/treeshaking/ssr/serverRender/entry.js +267 -0
  98. package/dist/js/treeshaking/ssr/serverRender/helmet.js +37 -0
  99. package/dist/js/treeshaking/ssr/serverRender/index.js +69 -0
  100. package/dist/js/treeshaking/ssr/serverRender/loadable.js +59 -0
  101. package/dist/js/treeshaking/ssr/serverRender/measure.js +17 -0
  102. package/dist/js/treeshaking/ssr/serverRender/reduce.js +11 -0
  103. package/dist/js/treeshaking/ssr/serverRender/styledComponent.js +8 -0
  104. package/dist/js/treeshaking/ssr/serverRender/template.js +111 -0
  105. package/dist/js/treeshaking/ssr/serverRender/type.js +8 -0
  106. package/dist/js/treeshaking/ssr/utils.js +53 -0
  107. package/dist/js/treeshaking/state/cli/index.js +100 -0
  108. package/dist/js/treeshaking/state/index.js +2 -0
  109. package/dist/js/treeshaking/state/plugins.js +13 -0
  110. package/dist/js/treeshaking/state/runtime/index.js +4 -0
  111. package/dist/js/treeshaking/state/runtime/plugin.js +63 -0
  112. package/dist/js/treeshaking/state/types.js +1 -0
  113. package/dist/types/common.d.ts +1 -0
  114. package/dist/types/exports/model.d.ts +2 -1
  115. package/dist/types/exports/router.d.ts +2 -1
  116. package/dist/types/exports/server.d.ts +0 -1
  117. package/dist/types/exports/ssr.d.ts +2 -1
  118. package/dist/types/index.d.ts +8 -2
  119. package/dist/types/router/cli/index.d.ts +5 -0
  120. package/dist/types/router/index.d.ts +2 -0
  121. package/dist/types/router/runtime/DefaultNotFound.d.ts +2 -0
  122. package/dist/types/router/runtime/index.d.ts +6 -0
  123. package/dist/types/router/runtime/plugin.d.ts +51 -0
  124. package/dist/types/router/runtime/utils.d.ts +6 -0
  125. package/dist/types/ssr/cli/index.d.ts +5 -0
  126. package/dist/types/ssr/index.d.ts +18 -0
  127. package/dist/types/ssr/index.node.d.ts +4 -0
  128. package/dist/types/ssr/prefetch.d.ts +13 -0
  129. package/dist/types/ssr/react/index.d.ts +2 -0
  130. package/dist/types/ssr/react/nossr/index.d.ts +2 -0
  131. package/dist/types/ssr/react/prerender/index.d.ts +1 -0
  132. package/dist/types/ssr/react/prerender/type.d.ts +29 -0
  133. package/dist/types/ssr/react/prerender/util.d.ts +6 -0
  134. package/dist/types/ssr/serverRender/entry.d.ts +20 -0
  135. package/dist/types/ssr/serverRender/helmet.d.ts +2 -0
  136. package/dist/types/ssr/serverRender/index.d.ts +8 -0
  137. package/dist/types/ssr/serverRender/loadable.d.ts +2 -0
  138. package/dist/types/ssr/serverRender/measure.d.ts +1 -0
  139. package/dist/types/ssr/serverRender/reduce.d.ts +3 -0
  140. package/dist/types/ssr/serverRender/styledComponent.d.ts +2 -0
  141. package/dist/types/ssr/serverRender/template.d.ts +14 -0
  142. package/dist/types/ssr/serverRender/type.d.ts +32 -0
  143. package/dist/types/ssr/utils.d.ts +8 -0
  144. package/dist/types/state/cli/index.d.ts +5 -0
  145. package/dist/types/state/index.d.ts +2 -0
  146. package/dist/types/state/plugins.d.ts +4 -0
  147. package/dist/types/state/runtime/index.d.ts +4 -0
  148. package/dist/types/state/runtime/plugin.d.ts +17 -0
  149. package/dist/types/state/types.d.ts +17 -0
  150. package/package.json +37 -20
  151. package/types/model.d.ts +1 -1
  152. package/types/state.d.ts +4 -0
  153. package/dist/js/modern/exports/request.js +0 -1
  154. package/dist/js/node/exports/request.js +0 -13
  155. package/dist/js/treeshaking/exports/request.js +0 -1
  156. package/dist/types/exports/request.d.ts +0 -1
@@ -0,0 +1,208 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+
8
+ var _path = _interopRequireDefault(require("path"));
9
+
10
+ var _constants = require("@modern-js/utils/constants");
11
+
12
+ var _react = _interopRequireDefault(require("react"));
13
+
14
+ var _server = _interopRequireDefault(require("react-dom/server"));
15
+
16
+ var _serializeJavascript = _interopRequireDefault(require("serialize-javascript"));
17
+
18
+ var _reactHelmet = _interopRequireDefault(require("react-helmet"));
19
+
20
+ var _template = require("./template");
21
+
22
+ var _type = require("./type");
23
+
24
+ var _helmet = _interopRequireDefault(require("./helmet"));
25
+
26
+ var _reduce = require("./reduce");
27
+
28
+ var loadableRenderer = _interopRequireWildcard(require("./loadable"));
29
+
30
+ var styledComponentRenderer = _interopRequireWildcard(require("./styledComponent"));
31
+
32
+ var _measure = require("./measure");
33
+
34
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
35
+
36
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
37
+
38
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
39
+
40
+ 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; }
41
+
42
+ const buildTemplateData = (context, data, renderLevel) => {
43
+ const {
44
+ request
45
+ } = context;
46
+ return {
47
+ data,
48
+ context: {
49
+ request: {
50
+ params: request.params,
51
+ query: request.query,
52
+ pathname: request.pathname,
53
+ host: request.host,
54
+ url: request.url,
55
+ headers: request.headers,
56
+ cookieMap: request.cookieMap
57
+ }
58
+ },
59
+ renderLevel
60
+ };
61
+ };
62
+
63
+ class Entry {
64
+ constructor(options) {
65
+ _defineProperty(this, "entryName", void 0);
66
+
67
+ _defineProperty(this, "result", void 0);
68
+
69
+ _defineProperty(this, "metrics", void 0);
70
+
71
+ _defineProperty(this, "logger", void 0);
72
+
73
+ _defineProperty(this, "App", void 0);
74
+
75
+ _defineProperty(this, "fragments", void 0);
76
+
77
+ const {
78
+ ctx
79
+ } = options;
80
+ const {
81
+ entryName,
82
+ template: templateHTML
83
+ } = ctx;
84
+ this.fragments = (0, _template.toFragments)(templateHTML);
85
+ this.entryName = entryName;
86
+ this.App = options.App;
87
+ this.metrics = ctx.metrics;
88
+ this.logger = ctx.logger;
89
+ this.result = {
90
+ renderLevel: _type.RenderLevel.CLIENT_RENDER,
91
+ html: '',
92
+ chunksMap: {
93
+ js: '',
94
+ css: ''
95
+ }
96
+ };
97
+ }
98
+
99
+ async renderToHtml(context) {
100
+ const {
101
+ ssrContext
102
+ } = context;
103
+
104
+ if (ssrContext.redirection.url) {
105
+ return '';
106
+ }
107
+
108
+ const prefetchData = await this.prefetch(context);
109
+
110
+ if (ssrContext.redirection.url) {
111
+ return '';
112
+ }
113
+
114
+ if (this.result.renderLevel >= _type.RenderLevel.SERVER_PREFETCH) {
115
+ this.result.html = this.renderToString(context);
116
+ }
117
+
118
+ if (ssrContext.redirection.url) {
119
+ return '';
120
+ }
121
+
122
+ let html = '';
123
+ const templateData = buildTemplateData(ssrContext, prefetchData, this.result.renderLevel);
124
+ const SSRData = this.getSSRDataScript(templateData);
125
+
126
+ for (const fragment of this.fragments) {
127
+ if (fragment.isVariable && fragment.content === 'SSRDataScript') {
128
+ html += fragment.getValue(SSRData);
129
+ } else {
130
+ html += fragment.getValue(this.result);
131
+ }
132
+ }
133
+
134
+ const helmetData = _reactHelmet.default.renderStatic();
135
+
136
+ return helmetData ? (0, _helmet.default)(html, helmetData) : html;
137
+ }
138
+
139
+ async prefetch(context) {
140
+ const {
141
+ App: {
142
+ prefetch
143
+ }
144
+ } = this;
145
+ let prefetchData;
146
+ const end = (0, _measure.time)();
147
+
148
+ try {
149
+ prefetchData = prefetch ? await prefetch(context) : null;
150
+ this.result.renderLevel = _type.RenderLevel.SERVER_PREFETCH;
151
+ const prefetchCost = end();
152
+ this.logger.debug(`App Prefetch cost = %d ms`, prefetchCost);
153
+ this.metrics.emitTimer('app.prefetch.cost', prefetchCost);
154
+ } catch (e) {
155
+ this.result.renderLevel = _type.RenderLevel.CLIENT_RENDER;
156
+ this.logger.error('App Prefetch Render', e);
157
+ this.metrics.emitCounter('app.prefetch.render.error', 1);
158
+ }
159
+
160
+ return prefetchData || {};
161
+ }
162
+
163
+ renderToString(context) {
164
+ let html = '';
165
+ const end = (0, _measure.time)();
166
+ const {
167
+ ssrContext
168
+ } = context;
169
+
170
+ try {
171
+ const App = /*#__PURE__*/_react.default.createElement(this.App, {
172
+ context: Object.assign(context, {
173
+ ssr: true
174
+ })
175
+ }); // Todo render Hook
176
+
177
+
178
+ const renderContext = {
179
+ loadableManifest: _path.default.resolve(ssrContext.distDir, _constants.LOADABLE_STATS_FILE),
180
+ result: this.result,
181
+ entryName: this.entryName
182
+ };
183
+ html = (0, _reduce.reduce)(App, renderContext, [styledComponentRenderer.toHtml, loadableRenderer.toHtml, jsx => _server.default.renderToString(jsx)]);
184
+ const cost = end();
185
+ this.logger.debug('App Render To HTML cost = %d ms', cost);
186
+ this.metrics.emitTimer('app.render.html.cost', cost);
187
+ this.result.renderLevel = _type.RenderLevel.SERVER_RENDER;
188
+ } catch (e) {
189
+ this.logger.error('App Render To HTML', e);
190
+ this.metrics.emitCounter('app.render.html.error', 1);
191
+ }
192
+
193
+ return html;
194
+ }
195
+
196
+ getSSRDataScript(templateData) {
197
+ return {
198
+ SSRDataScript: `
199
+ <script>window._SSR_DATA = ${(0, _serializeJavascript.default)(templateData, {
200
+ isJSON: true
201
+ })}</script>
202
+ `
203
+ };
204
+ }
205
+
206
+ }
207
+
208
+ exports.default = Entry;
@@ -0,0 +1,52 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = helmet;
7
+ // 用于 react-helmet 正则替换
8
+ const RE_HTML_ATTR = /<html[^>]*>/;
9
+ const RE_BODY_ATTR = /<body[^>]*>/;
10
+ const RE_LAST_IN_HEAD = /<\/head>/;
11
+ const RE_TITLE = /<title[^>]*>([\s\S\n\r]*?)<\/title>/g;
12
+ const TEST_TITLE_CONTENT = /(?<=<title[^>]*>)([\s\S\n\r]*?)([.|\S])([\s\S\n\r]*?)(?=<\/title>)/g; // 通过 react-helmet 修改模板
13
+
14
+ function helmet(content, helmetData) {
15
+ let result = content;
16
+ const bodyAttributes = helmetData.bodyAttributes.toString();
17
+
18
+ if (bodyAttributes) {
19
+ result = result.replace(RE_BODY_ATTR, `<body ${bodyAttributes}>`);
20
+ }
21
+
22
+ const htmlAttributes = helmetData.htmlAttributes.toString();
23
+
24
+ if (htmlAttributes) {
25
+ result = result.replace(RE_HTML_ATTR, `<html ${htmlAttributes}>`);
26
+ }
27
+
28
+ const base = helmetData.base.toString();
29
+ const link = helmetData.link.toString();
30
+ const meta = helmetData.meta.toString();
31
+ const noscript = helmetData.noscript.toString();
32
+ const script = helmetData.script.toString();
33
+ const style = helmetData.style.toString();
34
+ const title = helmetData.title.toString(); // 如果模板中存在 title,且 helmetData title 有内容则做替换
35
+
36
+ const existTitle = RE_TITLE.test(content);
37
+
38
+ if (TEST_TITLE_CONTENT.test(title.trim()) && existTitle) {
39
+ result = result.replace(RE_TITLE, title);
40
+ }
41
+
42
+ return result.replace(RE_LAST_IN_HEAD, `
43
+ ${base}
44
+ ${link}
45
+ ${meta}
46
+ ${noscript}
47
+ ${script}
48
+ ${style}
49
+ ${existTitle ? '' : title}
50
+ </head>
51
+ `);
52
+ }
@@ -0,0 +1,46 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.render = void 0;
7
+
8
+ var _runtimeCore = require("@modern-js/runtime-core");
9
+
10
+ var _ssr = require("@modern-js/utils/ssr");
11
+
12
+ var _prerender = require("../react/prerender");
13
+
14
+ var _entry = _interopRequireDefault(require("./entry"));
15
+
16
+ var _measure = require("./measure");
17
+
18
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
19
+
20
+ const render = async (ctx, _ = process.cwd(), App) => {
21
+ const {
22
+ ssrContext
23
+ } = ctx;
24
+ return (0, _ssr.run)(ssrContext.request.headers, async () => {
25
+ const entry = new _entry.default({
26
+ ctx: ssrContext,
27
+ App
28
+ });
29
+ entry.metrics.emitCounter('app.visit.count', 1);
30
+ const end = (0, _measure.time)();
31
+ const html = await entry.renderToHtml(ctx);
32
+ const cost = end();
33
+ entry.logger.info('App Render Total cost = %d ms', cost);
34
+ entry.metrics.emitTimer('app.render.cost', cost);
35
+
36
+ const cacheConfig = _prerender.PreRender.config();
37
+
38
+ if (cacheConfig) {
39
+ ctx.ssrContext.cacheConfig = cacheConfig;
40
+ }
41
+
42
+ return html;
43
+ });
44
+ };
45
+
46
+ exports.render = render;
@@ -0,0 +1,60 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.toHtml = void 0;
7
+
8
+ var _path = _interopRequireDefault(require("path"));
9
+
10
+ var _server = require("@loadable/server");
11
+
12
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
13
+
14
+ function getLoadableScripts(extractor) {
15
+ const check = scripts => (scripts || '').includes('__LOADABLE_REQUIRED_CHUNKS___ext');
16
+
17
+ const scripts = extractor.getScriptTags();
18
+
19
+ if (!check(scripts)) {
20
+ return '';
21
+ }
22
+
23
+ return scripts.split('</script>') // 前两个 script为 loadable 必须的 script
24
+ .slice(0, 2).map(i => `${i}</script>`).join('');
25
+ }
26
+
27
+ const toHtml = (jsx, renderer, next) => {
28
+ const {
29
+ loadableManifest,
30
+ result: {
31
+ chunksMap
32
+ }
33
+ } = renderer;
34
+
35
+ if (!loadableManifest || chunksMap.js) {
36
+ return next(jsx);
37
+ }
38
+
39
+ const extractor = new _server.ChunkExtractor({
40
+ statsFile: loadableManifest,
41
+ entrypoints: [renderer.entryName]
42
+ });
43
+ const html = next(extractor.collectChunks(jsx));
44
+ const chunks = extractor.getChunkAssets(extractor.chunks);
45
+ chunksMap.js = (chunksMap.js || '') + getLoadableScripts(extractor);
46
+
47
+ for (const v of chunks) {
48
+ const fileType = _path.default.extname(v.url).slice(1);
49
+
50
+ if (fileType === 'js') {
51
+ chunksMap[fileType] += `<script src="${v.url}"></script>`;
52
+ } else if (fileType === 'css') {
53
+ chunksMap[fileType] += `<link href="${v.url}" rel="stylesheet" />`;
54
+ }
55
+ }
56
+
57
+ return html;
58
+ };
59
+
60
+ exports.toHtml = toHtml;
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.time = void 0;
7
+
8
+ const getLatency = hrtime => {
9
+ const [s, ns] = process.hrtime(hrtime);
10
+ return s * 1e3 + ns / 1e6;
11
+ };
12
+
13
+ const time = () => {
14
+ const hrtime = process.hrtime();
15
+ return () => {
16
+ return getLatency(hrtime);
17
+ };
18
+ };
19
+
20
+ exports.time = time;
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.reduce = reduce;
7
+
8
+ function reduce(jsx, renderer, middleware) {
9
+ let index = 0;
10
+
11
+ const createNext = () => App => middleware[index++](App, renderer, createNext());
12
+
13
+ return createNext()(jsx);
14
+ }
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.toHtml = void 0;
7
+
8
+ var _styled = require("@modern-js/runtime-core/styled");
9
+
10
+ const toHtml = (jsx, renderer, next) => {
11
+ const sheet = new _styled.ServerStyleSheet();
12
+ const html = next(sheet.collectStyles(jsx));
13
+ const css = sheet.getStyleTags();
14
+ renderer.result.chunksMap.css += css;
15
+ return html;
16
+ };
17
+
18
+ exports.toHtml = toHtml;
@@ -0,0 +1,103 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.Fragment = void 0;
7
+ exports.toFragments = toFragments;
8
+
9
+ var _fs = _interopRequireDefault(require("fs"));
10
+
11
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
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
+
15
+ const readFile = filepath => {
16
+ if (_fs.default.existsSync(filepath)) {
17
+ return _fs.default.readFileSync(filepath, 'utf-8');
18
+ } else {
19
+ return null;
20
+ }
21
+ };
22
+
23
+ const VARIABLE_REG_EXP = /<!--<\?([-=+])\s*(.*?)\s*\?>-->/;
24
+ const VARIABLE_SPLITTER = /(<!--<\?.*?\?>-->)/;
25
+ const ENCODE_HTML_RULES = {
26
+ '&': '&amp;',
27
+ '<': '&lt;',
28
+ '>': '&gt;',
29
+ '"': '&#34;',
30
+ "'": '&#39;'
31
+ };
32
+ const MATCH_HTML = /[&<>'"]/g;
33
+
34
+ function encodeChar(c) {
35
+ return ENCODE_HTML_RULES[c] || c;
36
+ }
37
+
38
+ function escape(str) {
39
+ return str.replace(MATCH_HTML, encodeChar);
40
+ }
41
+
42
+ class Fragment {
43
+ constructor(template) {
44
+ _defineProperty(this, "isVariable", void 0);
45
+
46
+ _defineProperty(this, "content", void 0);
47
+
48
+ _defineProperty(this, "filters", void 0);
49
+
50
+ _defineProperty(this, "path", void 0);
51
+
52
+ const match = VARIABLE_REG_EXP.exec(template);
53
+
54
+ if (match) {
55
+ const [, filterFlag, content] = match;
56
+ this.isVariable = true;
57
+ this.content = content;
58
+ this.filters = [Fragment.filterMap[filterFlag]];
59
+ this.path = content.replace(/\[['"](.*?)['"]\]/g, '.$1').split('.');
60
+ } else {
61
+ this.isVariable = false;
62
+ this.content = template;
63
+ this.filters = [];
64
+ this.path = [];
65
+ }
66
+ }
67
+
68
+ getValue(data) {
69
+ if (this.isVariable) {
70
+ const value = this.path.reduce((p, n) => p != null ? p[n] : p, data);
71
+ return this.filters.reduce((p, n) => n(p), value != null ? value : '');
72
+ }
73
+
74
+ return this.content;
75
+ }
76
+
77
+ }
78
+
79
+ exports.Fragment = Fragment;
80
+
81
+ _defineProperty(Fragment, "filterMap", {
82
+ '=': escape,
83
+ '-': v => v
84
+ });
85
+
86
+ const fragmentListMap = {};
87
+
88
+ function toFragments(filename) {
89
+ if (fragmentListMap[filename]) {
90
+ return fragmentListMap[filename];
91
+ } // 未开启现代构建的项目无 -es6.html
92
+
93
+
94
+ const template = readFile(filename);
95
+
96
+ if (!template) {
97
+ throw new Error(`Could not find template file: ${filename}`);
98
+ }
99
+
100
+ const fragmentList = template.split(VARIABLE_SPLITTER).filter(v => Boolean(v)).map(v => new Fragment(v));
101
+ fragmentListMap[filename] = fragmentList;
102
+ return fragmentList;
103
+ }
@@ -0,0 +1,15 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.RenderLevel = void 0;
7
+ // import { IncomingHttpHeaders } from 'http';
8
+ let RenderLevel;
9
+ exports.RenderLevel = RenderLevel;
10
+
11
+ (function (RenderLevel) {
12
+ RenderLevel[RenderLevel["CLIENT_RENDER"] = 0] = "CLIENT_RENDER";
13
+ RenderLevel[RenderLevel["SERVER_PREFETCH"] = 1] = "SERVER_PREFETCH";
14
+ RenderLevel[RenderLevel["SERVER_RENDER"] = 2] = "SERVER_RENDER";
15
+ })(RenderLevel || (exports.RenderLevel = RenderLevel = {}));
@@ -0,0 +1,65 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.mockResponse = exports.formatServer = exports.formatClient = void 0;
7
+
8
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
9
+
10
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
11
+
12
+ 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; }
13
+
14
+ const formatServer = request => {
15
+ const {
16
+ cookie = '',
17
+ 'user-agent': userAgent = '',
18
+ referer
19
+ } = request.headers || {};
20
+ return _objectSpread({
21
+ cookie,
22
+ userAgent,
23
+ referer
24
+ }, request);
25
+ };
26
+
27
+ exports.formatServer = formatServer;
28
+
29
+ const getQuery = () => window.location.search.substring(1).split('&').reduce((res, item) => {
30
+ const [key, value] = item.split('=');
31
+ res[key] = value;
32
+ return res;
33
+ }, {});
34
+
35
+ const formatClient = request => {
36
+ return {
37
+ params: request.params || {},
38
+ host: request.host || location.host,
39
+ pathname: request.pathname || location.pathname,
40
+ headers: request.headers || {},
41
+ cookieMap: request.cookieMap || {},
42
+ cookie: request.headers.cookie || document.cookie,
43
+ userAgent: request.headers['user-agent'] || navigator.userAgent,
44
+ referer: request.referer || document.referrer,
45
+ query: request.query || getQuery(),
46
+ url: location.href
47
+ };
48
+ };
49
+
50
+ exports.formatClient = formatClient;
51
+
52
+ const mockResponse = () => {
53
+ return {
54
+ setHeader() {
55
+ console.info('setHeader can only be used in the server side');
56
+ },
57
+
58
+ status() {
59
+ console.info('status can only be used in the server side');
60
+ }
61
+
62
+ };
63
+ };
64
+
65
+ exports.mockResponse = mockResponse;