@modern-js/runtime 2.0.0-canary.0 → 2.0.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.
- package/CHANGELOG.md +328 -0
- package/dist/js/modern/cli/index.js +49 -19
- package/dist/js/modern/cli/types.d.js +0 -0
- package/dist/js/modern/common.js +4 -1
- package/dist/js/modern/config.js +0 -0
- package/dist/js/modern/core/app-config.js +8 -9
- package/dist/js/modern/core/compatible.js +195 -169
- package/dist/js/modern/core/index.js +14 -6
- package/dist/js/modern/core/loader/index.js +4 -1
- package/dist/js/modern/core/loader/loaderManager.js +75 -77
- package/dist/js/modern/core/loader/useLoader.js +96 -69
- package/dist/js/modern/core/plugin.js +37 -20
- package/dist/js/modern/document/Body.js +20 -14
- package/dist/js/modern/document/DocumentContext.js +6 -3
- package/dist/js/modern/document/DocumentStructrueContext.js +8 -4
- package/dist/js/modern/document/Head.js +20 -17
- package/dist/js/modern/document/Html.js +44 -58
- package/dist/js/modern/document/Links.js +10 -0
- package/dist/js/modern/document/Root.js +22 -20
- package/dist/js/modern/document/Script.js +20 -0
- package/dist/js/modern/document/Scripts.js +7 -7
- package/dist/js/modern/document/cli/index.js +181 -85
- package/dist/js/modern/document/constants.js +45 -15
- package/dist/js/modern/document/index.js +3 -1
- package/dist/js/modern/document/type.d.js +0 -0
- package/dist/js/modern/exports/head.js +6 -3
- package/dist/js/modern/exports/loadable.js +6 -3
- package/dist/js/modern/exports/server.js +4 -1
- package/dist/js/modern/exports/styled.js +6 -3
- package/dist/js/modern/index.js +22 -2
- package/dist/js/modern/modern-app.env.d.js +0 -0
- package/dist/js/modern/router/cli/index.js +76 -60
- package/dist/js/modern/router/index.js +7 -3
- package/dist/js/modern/router/runtime/DefaultNotFound.js +11 -10
- package/dist/js/modern/router/runtime/index.js +8 -4
- package/dist/js/modern/router/runtime/plugin.js +69 -46
- package/dist/js/modern/router/runtime/plugin.node.js +88 -83
- package/dist/js/modern/router/runtime/root/index.js +10 -10
- package/dist/js/modern/router/runtime/root/load.js +57 -36
- package/dist/js/modern/router/runtime/server.js +1 -1
- package/dist/js/modern/router/runtime/types.js +0 -1
- package/dist/js/modern/router/runtime/utils.js +91 -66
- package/dist/js/modern/router/runtime/withRouter.js +31 -15
- package/dist/js/modern/runtime-context.js +7 -3
- package/dist/js/modern/ssr/cli/babel-plugin-ssr-loader-id.js +130 -0
- package/dist/js/modern/ssr/cli/index.js +102 -79
- package/dist/js/modern/ssr/index.js +89 -71
- package/dist/js/modern/ssr/index.node.js +59 -37
- package/dist/js/modern/ssr/prefetch.js +64 -45
- package/dist/js/modern/ssr/react/index.js +6 -2
- package/dist/js/modern/ssr/react/nossr/index.js +8 -7
- package/dist/js/modern/ssr/react/prerender/index.js +53 -28
- package/dist/js/modern/ssr/react/prerender/util.js +38 -26
- package/dist/js/modern/ssr/react/withCallback/index.js +6 -7
- package/dist/js/modern/ssr/serverRender/helmet.js +18 -12
- package/dist/js/modern/ssr/serverRender/index.js +34 -13
- package/dist/js/modern/ssr/serverRender/renderToStream/buildTemplate.after.js +10 -12
- package/dist/js/modern/ssr/serverRender/renderToStream/buildTemplate.share.js +11 -5
- package/dist/js/modern/ssr/serverRender/renderToStream/bulidTemplate.before.js +35 -39
- package/dist/js/modern/ssr/serverRender/renderToStream/index.js +36 -18
- package/dist/js/modern/ssr/serverRender/renderToStream/loadable.js +7 -7
- package/dist/js/modern/ssr/serverRender/renderToStream/renderToPipe.js +56 -34
- package/dist/js/modern/ssr/serverRender/renderToStream/styledComponent.js +6 -5
- package/dist/js/modern/ssr/serverRender/renderToStream/template.js +13 -9
- package/dist/js/modern/ssr/serverRender/renderToString/entry.js +101 -84
- package/dist/js/modern/ssr/serverRender/renderToString/index.js +32 -9
- package/dist/js/modern/ssr/serverRender/renderToString/loadable.js +21 -18
- package/dist/js/modern/ssr/serverRender/renderToString/reduce.js +6 -3
- package/dist/js/modern/ssr/serverRender/renderToString/styledComponent.js +6 -3
- package/dist/js/modern/ssr/serverRender/renderToString/template.js +22 -22
- package/dist/js/modern/ssr/serverRender/renderToString/type.js +9 -6
- package/dist/js/modern/ssr/serverRender/types.js +3 -1
- package/dist/js/modern/ssr/serverRender/utils.js +11 -9
- package/dist/js/modern/ssr/type.d.js +0 -0
- package/dist/js/modern/ssr/utils.js +41 -21
- package/dist/js/modern/state/cli/index.js +43 -32
- package/dist/js/modern/state/index.js +7 -3
- package/dist/js/modern/state/plugins.js +13 -7
- package/dist/js/modern/state/runtime/index.js +9 -4
- package/dist/js/modern/state/runtime/plugin.js +56 -40
- package/dist/js/modern/state/types.js +0 -1
- package/dist/js/node/cli/index.js +79 -30
- package/dist/js/node/cli/types.d.js +0 -0
- package/dist/js/node/common.js +26 -7
- package/dist/js/node/config.js +15 -0
- package/dist/js/node/core/app-config.js +29 -14
- package/dist/js/node/core/compatible.js +227 -186
- package/dist/js/node/core/index.js +44 -99
- package/dist/js/node/core/loader/index.js +31 -11
- package/dist/js/node/core/loader/loaderManager.js +102 -83
- package/dist/js/node/core/loader/useLoader.js +120 -83
- package/dist/js/node/core/plugin.js +65 -35
- package/dist/js/node/document/Body.js +40 -23
- package/dist/js/node/document/DocumentContext.js +33 -9
- package/dist/js/node/document/DocumentStructrueContext.js +35 -10
- package/dist/js/node/document/Head.js +45 -27
- package/dist/js/node/document/Html.js +68 -65
- package/dist/js/node/document/Links.js +33 -0
- package/dist/js/node/document/Root.js +47 -31
- package/dist/js/node/document/Script.js +40 -0
- package/dist/js/node/document/Scripts.js +30 -14
- package/dist/js/node/document/cli/index.js +193 -95
- package/dist/js/node/document/constants.js +78 -28
- package/dist/js/node/document/index.js +26 -93
- package/dist/js/node/document/type.d.js +0 -0
- package/dist/js/node/exports/head.js +33 -22
- package/dist/js/node/exports/loadable.js +33 -22
- package/dist/js/node/exports/server.js +26 -7
- package/dist/js/node/exports/styled.js +33 -22
- package/dist/js/node/index.js +43 -60
- package/dist/js/node/modern-app.env.d.js +0 -0
- package/dist/js/node/router/cli/index.js +89 -65
- package/dist/js/node/router/index.js +33 -30
- package/dist/js/node/router/runtime/DefaultNotFound.js +32 -17
- package/dist/js/node/router/runtime/index.js +29 -38
- package/dist/js/node/router/runtime/plugin.js +91 -57
- package/dist/js/node/router/runtime/plugin.node.js +113 -93
- package/dist/js/node/router/runtime/root/index.js +37 -21
- package/dist/js/node/router/runtime/root/load.js +80 -42
- package/dist/js/node/router/runtime/server.js +17 -16
- package/dist/js/node/router/runtime/types.js +15 -5
- package/dist/js/node/router/runtime/utils.js +112 -75
- package/dist/js/node/router/runtime/withRouter.js +53 -22
- package/dist/js/node/runtime-context.js +30 -10
- package/dist/js/node/ssr/cli/babel-plugin-ssr-loader-id.js +139 -0
- package/dist/js/node/ssr/cli/index.js +119 -85
- package/dist/js/node/ssr/index.js +125 -104
- package/dist/js/node/ssr/index.node.js +86 -59
- package/dist/js/node/ssr/prefetch.js +84 -51
- package/dist/js/node/ssr/react/index.js +27 -16
- package/dist/js/node/ssr/react/nossr/index.js +37 -16
- package/dist/js/node/ssr/react/prerender/index.js +82 -45
- package/dist/js/node/ssr/react/prerender/type.js +15 -0
- package/dist/js/node/ssr/react/prerender/util.js +63 -36
- package/dist/js/node/ssr/react/withCallback/index.js +29 -15
- package/dist/js/node/ssr/serverRender/helmet.js +37 -17
- package/dist/js/node/ssr/serverRender/index.js +55 -19
- package/dist/js/node/ssr/serverRender/renderToStream/buildTemplate.after.js +40 -20
- package/dist/js/node/ssr/serverRender/renderToStream/buildTemplate.share.js +32 -10
- package/dist/js/node/ssr/serverRender/renderToStream/bulidTemplate.before.js +63 -48
- package/dist/js/node/ssr/serverRender/renderToStream/index.js +69 -30
- package/dist/js/node/ssr/serverRender/renderToStream/loadable.js +29 -12
- package/dist/js/node/ssr/serverRender/renderToStream/renderToPipe.js +75 -43
- package/dist/js/node/ssr/serverRender/renderToStream/styledComponent.js +29 -11
- package/dist/js/node/ssr/serverRender/renderToStream/template.js +36 -16
- package/dist/js/node/ssr/serverRender/renderToStream/type.js +15 -0
- package/dist/js/node/ssr/serverRender/renderToString/entry.js +135 -103
- package/dist/js/node/ssr/serverRender/renderToString/index.js +64 -20
- package/dist/js/node/ssr/serverRender/renderToString/loadable.js +45 -26
- package/dist/js/node/ssr/serverRender/renderToString/reduce.js +27 -7
- package/dist/js/node/ssr/serverRender/renderToString/styledComponent.js +27 -8
- package/dist/js/node/ssr/serverRender/renderToString/template.js +44 -28
- package/dist/js/node/ssr/serverRender/renderToString/type.js +31 -12
- package/dist/js/node/ssr/serverRender/types.js +25 -10
- package/dist/js/node/ssr/serverRender/utils.js +31 -13
- package/dist/js/node/ssr/type.d.js +0 -0
- package/dist/js/node/ssr/utils.js +63 -29
- package/dist/js/node/state/cli/index.js +58 -37
- package/dist/js/node/state/index.js +33 -30
- package/dist/js/node/state/plugins.js +43 -22
- package/dist/js/node/state/runtime/index.js +36 -50
- package/dist/js/node/state/runtime/plugin.js +89 -68
- package/dist/js/node/state/types.js +15 -5
- package/dist/js/treeshaking/cli/index.js +180 -52
- package/dist/js/treeshaking/cli/types.d.js +1 -0
- package/dist/js/treeshaking/common.js +4 -3
- package/dist/js/treeshaking/config.js +1 -0
- package/dist/js/treeshaking/core/app-config.js +8 -13
- package/dist/js/treeshaking/core/compatible.js +473 -276
- package/dist/js/treeshaking/core/index.js +5 -6
- package/dist/js/treeshaking/core/loader/index.js +2 -1
- package/dist/js/treeshaking/core/loader/loaderManager.js +395 -224
- package/dist/js/treeshaking/core/loader/useLoader.js +181 -83
- package/dist/js/treeshaking/core/plugin.js +164 -48
- package/dist/js/treeshaking/document/Body.js +15 -11
- package/dist/js/treeshaking/document/DocumentContext.js +7 -6
- package/dist/js/treeshaking/document/DocumentStructrueContext.js +9 -7
- package/dist/js/treeshaking/document/Head.js +20 -17
- package/dist/js/treeshaking/document/Html.js +88 -93
- package/dist/js/treeshaking/document/Links.js +8 -0
- package/dist/js/treeshaking/document/Root.js +23 -21
- package/dist/js/treeshaking/document/Script.js +15 -0
- package/dist/js/treeshaking/document/Scripts.js +7 -9
- package/dist/js/treeshaking/document/cli/index.js +386 -168
- package/dist/js/treeshaking/document/constants.js +35 -16
- package/dist/js/treeshaking/document/index.js +3 -1
- package/dist/js/treeshaking/document/type.d.js +1 -0
- package/dist/js/treeshaking/exports/head.js +4 -3
- package/dist/js/treeshaking/exports/loadable.js +4 -3
- package/dist/js/treeshaking/exports/server.js +4 -3
- package/dist/js/treeshaking/exports/styled.js +4 -3
- package/dist/js/treeshaking/index.js +3 -2
- package/dist/js/treeshaking/modern-app.env.d.js +1 -0
- package/dist/js/treeshaking/router/cli/index.js +145 -99
- package/dist/js/treeshaking/router/index.js +4 -3
- package/dist/js/treeshaking/router/runtime/DefaultNotFound.js +14 -15
- package/dist/js/treeshaking/router/runtime/index.js +5 -4
- package/dist/js/treeshaking/router/runtime/plugin.js +127 -78
- package/dist/js/treeshaking/router/runtime/plugin.node.js +375 -152
- package/dist/js/treeshaking/router/runtime/root/index.js +17 -15
- package/dist/js/treeshaking/router/runtime/root/load.js +290 -95
- package/dist/js/treeshaking/router/runtime/server.js +1 -1
- package/dist/js/treeshaking/router/runtime/types.js +1 -1
- package/dist/js/treeshaking/router/runtime/utils.js +230 -142
- package/dist/js/treeshaking/router/runtime/withRouter.js +67 -18
- package/dist/js/treeshaking/runtime-context.js +4 -3
- package/dist/js/treeshaking/ssr/cli/babel-plugin-ssr-loader-id.js +122 -0
- package/dist/js/treeshaking/ssr/cli/index.js +210 -138
- package/dist/js/treeshaking/ssr/index.js +305 -144
- package/dist/js/treeshaking/ssr/index.node.js +234 -66
- package/dist/js/treeshaking/ssr/prefetch.js +196 -79
- package/dist/js/treeshaking/ssr/react/index.js +3 -2
- package/dist/js/treeshaking/ssr/react/nossr/index.js +57 -14
- package/dist/js/treeshaking/ssr/react/prerender/index.js +226 -89
- package/dist/js/treeshaking/ssr/react/prerender/type.js +1 -0
- package/dist/js/treeshaking/ssr/react/prerender/util.js +96 -86
- package/dist/js/treeshaking/ssr/react/withCallback/index.js +16 -15
- package/dist/js/treeshaking/ssr/serverRender/helmet.js +38 -34
- package/dist/js/treeshaking/ssr/serverRender/index.js +165 -37
- package/dist/js/treeshaking/ssr/serverRender/renderToStream/buildTemplate.after.js +33 -31
- package/dist/js/treeshaking/ssr/serverRender/renderToStream/buildTemplate.share.js +7 -7
- package/dist/js/treeshaking/ssr/serverRender/renderToStream/bulidTemplate.before.js +108 -60
- package/dist/js/treeshaking/ssr/serverRender/renderToStream/index.js +157 -42
- package/dist/js/treeshaking/ssr/serverRender/renderToStream/loadable.js +20 -20
- package/dist/js/treeshaking/ssr/serverRender/renderToStream/renderToPipe.js +114 -63
- package/dist/js/treeshaking/ssr/serverRender/renderToStream/styledComponent.js +11 -10
- package/dist/js/treeshaking/ssr/serverRender/renderToStream/template.js +61 -20
- package/dist/js/treeshaking/ssr/serverRender/renderToStream/type.js +1 -0
- package/dist/js/treeshaking/ssr/serverRender/renderToString/entry.js +380 -208
- package/dist/js/treeshaking/ssr/serverRender/renderToString/index.js +161 -40
- package/dist/js/treeshaking/ssr/serverRender/renderToString/loadable.js +51 -45
- package/dist/js/treeshaking/ssr/serverRender/renderToString/reduce.js +9 -8
- package/dist/js/treeshaking/ssr/serverRender/renderToString/styledComponent.js +9 -8
- package/dist/js/treeshaking/ssr/serverRender/renderToString/template.js +142 -64
- package/dist/js/treeshaking/ssr/serverRender/renderToString/type.js +7 -6
- package/dist/js/treeshaking/ssr/serverRender/types.js +1 -1
- package/dist/js/treeshaking/ssr/serverRender/utils.js +67 -26
- package/dist/js/treeshaking/ssr/type.d.js +1 -0
- package/dist/js/treeshaking/ssr/utils.js +128 -64
- package/dist/js/treeshaking/state/cli/index.js +70 -68
- package/dist/js/treeshaking/state/index.js +4 -3
- package/dist/js/treeshaking/state/plugins.js +12 -11
- package/dist/js/treeshaking/state/runtime/index.js +5 -4
- package/dist/js/treeshaking/state/runtime/plugin.js +189 -77
- package/dist/js/treeshaking/state/types.js +1 -1
- package/dist/types/cli/index.d.ts +2 -0
- package/dist/types/config.d.ts +8 -0
- package/dist/types/core/compatible.d.ts +2 -2
- package/dist/types/core/loader/loaderManager.d.ts +4 -3
- package/dist/types/core/loader/useLoader.d.ts +6 -1
- package/dist/types/core/plugin.d.ts +10 -5
- package/dist/types/document/DocumentContext.d.ts +1 -1
- package/dist/types/document/DocumentStructrueContext.d.ts +2 -1
- package/dist/types/document/Links.d.ts +2 -0
- package/dist/types/document/Script.d.ts +4 -0
- package/dist/types/document/cli/index.d.ts +2 -0
- package/dist/types/document/constants.d.ts +3 -0
- package/dist/types/document/index.d.ts +2 -0
- package/dist/types/exports/server.d.ts +3 -3
- package/dist/types/index.d.ts +1 -0
- package/dist/types/router/cli/index.d.ts +2 -0
- package/dist/types/router/runtime/plugin.d.ts +2 -2
- package/dist/types/router/runtime/types.d.ts +6 -4
- package/dist/types/ssr/cli/babel-plugin-ssr-loader-id.d.ts +1 -0
- package/dist/types/ssr/cli/index.d.ts +2 -0
- package/dist/types/ssr/react/prerender/type.d.ts +6 -6
- package/dist/types/ssr/serverRender/renderToStream/buildTemplate.after.d.ts +1 -1
- package/dist/types/ssr/serverRender/renderToStream/buildTemplate.share.d.ts +1 -1
- package/dist/types/ssr/serverRender/renderToStream/renderToPipe.d.ts +1 -1
- package/dist/types/ssr/serverRender/renderToStream/type.d.ts +1 -1
- package/dist/types/ssr/serverRender/renderToString/entry.d.ts +1 -1
- package/dist/types/ssr/serverRender/renderToString/template.d.ts +1 -1
- package/dist/types/ssr/serverRender/renderToString/type.d.ts +3 -3
- package/dist/types/ssr/serverRender/types.d.ts +3 -3
- package/dist/types/state/cli/index.d.ts +2 -0
- package/dist/types/state/runtime/plugin.d.ts +3 -3
- package/dist/types/state/types.d.ts +2 -1
- package/package.json +19 -16
- package/types/index.d.ts +8 -2
- package/types/router.d.ts +8 -2
|
@@ -1,19 +1,19 @@
|
|
|
1
|
-
import
|
|
2
|
-
import {
|
|
1
|
+
import { Fragment, jsx } from "react/jsx-runtime";
|
|
2
|
+
import { useContext, useEffect } from "react";
|
|
3
|
+
import { useLocation } from "react-router-dom";
|
|
3
4
|
import { RuntimeReactContext } from "../../../core";
|
|
4
5
|
import { handleLoad } from "./load";
|
|
5
|
-
|
|
6
|
-
import { jsx as _jsx } from "react/jsx-runtime";
|
|
7
|
-
export function RootLayout(props) {
|
|
6
|
+
function RootLayout(props) {
|
|
8
7
|
const location = useLocation();
|
|
9
8
|
const context = useContext(RuntimeReactContext);
|
|
10
9
|
useEffect(() => {
|
|
11
|
-
const {
|
|
12
|
-
routes
|
|
13
|
-
} = props;
|
|
10
|
+
const { routes } = props;
|
|
14
11
|
handleLoad(routes, location, context.routeManifest);
|
|
15
12
|
}, [location]);
|
|
16
|
-
return
|
|
13
|
+
return /* @__PURE__ */ jsx(Fragment, {
|
|
17
14
|
children: props.children
|
|
18
15
|
});
|
|
19
|
-
}
|
|
16
|
+
}
|
|
17
|
+
export {
|
|
18
|
+
RootLayout
|
|
19
|
+
};
|
|
@@ -1,5 +1,24 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
var __async = (__this, __arguments, generator) => {
|
|
2
|
+
return new Promise((resolve, reject) => {
|
|
3
|
+
var fulfilled = (value) => {
|
|
4
|
+
try {
|
|
5
|
+
step(generator.next(value));
|
|
6
|
+
} catch (e) {
|
|
7
|
+
reject(e);
|
|
8
|
+
}
|
|
9
|
+
};
|
|
10
|
+
var rejected = (value) => {
|
|
11
|
+
try {
|
|
12
|
+
step(generator.throw(value));
|
|
13
|
+
} catch (e) {
|
|
14
|
+
reject(e);
|
|
15
|
+
}
|
|
16
|
+
};
|
|
17
|
+
var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
|
|
18
|
+
step((generator = generator.apply(__this, __arguments)).next());
|
|
19
|
+
});
|
|
20
|
+
};
|
|
21
|
+
import { matchRoutes } from "react-router-dom";
|
|
3
22
|
class Logger {
|
|
4
23
|
static getLogger(options) {
|
|
5
24
|
if (this.logger) {
|
|
@@ -9,53 +28,55 @@ class Logger {
|
|
|
9
28
|
return this.logger;
|
|
10
29
|
}
|
|
11
30
|
constructor(options) {
|
|
12
|
-
_defineProperty(this, "enableLogging", void 0);
|
|
13
31
|
this.enableLogging = options.enableLogging;
|
|
14
32
|
}
|
|
15
33
|
log(...args) {
|
|
16
34
|
if (this.enableLogging) {
|
|
17
|
-
// eslint-disable-next-line no-console
|
|
18
35
|
console.log(...args);
|
|
19
36
|
}
|
|
20
37
|
}
|
|
21
38
|
}
|
|
22
|
-
|
|
23
|
-
export function handleLoad(routes, location, routeManifest) {
|
|
39
|
+
function handleLoad(routes, location, routeManifest) {
|
|
24
40
|
if (!routeManifest || !routeManifest.enableFetchParallel === false) {
|
|
25
41
|
return;
|
|
26
42
|
}
|
|
27
|
-
const {
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
enableLogging: routeManifest.enableLogging
|
|
32
|
-
}).log('handle page load');
|
|
43
|
+
const { routeAssets } = routeManifest;
|
|
44
|
+
Logger.getLogger({ enableLogging: routeManifest.enableLogging }).log(
|
|
45
|
+
"handle page load"
|
|
46
|
+
);
|
|
33
47
|
const matches = matchClientRoutes(routes, location);
|
|
34
|
-
matches
|
|
48
|
+
matches == null ? void 0 : matches.forEach((match) => loadRouteModule(match.route, routeAssets));
|
|
35
49
|
}
|
|
36
|
-
|
|
50
|
+
function matchClientRoutes(routes, location) {
|
|
37
51
|
const matches = matchRoutes(routes, location);
|
|
38
52
|
return matches;
|
|
39
53
|
}
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
chunkIds
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
}
|
|
54
|
+
function loadRouteModule(route, routeAssets) {
|
|
55
|
+
return __async(this, null, function* () {
|
|
56
|
+
const routeId = route.id;
|
|
57
|
+
if (!routeId) {
|
|
58
|
+
return;
|
|
59
|
+
}
|
|
60
|
+
if (!routeAssets[routeId]) {
|
|
61
|
+
return;
|
|
62
|
+
}
|
|
63
|
+
const { chunkIds } = routeAssets[routeId];
|
|
64
|
+
if (!chunkIds) {
|
|
65
|
+
return;
|
|
66
|
+
}
|
|
67
|
+
try {
|
|
68
|
+
yield Promise.all(
|
|
69
|
+
chunkIds.map((chunkId) => {
|
|
70
|
+
return __webpack_chunk_load__(String(chunkId));
|
|
71
|
+
})
|
|
72
|
+
);
|
|
73
|
+
} catch (error) {
|
|
74
|
+
console.error(error);
|
|
75
|
+
}
|
|
76
|
+
});
|
|
77
|
+
}
|
|
78
|
+
export {
|
|
79
|
+
handleLoad,
|
|
80
|
+
loadRouteModule,
|
|
81
|
+
matchClientRoutes
|
|
82
|
+
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export * from
|
|
1
|
+
export * from "react-router-dom/server";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1,24 +1,41 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __defProps = Object.defineProperties;
|
|
3
|
+
var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
|
|
4
|
+
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
7
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
8
|
+
var __spreadValues = (a, b) => {
|
|
9
|
+
for (var prop in b || (b = {}))
|
|
10
|
+
if (__hasOwnProp.call(b, prop))
|
|
11
|
+
__defNormalProp(a, prop, b[prop]);
|
|
12
|
+
if (__getOwnPropSymbols)
|
|
13
|
+
for (var prop of __getOwnPropSymbols(b)) {
|
|
14
|
+
if (__propIsEnum.call(b, prop))
|
|
15
|
+
__defNormalProp(a, prop, b[prop]);
|
|
16
|
+
}
|
|
17
|
+
return a;
|
|
18
|
+
};
|
|
19
|
+
var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
|
|
20
|
+
var __objRest = (source, exclude) => {
|
|
21
|
+
var target = {};
|
|
22
|
+
for (var prop in source)
|
|
23
|
+
if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
|
|
24
|
+
target[prop] = source[prop];
|
|
25
|
+
if (source != null && __getOwnPropSymbols)
|
|
26
|
+
for (var prop of __getOwnPropSymbols(source)) {
|
|
27
|
+
if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
|
|
28
|
+
target[prop] = source[prop];
|
|
29
|
+
}
|
|
30
|
+
return target;
|
|
31
|
+
};
|
|
32
|
+
import { jsx } from "react/jsx-runtime";
|
|
33
|
+
import { Suspense } from "react";
|
|
34
|
+
import { Route } from "react-router-dom";
|
|
9
35
|
import { DefaultNotFound } from "./DefaultNotFound";
|
|
10
36
|
import { RootLayout } from "./root";
|
|
11
|
-
import { jsx as _jsx } from "react/jsx-runtime";
|
|
12
37
|
const renderNestedRoute = (nestedRoute, parent) => {
|
|
13
|
-
const {
|
|
14
|
-
children,
|
|
15
|
-
index,
|
|
16
|
-
id,
|
|
17
|
-
component: Component
|
|
18
|
-
} = nestedRoute;
|
|
19
|
-
const childElements = children === null || children === void 0 ? void 0 : children.map(childRoute => {
|
|
20
|
-
return renderNestedRoute(childRoute, nestedRoute);
|
|
21
|
-
});
|
|
38
|
+
const { children, index, id, component: Component } = nestedRoute;
|
|
22
39
|
const routeProps = {
|
|
23
40
|
caseSensitive: nestedRoute.caseSensitive,
|
|
24
41
|
path: nestedRoute.path,
|
|
@@ -29,121 +46,129 @@ const renderNestedRoute = (nestedRoute, parent) => {
|
|
|
29
46
|
shouldRevalidate: nestedRoute.shouldRevalidate,
|
|
30
47
|
handle: nestedRoute.handle,
|
|
31
48
|
index: nestedRoute.index,
|
|
49
|
+
element: nestedRoute.element,
|
|
32
50
|
errorElement: nestedRoute.errorElement
|
|
33
51
|
};
|
|
34
52
|
if (nestedRoute.error) {
|
|
35
|
-
const errorElement =
|
|
53
|
+
const errorElement = /* @__PURE__ */ jsx(nestedRoute.error, {});
|
|
36
54
|
routeProps.errorElement = errorElement;
|
|
37
55
|
}
|
|
38
56
|
let element;
|
|
39
57
|
if (Component) {
|
|
40
|
-
if (parent
|
|
58
|
+
if (parent == null ? void 0 : parent.loading) {
|
|
41
59
|
const Loading = parent.loading;
|
|
42
|
-
element =
|
|
43
|
-
fallback:
|
|
44
|
-
children:
|
|
60
|
+
element = /* @__PURE__ */ jsx(Suspense, {
|
|
61
|
+
fallback: /* @__PURE__ */ jsx(Loading, {}),
|
|
62
|
+
children: /* @__PURE__ */ jsx(Component, {})
|
|
45
63
|
});
|
|
46
|
-
} else {
|
|
47
|
-
element =
|
|
48
|
-
children:
|
|
64
|
+
} else if (!(parent == null ? void 0 : parent.index)) {
|
|
65
|
+
element = /* @__PURE__ */ jsx(Suspense, {
|
|
66
|
+
children: /* @__PURE__ */ jsx(Component, {})
|
|
49
67
|
});
|
|
68
|
+
} else {
|
|
69
|
+
element = /* @__PURE__ */ jsx(Component, {});
|
|
50
70
|
}
|
|
71
|
+
} else {
|
|
72
|
+
nestedRoute.loading = parent == null ? void 0 : parent.loading;
|
|
51
73
|
}
|
|
52
74
|
if (!parent && element) {
|
|
53
|
-
element =
|
|
75
|
+
element = /* @__PURE__ */ jsx(RootLayout, {
|
|
54
76
|
routes: [nestedRoute],
|
|
55
77
|
children: element
|
|
56
78
|
});
|
|
57
79
|
}
|
|
58
|
-
|
|
59
|
-
|
|
80
|
+
if (element) {
|
|
81
|
+
routeProps.element = element;
|
|
82
|
+
}
|
|
83
|
+
const childElements = children == null ? void 0 : children.map((childRoute) => {
|
|
84
|
+
return renderNestedRoute(childRoute, nestedRoute);
|
|
85
|
+
});
|
|
86
|
+
const routeElement = index ? /* @__PURE__ */ jsx(Route, __spreadProps(__spreadValues({}, routeProps), {
|
|
60
87
|
index: true
|
|
61
|
-
}), id) :
|
|
88
|
+
}), id) : /* @__PURE__ */ jsx(Route, __spreadProps(__spreadValues({}, routeProps), {
|
|
62
89
|
index: false,
|
|
63
90
|
children: childElements
|
|
64
91
|
}), id);
|
|
65
92
|
return routeElement;
|
|
66
93
|
};
|
|
67
|
-
|
|
68
|
-
const Layout =
|
|
69
|
-
|
|
70
|
-
Component
|
|
71
|
-
} = _ref,
|
|
72
|
-
props = _objectWithoutProperties(_ref, _excluded);
|
|
94
|
+
function getRouteComponents(routes, globalApp) {
|
|
95
|
+
const Layout = (_a) => {
|
|
96
|
+
var _b = _a, { Component } = _b, props = __objRest(_b, ["Component"]);
|
|
73
97
|
const GlobalLayout = globalApp;
|
|
74
98
|
if (!GlobalLayout) {
|
|
75
|
-
return
|
|
99
|
+
return /* @__PURE__ */ jsx(Component, __spreadValues({}, props));
|
|
76
100
|
}
|
|
77
|
-
return
|
|
78
|
-
Component
|
|
101
|
+
return /* @__PURE__ */ jsx(GlobalLayout, __spreadValues({
|
|
102
|
+
Component
|
|
79
103
|
}, props));
|
|
80
104
|
};
|
|
81
105
|
const routeElements = [];
|
|
82
106
|
for (const route of routes) {
|
|
83
|
-
if (route.type ===
|
|
107
|
+
if (route.type === "nested") {
|
|
84
108
|
const routeElement = renderNestedRoute(route);
|
|
85
109
|
routeElements.push(routeElement);
|
|
86
110
|
} else {
|
|
87
|
-
const routeElement =
|
|
111
|
+
const routeElement = /* @__PURE__ */ jsx(Route, {
|
|
88
112
|
path: route.path,
|
|
89
|
-
element:
|
|
113
|
+
element: /* @__PURE__ */ jsx(Layout, {
|
|
90
114
|
Component: route.component
|
|
91
115
|
})
|
|
92
116
|
}, route.path);
|
|
93
117
|
routeElements.push(routeElement);
|
|
94
118
|
}
|
|
95
119
|
}
|
|
96
|
-
routeElements.push(
|
|
120
|
+
routeElements.push(/* @__PURE__ */ jsx(Route, {
|
|
97
121
|
path: "*",
|
|
98
|
-
element:
|
|
122
|
+
element: /* @__PURE__ */ jsx(DefaultNotFound, {})
|
|
99
123
|
}, "*"));
|
|
100
124
|
return routeElements;
|
|
101
125
|
}
|
|
102
|
-
|
|
126
|
+
function renderRoutes(routesConfig) {
|
|
103
127
|
if (!routesConfig) {
|
|
104
128
|
return null;
|
|
105
129
|
}
|
|
106
|
-
const {
|
|
107
|
-
routes,
|
|
108
|
-
globalApp
|
|
109
|
-
} = routesConfig;
|
|
130
|
+
const { routes, globalApp } = routesConfig;
|
|
110
131
|
if (!routes) {
|
|
111
132
|
return null;
|
|
112
133
|
}
|
|
113
134
|
const routeElements = getRouteComponents(routes, globalApp);
|
|
114
135
|
return routeElements;
|
|
115
136
|
}
|
|
116
|
-
|
|
117
|
-
var
|
|
118
|
-
const {
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
} = (serverContext === null || serverContext === void 0 ? void 0 : serverContext.request) || {};
|
|
122
|
-
const cleanUrl = url === null || url === void 0 ? void 0 : (_url$replace = url.replace('http://', '')) === null || _url$replace === void 0 ? void 0 : _url$replace.replace('https://', '');
|
|
123
|
-
const index = (cleanUrl || '').indexOf(pathname);
|
|
137
|
+
function getLocation(serverContext) {
|
|
138
|
+
var _a;
|
|
139
|
+
const { pathname, url } = (serverContext == null ? void 0 : serverContext.request) || {};
|
|
140
|
+
const cleanUrl = (_a = url == null ? void 0 : url.replace("http://", "")) == null ? void 0 : _a.replace("https://", "");
|
|
141
|
+
const index = (cleanUrl || "").indexOf(pathname);
|
|
124
142
|
if (index === -1) {
|
|
125
143
|
return pathname;
|
|
126
144
|
}
|
|
127
145
|
return cleanUrl.substring(index);
|
|
128
146
|
}
|
|
129
|
-
|
|
130
|
-
const separator =
|
|
131
|
-
const replace = new RegExp(`${separator}{1,}`,
|
|
147
|
+
const urlJoin = (...parts) => {
|
|
148
|
+
const separator = "/";
|
|
149
|
+
const replace = new RegExp(`${separator}{1,}`, "g");
|
|
132
150
|
return standardSlash(parts.join(separator).replace(replace, separator));
|
|
133
151
|
};
|
|
134
|
-
|
|
152
|
+
function standardSlash(str) {
|
|
135
153
|
let addr = str;
|
|
136
|
-
if (!addr || typeof addr !==
|
|
154
|
+
if (!addr || typeof addr !== "string") {
|
|
137
155
|
return addr;
|
|
138
156
|
}
|
|
139
|
-
if (addr.startsWith(
|
|
157
|
+
if (addr.startsWith(".")) {
|
|
140
158
|
addr = addr.slice(1);
|
|
141
159
|
}
|
|
142
|
-
if (!addr.startsWith(
|
|
160
|
+
if (!addr.startsWith("/")) {
|
|
143
161
|
addr = `/${addr}`;
|
|
144
162
|
}
|
|
145
|
-
if (addr.endsWith(
|
|
163
|
+
if (addr.endsWith("/") && addr !== "/") {
|
|
146
164
|
addr = addr.slice(0, addr.length - 1);
|
|
147
165
|
}
|
|
148
166
|
return addr;
|
|
149
|
-
}
|
|
167
|
+
}
|
|
168
|
+
export {
|
|
169
|
+
getLocation,
|
|
170
|
+
getRouteComponents,
|
|
171
|
+
renderRoutes,
|
|
172
|
+
standardSlash,
|
|
173
|
+
urlJoin
|
|
174
|
+
};
|
|
@@ -1,20 +1,36 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __defProps = Object.defineProperties;
|
|
3
|
+
var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
|
|
4
|
+
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
7
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
8
|
+
var __spreadValues = (a, b) => {
|
|
9
|
+
for (var prop in b || (b = {}))
|
|
10
|
+
if (__hasOwnProp.call(b, prop))
|
|
11
|
+
__defNormalProp(a, prop, b[prop]);
|
|
12
|
+
if (__getOwnPropSymbols)
|
|
13
|
+
for (var prop of __getOwnPropSymbols(b)) {
|
|
14
|
+
if (__propIsEnum.call(b, prop))
|
|
15
|
+
__defNormalProp(a, prop, b[prop]);
|
|
16
|
+
}
|
|
17
|
+
return a;
|
|
18
|
+
};
|
|
19
|
+
var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
|
|
20
|
+
import { jsx } from "react/jsx-runtime";
|
|
21
|
+
import { useLocation, useNavigate, useParams } from "react-router-dom";
|
|
22
|
+
const withRouter = (Component) => {
|
|
23
|
+
return (props) => {
|
|
11
24
|
const location = useLocation();
|
|
12
25
|
const params = useParams();
|
|
13
26
|
const navigate = useNavigate();
|
|
14
|
-
return
|
|
15
|
-
location
|
|
16
|
-
params
|
|
17
|
-
navigate
|
|
27
|
+
return /* @__PURE__ */ jsx(Component, __spreadProps(__spreadValues({}, props), {
|
|
28
|
+
location,
|
|
29
|
+
params,
|
|
30
|
+
navigate
|
|
18
31
|
}));
|
|
19
32
|
};
|
|
20
|
-
};
|
|
33
|
+
};
|
|
34
|
+
export {
|
|
35
|
+
withRouter
|
|
36
|
+
};
|
|
@@ -1,3 +1,7 @@
|
|
|
1
|
-
import { createContext } from
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
import { createContext } from "react";
|
|
2
|
+
const RuntimeReactContext = createContext({});
|
|
3
|
+
const ServerRouterContext = createContext({});
|
|
4
|
+
export {
|
|
5
|
+
RuntimeReactContext,
|
|
6
|
+
ServerRouterContext
|
|
7
|
+
};
|
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
2
|
+
var __commonJS = (cb, mod) => function __require() {
|
|
3
|
+
return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports;
|
|
4
|
+
};
|
|
5
|
+
import crypto from "crypto";
|
|
6
|
+
import { Buffer as Buffer2 } from "buffer";
|
|
7
|
+
import * as t from "@babel/types";
|
|
8
|
+
import { get } from "@modern-js/utils/lodash";
|
|
9
|
+
var require_babel_plugin_ssr_loader_id = __commonJS({
|
|
10
|
+
"src/ssr/cli/babel-plugin-ssr-loader-id.ts"(exports, module) {
|
|
11
|
+
const RUNTIME_PACKAGE_NAMES = ["@modern-js/runtime"];
|
|
12
|
+
const FUNCTION_USE_LOADER_NAME = "useLoader";
|
|
13
|
+
function getHash(filepath) {
|
|
14
|
+
const cwd = process.cwd();
|
|
15
|
+
const point = filepath.indexOf(cwd);
|
|
16
|
+
let relativePath = filepath;
|
|
17
|
+
if (point !== -1) {
|
|
18
|
+
relativePath = filepath.substring(point + cwd.length);
|
|
19
|
+
}
|
|
20
|
+
const fileBuf = Buffer2.from(relativePath);
|
|
21
|
+
const fsHash = crypto.createHash("md5");
|
|
22
|
+
const md5 = fsHash.update(fileBuf).digest("hex");
|
|
23
|
+
return md5;
|
|
24
|
+
}
|
|
25
|
+
function getUseLoaderPath(path, calleeName) {
|
|
26
|
+
const { node } = path;
|
|
27
|
+
if (!calleeName || node.callee.name !== calleeName) {
|
|
28
|
+
return false;
|
|
29
|
+
}
|
|
30
|
+
const arg1 = get(node, "arguments.0");
|
|
31
|
+
if (t.isFunction(arg1) || t.isFunctionExpression(arg1) || t.isArrowFunctionExpression(arg1) || t.isIdentifier(arg1) || t.isCallExpression(arg1) || t.isMemberExpression(arg1)) {
|
|
32
|
+
const loaderPath = path.get("arguments.0");
|
|
33
|
+
if (isDuplicateInnerLoader(loaderPath)) {
|
|
34
|
+
return false;
|
|
35
|
+
} else {
|
|
36
|
+
return loaderPath;
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
console.warn("useLoader 中 loaderId 生成失败,请检查 useLoader");
|
|
40
|
+
throw path.buildCodeFrameError(`
|
|
41
|
+
please check the usage of ${path.node.name}
|
|
42
|
+
`);
|
|
43
|
+
}
|
|
44
|
+
function isDuplicateInnerLoader(path) {
|
|
45
|
+
const { node } = path;
|
|
46
|
+
if (t.isFunctionExpression(node.callee)) {
|
|
47
|
+
if (t.isBlockStatement(node.callee.body)) {
|
|
48
|
+
if (get(node.callee.body, "body.0.declarations.0.id.name") === "innerLoader" && get(node.callee.body, "body.2.argument.name") === "innerLoader") {
|
|
49
|
+
return true;
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
return false;
|
|
54
|
+
}
|
|
55
|
+
function getSelfRunLoaderExpression(loaderExpression, id) {
|
|
56
|
+
return t.callExpression(
|
|
57
|
+
t.functionExpression(
|
|
58
|
+
null,
|
|
59
|
+
[],
|
|
60
|
+
t.blockStatement([
|
|
61
|
+
t.variableDeclaration("var", [
|
|
62
|
+
t.variableDeclarator(t.identifier("innerLoader"), loaderExpression)
|
|
63
|
+
]),
|
|
64
|
+
t.expressionStatement(
|
|
65
|
+
t.assignmentExpression(
|
|
66
|
+
"=",
|
|
67
|
+
t.memberExpression(t.identifier("innerLoader"), t.identifier("id")),
|
|
68
|
+
t.stringLiteral(id)
|
|
69
|
+
)
|
|
70
|
+
),
|
|
71
|
+
t.returnStatement(t.identifier("innerLoader"))
|
|
72
|
+
])
|
|
73
|
+
),
|
|
74
|
+
[]
|
|
75
|
+
);
|
|
76
|
+
}
|
|
77
|
+
module.exports = function() {
|
|
78
|
+
let useLoader = null;
|
|
79
|
+
let hash = "";
|
|
80
|
+
let index = 0;
|
|
81
|
+
function genId() {
|
|
82
|
+
return `${hash}_${index++}`;
|
|
83
|
+
}
|
|
84
|
+
return {
|
|
85
|
+
name: "babel-plugin-ssr-loader-id",
|
|
86
|
+
pre() {
|
|
87
|
+
index = 0;
|
|
88
|
+
useLoader = null;
|
|
89
|
+
hash = "";
|
|
90
|
+
},
|
|
91
|
+
visitor: {
|
|
92
|
+
ImportDeclaration(path, state) {
|
|
93
|
+
if (useLoader) {
|
|
94
|
+
return false;
|
|
95
|
+
}
|
|
96
|
+
if (!RUNTIME_PACKAGE_NAMES.includes(get(path, "node.source.value"))) {
|
|
97
|
+
return false;
|
|
98
|
+
}
|
|
99
|
+
hash = getHash(state.file.opts.filename);
|
|
100
|
+
get(path, "node.specifiers", []).forEach(({ imported, local }) => {
|
|
101
|
+
if (!imported) {
|
|
102
|
+
throw path.buildCodeFrameError(
|
|
103
|
+
`please \`import { useLoader } from ${RUNTIME_PACKAGE_NAMES[0]}\``
|
|
104
|
+
);
|
|
105
|
+
}
|
|
106
|
+
if (!useLoader && imported.name === FUNCTION_USE_LOADER_NAME) {
|
|
107
|
+
useLoader = local.name;
|
|
108
|
+
}
|
|
109
|
+
});
|
|
110
|
+
return false;
|
|
111
|
+
},
|
|
112
|
+
CallExpression(path) {
|
|
113
|
+
let loaderPath = getUseLoaderPath(path, useLoader);
|
|
114
|
+
if (loaderPath) {
|
|
115
|
+
if (!Array.isArray(loaderPath)) {
|
|
116
|
+
loaderPath = [loaderPath];
|
|
117
|
+
}
|
|
118
|
+
loaderPath.forEach((p) => {
|
|
119
|
+
p.replaceWith(getSelfRunLoaderExpression(p.node, genId()));
|
|
120
|
+
});
|
|
121
|
+
return false;
|
|
122
|
+
}
|
|
123
|
+
return false;
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
};
|
|
127
|
+
};
|
|
128
|
+
}
|
|
129
|
+
});
|
|
130
|
+
export default require_babel_plugin_ssr_loader_id();
|