@modern-js/runtime 1.21.2 → 2.0.0-beta.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 +52 -0
- package/dist/js/modern/cli/index.js +1 -1
- package/dist/js/modern/core/index.js +1 -1
- package/dist/js/modern/index.js +1 -0
- package/dist/js/modern/router/cli/index.js +24 -8
- package/dist/js/modern/router/runtime/index.js +1 -1
- package/dist/js/modern/router/runtime/plugin.js +26 -44
- package/dist/js/modern/router/runtime/plugin.node.js +143 -0
- package/dist/js/modern/router/runtime/types.js +1 -0
- package/dist/js/modern/router/runtime/utils.js +97 -37
- package/dist/js/modern/router/runtime/withRouter.js +22 -0
- package/dist/js/modern/runtime-context.js +2 -1
- package/dist/js/modern/ssr/cli/index.js +44 -5
- package/dist/js/modern/ssr/index.js +67 -43
- package/dist/js/modern/ssr/index.node.js +6 -2
- package/dist/js/modern/ssr/serverRender/index.js +12 -26
- package/dist/js/modern/ssr/serverRender/renderToStream/buildTemplate.after.js +38 -0
- package/dist/js/modern/ssr/serverRender/renderToStream/buildTemplate.share.js +5 -0
- package/dist/js/modern/ssr/serverRender/renderToStream/bulidTemplate.before.js +24 -0
- package/dist/js/modern/ssr/serverRender/renderToStream/index.js +73 -0
- package/dist/js/modern/ssr/serverRender/renderToStream/loadable.js +26 -0
- package/dist/js/modern/ssr/serverRender/renderToStream/renderToPipe.js +61 -0
- package/dist/js/modern/ssr/serverRender/renderToStream/styledComponent.js +11 -0
- package/dist/js/modern/ssr/serverRender/renderToStream/template.js +22 -0
- package/dist/js/modern/ssr/serverRender/renderToStream/type.js +0 -0
- package/dist/js/modern/ssr/serverRender/{entry.js → renderToString/entry.js} +4 -6
- package/dist/js/modern/ssr/serverRender/renderToString/index.js +31 -0
- package/dist/js/modern/ssr/serverRender/{loadable.js → renderToString/loadable.js} +5 -13
- package/dist/js/modern/ssr/serverRender/{reduce.js → renderToString/reduce.js} +0 -0
- package/dist/js/modern/ssr/serverRender/{styledComponent.js → renderToString/styledComponent.js} +0 -0
- package/dist/js/modern/ssr/serverRender/{template.js → renderToString/template.js} +0 -0
- package/dist/js/modern/ssr/serverRender/{type.js → renderToString/type.js} +0 -1
- package/dist/js/modern/ssr/serverRender/types.js +2 -0
- package/dist/js/modern/ssr/serverRender/utils.js +24 -0
- package/dist/js/modern/ssr/utils.js +9 -3
- package/dist/js/node/cli/index.js +1 -1
- package/dist/js/node/core/index.js +8 -1
- package/dist/js/node/index.js +8 -0
- package/dist/js/node/router/cli/index.js +24 -8
- package/dist/js/node/router/runtime/index.js +4 -4
- package/dist/js/node/router/runtime/plugin.js +24 -49
- package/dist/js/node/router/runtime/plugin.node.js +169 -0
- package/dist/js/node/router/runtime/types.js +5 -0
- package/dist/js/node/router/runtime/utils.js +97 -35
- package/dist/js/node/router/runtime/withRouter.js +35 -0
- package/dist/js/node/runtime-context.js +4 -2
- package/dist/js/node/ssr/cli/index.js +43 -5
- package/dist/js/node/ssr/index.js +66 -43
- package/dist/js/node/ssr/index.node.js +7 -3
- package/dist/js/node/ssr/serverRender/index.js +13 -35
- package/dist/js/node/ssr/serverRender/renderToStream/buildTemplate.after.js +49 -0
- package/dist/js/node/ssr/serverRender/renderToStream/buildTemplate.share.js +14 -0
- package/dist/js/node/ssr/serverRender/renderToStream/bulidTemplate.before.js +37 -0
- package/dist/js/node/ssr/serverRender/renderToStream/index.js +90 -0
- package/dist/js/node/ssr/serverRender/renderToStream/loadable.js +34 -0
- package/dist/js/node/ssr/serverRender/renderToStream/renderToPipe.js +70 -0
- package/dist/js/node/ssr/serverRender/renderToStream/styledComponent.js +19 -0
- package/dist/js/node/ssr/serverRender/renderToStream/template.js +32 -0
- package/dist/js/node/ssr/serverRender/renderToStream/type.js +0 -0
- package/dist/js/node/ssr/serverRender/{entry.js → renderToString/entry.js} +13 -15
- package/dist/js/node/ssr/serverRender/renderToString/index.js +47 -0
- package/dist/js/node/ssr/serverRender/{loadable.js → renderToString/loadable.js} +7 -14
- package/dist/js/node/ssr/serverRender/{reduce.js → renderToString/reduce.js} +0 -0
- package/dist/js/node/ssr/serverRender/{styledComponent.js → renderToString/styledComponent.js} +0 -0
- package/dist/js/node/ssr/serverRender/{template.js → renderToString/template.js} +0 -0
- package/dist/js/node/ssr/serverRender/{type.js → renderToString/type.js} +0 -1
- package/dist/js/node/ssr/serverRender/types.js +13 -0
- package/dist/js/node/ssr/serverRender/utils.js +34 -0
- package/dist/js/node/ssr/utils.js +13 -4
- package/dist/js/treeshaking/cli/index.js +1 -1
- package/dist/js/treeshaking/core/index.js +1 -1
- package/dist/js/treeshaking/index.js +1 -0
- package/dist/js/treeshaking/router/cli/index.js +24 -8
- package/dist/js/treeshaking/router/runtime/index.js +1 -1
- package/dist/js/treeshaking/router/runtime/plugin.js +25 -43
- package/dist/js/treeshaking/router/runtime/plugin.node.js +174 -0
- package/dist/js/treeshaking/router/runtime/types.js +1 -0
- package/dist/js/treeshaking/router/runtime/utils.js +100 -36
- package/dist/js/treeshaking/router/runtime/withRouter.js +17 -0
- package/dist/js/treeshaking/runtime-context.js +2 -1
- package/dist/js/treeshaking/ssr/cli/index.js +47 -5
- package/dist/js/treeshaking/ssr/index.js +74 -45
- package/dist/js/treeshaking/ssr/index.node.js +6 -2
- package/dist/js/treeshaking/ssr/serverRender/index.js +41 -55
- package/dist/js/treeshaking/ssr/serverRender/renderToStream/buildTemplate.after.js +33 -0
- package/dist/js/treeshaking/ssr/serverRender/renderToStream/buildTemplate.share.js +7 -0
- package/dist/js/treeshaking/ssr/serverRender/renderToStream/bulidTemplate.before.js +29 -0
- package/dist/js/treeshaking/ssr/serverRender/renderToStream/index.js +120 -0
- package/dist/js/treeshaking/ssr/serverRender/renderToStream/loadable.js +24 -0
- package/dist/js/treeshaking/ssr/serverRender/renderToStream/renderToPipe.js +57 -0
- package/dist/js/treeshaking/ssr/serverRender/renderToStream/styledComponent.js +10 -0
- package/dist/js/treeshaking/ssr/serverRender/renderToStream/template.js +29 -0
- package/dist/js/treeshaking/ssr/serverRender/renderToStream/type.js +0 -0
- package/dist/js/treeshaking/ssr/serverRender/{entry.js → renderToString/entry.js} +3 -3
- package/dist/js/treeshaking/ssr/serverRender/renderToString/index.js +48 -0
- package/dist/js/treeshaking/ssr/serverRender/{loadable.js → renderToString/loadable.js} +5 -17
- package/dist/js/treeshaking/ssr/serverRender/{reduce.js → renderToString/reduce.js} +0 -0
- package/dist/js/treeshaking/ssr/serverRender/{styledComponent.js → renderToString/styledComponent.js} +0 -0
- package/dist/js/treeshaking/ssr/serverRender/{template.js → renderToString/template.js} +0 -0
- package/dist/js/treeshaking/ssr/serverRender/{type.js → renderToString/type.js} +0 -1
- package/dist/js/treeshaking/ssr/serverRender/types.js +2 -0
- package/dist/js/treeshaking/ssr/serverRender/{measure.js → utils.js} +16 -0
- package/dist/js/treeshaking/ssr/utils.js +15 -3
- package/dist/types/common.d.ts +0 -2
- package/dist/types/core/index.d.ts +1 -1
- package/dist/types/core/plugin.d.ts +1 -1
- package/dist/types/exports/server.d.ts +21 -1
- package/dist/types/index.d.ts +1 -0
- package/dist/types/router/runtime/DefaultNotFound.d.ts +1 -0
- package/dist/types/router/runtime/index.d.ts +3 -3
- package/dist/types/router/runtime/plugin.d.ts +2 -45
- package/dist/types/router/runtime/plugin.node.d.ts +8 -0
- package/dist/types/router/runtime/types.d.ts +38 -0
- package/dist/types/router/runtime/utils.d.ts +5 -2
- package/dist/types/router/runtime/withRouter.d.ts +8 -0
- package/dist/types/runtime-context.d.ts +2 -1
- package/dist/types/ssr/index.d.ts +2 -2
- package/dist/types/ssr/index.node.d.ts +1 -1
- package/dist/types/ssr/react/nossr/index.d.ts +3 -1
- package/dist/types/ssr/serverRender/index.d.ts +2 -3
- package/dist/types/ssr/serverRender/renderToStream/buildTemplate.after.d.ts +6 -0
- package/dist/types/ssr/serverRender/renderToStream/buildTemplate.share.d.ts +3 -0
- package/dist/types/ssr/serverRender/renderToStream/bulidTemplate.before.d.ts +1 -0
- package/dist/types/ssr/serverRender/renderToStream/index.d.ts +6 -0
- package/dist/types/ssr/serverRender/renderToStream/loadable.d.ts +16 -0
- package/dist/types/ssr/serverRender/renderToStream/renderToPipe.d.ts +8 -0
- package/dist/types/ssr/serverRender/renderToStream/styledComponent.d.ts +12 -0
- package/dist/types/ssr/serverRender/renderToStream/template.d.ts +3 -0
- package/dist/types/ssr/serverRender/renderToStream/type.d.ts +4 -0
- package/dist/types/ssr/serverRender/{entry.d.ts → renderToString/entry.d.ts} +2 -2
- package/dist/types/ssr/serverRender/renderToString/index.d.ts +6 -0
- package/dist/types/ssr/serverRender/{loadable.d.ts → renderToString/loadable.d.ts} +0 -0
- package/dist/types/ssr/serverRender/{reduce.d.ts → renderToString/reduce.d.ts} +0 -0
- package/dist/types/ssr/serverRender/{styledComponent.d.ts → renderToString/styledComponent.d.ts} +0 -0
- package/dist/types/ssr/serverRender/{template.d.ts → renderToString/template.d.ts} +0 -0
- package/dist/types/ssr/serverRender/{type.d.ts → renderToString/type.d.ts} +1 -8
- package/dist/types/ssr/serverRender/types.d.ts +18 -0
- package/dist/types/ssr/serverRender/utils.d.ts +3 -0
- package/dist/types/ssr/utils.d.ts +4 -2
- package/dist/types/state/runtime/plugin.d.ts +1 -1
- package/package.json +57 -73
- package/types/index.d.ts +13 -0
- package/types/router.d.ts +14 -0
- package/dist/js/modern/ssr/serverRender/measure.js +0 -11
- package/dist/js/node/ssr/serverRender/measure.js +0 -20
- package/dist/types/ssr/serverRender/measure.d.ts +0 -1
- package/lib/types.d.ts +0 -10
- package/type.d.ts +0 -5
|
@@ -1,27 +1,15 @@
|
|
|
1
1
|
import _createForOfIteratorHelper from "@babel/runtime/helpers/esm/createForOfIteratorHelper";
|
|
2
2
|
import { ChunkExtractor } from '@loadable/server';
|
|
3
|
-
import { isCrossOrigin } from "
|
|
3
|
+
import { isCrossOrigin } from "../../utils";
|
|
4
|
+
import { getLoadableScripts } from "../utils";
|
|
4
5
|
|
|
5
6
|
var extname = function extname(uri) {
|
|
6
|
-
|
|
7
|
-
};
|
|
8
|
-
|
|
9
|
-
function getLoadableScripts(extractor) {
|
|
10
|
-
var check = function check(scripts) {
|
|
11
|
-
return (scripts || '').includes('__LOADABLE_REQUIRED_CHUNKS___ext');
|
|
12
|
-
};
|
|
13
|
-
|
|
14
|
-
var scripts = extractor.getScriptTags();
|
|
15
|
-
|
|
16
|
-
if (!check(scripts)) {
|
|
7
|
+
if (typeof uri !== 'string' || !uri.includes('.')) {
|
|
17
8
|
return '';
|
|
18
9
|
}
|
|
19
10
|
|
|
20
|
-
return
|
|
21
|
-
|
|
22
|
-
return "".concat(i, "</script>");
|
|
23
|
-
}).join('');
|
|
24
|
-
}
|
|
11
|
+
return ".".concat(uri === null || uri === void 0 ? void 0 : uri.split('.').pop()) || '';
|
|
12
|
+
};
|
|
25
13
|
|
|
26
14
|
export var toHtml = function toHtml(jsx, renderer, next) {
|
|
27
15
|
var stats = renderer.stats,
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
@@ -1,4 +1,20 @@
|
|
|
1
1
|
import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
|
|
2
|
+
export function getLoadableScripts(extractor) {
|
|
3
|
+
var check = function check(scripts) {
|
|
4
|
+
return (scripts || '').includes('__LOADABLE_REQUIRED_CHUNKS___ext');
|
|
5
|
+
};
|
|
6
|
+
|
|
7
|
+
var scripts = extractor.getScriptTags();
|
|
8
|
+
|
|
9
|
+
if (!check(scripts)) {
|
|
10
|
+
return '';
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
return scripts.split('</script>') // 前两个 script为 loadable 必须的 script
|
|
14
|
+
.slice(0, 2).map(function (i) {
|
|
15
|
+
return "".concat(i, "</script>");
|
|
16
|
+
}).join('');
|
|
17
|
+
}
|
|
2
18
|
|
|
3
19
|
var getLatency = function getLatency(hrtime) {
|
|
4
20
|
var _process$hrtime = process.hrtime(hrtime),
|
|
@@ -1,5 +1,8 @@
|
|
|
1
1
|
import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
|
|
2
2
|
import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
|
|
3
|
+
export var isReact18 = function isReact18() {
|
|
4
|
+
return process.env.IS_REACT18 === 'true';
|
|
5
|
+
};
|
|
3
6
|
export var formatServer = function formatServer(request) {
|
|
4
7
|
var _ref = request.headers || {},
|
|
5
8
|
_ref$cookie = _ref.cookie,
|
|
@@ -49,14 +52,23 @@ export var formatClient = function formatClient(request) {
|
|
|
49
52
|
export var mockResponse = function mockResponse() {
|
|
50
53
|
return {
|
|
51
54
|
setHeader: function setHeader() {
|
|
52
|
-
console.
|
|
55
|
+
console.warn('response.setHeader() can only be used in the server side');
|
|
53
56
|
},
|
|
54
57
|
status: function status() {
|
|
55
|
-
console.
|
|
58
|
+
console.warn('response.status() can only be used in the server side');
|
|
59
|
+
},
|
|
60
|
+
|
|
61
|
+
get locals() {
|
|
62
|
+
console.warn('response.locals can only be used in the server side');
|
|
63
|
+
return {};
|
|
56
64
|
}
|
|
65
|
+
|
|
57
66
|
};
|
|
58
67
|
};
|
|
59
|
-
export var isCrossOrigin = function isCrossOrigin(
|
|
68
|
+
export var isCrossOrigin = function isCrossOrigin() {
|
|
69
|
+
var url = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
|
|
70
|
+
var base = arguments.length > 1 ? arguments[1] : undefined;
|
|
71
|
+
|
|
60
72
|
if (url.startsWith('/') || url.startsWith('./')) {
|
|
61
73
|
return false;
|
|
62
74
|
} else if (!url.includes(base)) {
|
package/dist/types/common.d.ts
CHANGED
|
@@ -3,6 +3,6 @@ export type { Plugin } from './plugin';
|
|
|
3
3
|
export { defineConfig, getConfig } from './app-config';
|
|
4
4
|
export * from './compatible';
|
|
5
5
|
export type { TRuntimeContext, RuntimeContext } from '../runtime-context';
|
|
6
|
-
export { RuntimeReactContext } from '../runtime-context';
|
|
6
|
+
export { RuntimeReactContext, ServerRouterContext } from '../runtime-context';
|
|
7
7
|
export * from './loader';
|
|
8
8
|
export * from '@modern-js/plugin';
|
|
@@ -185,7 +185,7 @@ export declare const createPlugin: (setup?: Setup<{
|
|
|
185
185
|
context: RuntimeContext;
|
|
186
186
|
pickedContext: TRuntimeContext;
|
|
187
187
|
}, TRuntimeContext>;
|
|
188
|
-
}, Record<string, never
|
|
188
|
+
}, Record<string, never>>, Record<string, unknown>> | undefined) => import("@modern-js/plugin").Plugin<{
|
|
189
189
|
hoc: import("@modern-js/plugin").Pipeline<{
|
|
190
190
|
App: React.ComponentType<any>;
|
|
191
191
|
}, React.ComponentType<any>>;
|
|
@@ -1 +1,21 @@
|
|
|
1
|
-
|
|
1
|
+
import { AfterMatchContext, AfterRenderContext, MiddlewareContext, NextFunction } from '@modern-js/types';
|
|
2
|
+
export declare const hook: (attacher: ({
|
|
3
|
+
addMiddleware,
|
|
4
|
+
afterMatch,
|
|
5
|
+
afterRender
|
|
6
|
+
}: {
|
|
7
|
+
addMiddleware: (mid: RequestHandler) => void;
|
|
8
|
+
afterRender: (hook: AfterRenderHook) => void;
|
|
9
|
+
afterMatch: (hook: AfterMatchHook) => void;
|
|
10
|
+
}) => void) => ({
|
|
11
|
+
addMiddleware,
|
|
12
|
+
afterMatch,
|
|
13
|
+
afterRender
|
|
14
|
+
}: {
|
|
15
|
+
addMiddleware: (mid: RequestHandler) => void;
|
|
16
|
+
afterRender: (hook: AfterRenderHook) => void;
|
|
17
|
+
afterMatch: (hook: AfterMatchHook) => void;
|
|
18
|
+
}) => void;
|
|
19
|
+
export declare type AfterRenderHook = (context: AfterRenderContext, next: NextFunction) => void;
|
|
20
|
+
export declare type AfterMatchHook = (context: AfterMatchContext, next: NextFunction) => void;
|
|
21
|
+
export declare type RequestHandler = (context: MiddlewareContext, next: NextFunction) => Promise<void> | void;
|
package/dist/types/index.d.ts
CHANGED
|
@@ -2,6 +2,7 @@ import type { StateConfig } from './state';
|
|
|
2
2
|
import type { RouterConfig } from './router';
|
|
3
3
|
export type { Plugin } from './core';
|
|
4
4
|
export type { AppConfig } from './common';
|
|
5
|
+
export { isBrowser } from './common';
|
|
5
6
|
export type { BaseRuntimeContext, RuntimeContext, BaseTRuntimeContext, TRuntimeContext } from './runtime-context';
|
|
6
7
|
export { createApp, createPlugin, useLoader, bootstrap, RuntimeReactContext, registerPrefetch, defineConfig, registerInit, useRuntimeContext } from './core';
|
|
7
8
|
export { StateConfig, RouterConfig };
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { routerPlugin } from './plugin';
|
|
2
|
-
import type { SingleRouteConfig,
|
|
3
|
-
export type { SingleRouteConfig,
|
|
2
|
+
import type { SingleRouteConfig, RouterConfig } from './types';
|
|
3
|
+
export type { SingleRouteConfig, RouterConfig };
|
|
4
4
|
export default routerPlugin;
|
|
5
5
|
export * from 'react-router-dom';
|
|
6
|
-
export * from '
|
|
6
|
+
export * from './withRouter';
|
|
@@ -1,51 +1,8 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
|
-
import { History, BrowserHistoryBuildOptions, HashHistoryBuildOptions } from 'history';
|
|
3
|
-
import { RouteProps } from 'react-router-dom';
|
|
4
1
|
import type { Plugin } from '../../core';
|
|
5
|
-
|
|
6
|
-
interface Window {
|
|
7
|
-
_SERVER_DATA?: {
|
|
8
|
-
router: {
|
|
9
|
-
baseUrl: string;
|
|
10
|
-
params: Record<string, string>;
|
|
11
|
-
};
|
|
12
|
-
};
|
|
13
|
-
}
|
|
14
|
-
}
|
|
15
|
-
export declare type SingleRouteConfig = RouteProps & {
|
|
16
|
-
redirect?: string;
|
|
17
|
-
routes?: SingleRouteConfig[];
|
|
18
|
-
key?: string;
|
|
19
|
-
/**
|
|
20
|
-
* layout component
|
|
21
|
-
*/
|
|
22
|
-
|
|
23
|
-
layout?: React.ComponentType;
|
|
24
|
-
/**
|
|
25
|
-
* component would be rendered when route macthed.
|
|
26
|
-
*/
|
|
27
|
-
|
|
28
|
-
component?: React.ComponentType;
|
|
29
|
-
};
|
|
30
|
-
export declare type HistoryConfig = {
|
|
31
|
-
supportHtml5History: true;
|
|
32
|
-
historyOptions: BrowserHistoryBuildOptions;
|
|
33
|
-
} | {
|
|
34
|
-
supportHtml5History: false;
|
|
35
|
-
historyOptions: HashHistoryBuildOptions;
|
|
36
|
-
};
|
|
37
|
-
export declare type RouterConfig = Partial<HistoryConfig> & {
|
|
38
|
-
routesConfig?: {
|
|
39
|
-
globalApp?: React.ComponentType<any>;
|
|
40
|
-
routes?: SingleRouteConfig[];
|
|
41
|
-
};
|
|
42
|
-
history?: History;
|
|
43
|
-
serverBase?: string[];
|
|
44
|
-
};
|
|
2
|
+
import type { RouterConfig } from './types';
|
|
45
3
|
export declare const routerPlugin: ({
|
|
46
4
|
serverBase,
|
|
47
|
-
history: customHistory,
|
|
48
5
|
supportHtml5History,
|
|
49
6
|
routesConfig,
|
|
50
|
-
|
|
7
|
+
createRoutes
|
|
51
8
|
}: RouterConfig) => Plugin;
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { Plugin } from '../../core';
|
|
2
|
+
import { SSRServerContext } from '../../ssr/serverRender/types';
|
|
3
|
+
import type { RouterConfig } from './types';
|
|
4
|
+
export declare function createFetchHeaders(requestHeaders: SSRServerContext['request']['headers']): Headers;
|
|
5
|
+
export declare const routerPlugin: ({
|
|
6
|
+
routesConfig,
|
|
7
|
+
createRoutes
|
|
8
|
+
}: RouterConfig) => Plugin;
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import type { RouteProps, RouteObject } from 'react-router-dom';
|
|
3
|
+
import { PageRoute, NestedRoute } from '@modern-js/types';
|
|
4
|
+
declare global {
|
|
5
|
+
interface Window {
|
|
6
|
+
_SERVER_DATA?: {
|
|
7
|
+
router: {
|
|
8
|
+
baseUrl: string;
|
|
9
|
+
params: Record<string, string>;
|
|
10
|
+
};
|
|
11
|
+
};
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
export declare type SingleRouteConfig = RouteProps & {
|
|
15
|
+
redirect?: string;
|
|
16
|
+
routes?: SingleRouteConfig[];
|
|
17
|
+
key?: string;
|
|
18
|
+
/**
|
|
19
|
+
* layout component
|
|
20
|
+
*/
|
|
21
|
+
|
|
22
|
+
layout?: React.ComponentType;
|
|
23
|
+
/**
|
|
24
|
+
* component would be rendered when route macthed.
|
|
25
|
+
*/
|
|
26
|
+
|
|
27
|
+
component?: React.ComponentType;
|
|
28
|
+
};
|
|
29
|
+
export declare type RouterConfig = {
|
|
30
|
+
legacy?: boolean;
|
|
31
|
+
routesConfig: {
|
|
32
|
+
globalApp?: React.ComponentType<any>;
|
|
33
|
+
routes: (NestedRoute | PageRoute)[];
|
|
34
|
+
};
|
|
35
|
+
serverBase?: string[];
|
|
36
|
+
supportHtml5History?: boolean;
|
|
37
|
+
createRoutes?: () => RouteObject[];
|
|
38
|
+
};
|
|
@@ -1,5 +1,8 @@
|
|
|
1
|
-
import
|
|
2
|
-
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import type { NestedRoute, PageRoute } from '@modern-js/types';
|
|
3
|
+
import { RouterConfig } from './types';
|
|
4
|
+
export declare function getRouteComponents(routes: (NestedRoute | PageRoute)[], globalApp?: React.ComponentType<any>): React.ReactElement<any, string | React.JSXElementConstructor<any>>[];
|
|
5
|
+
export declare function renderRoutes(routesConfig: RouterConfig['routesConfig']): React.ReactElement<any, string | React.JSXElementConstructor<any>>[] | null;
|
|
3
6
|
export declare function getLocation(serverContext: any): string;
|
|
4
7
|
export declare const urlJoin: (...parts: string[]) => string;
|
|
5
8
|
export declare function standardSlash(str: string): string;
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { useLocation, useNavigate } from 'react-router-dom';
|
|
3
|
+
export interface WithRouterProps {
|
|
4
|
+
location: ReturnType<typeof useLocation>;
|
|
5
|
+
params: Record<string, string>;
|
|
6
|
+
navigate: ReturnType<typeof useNavigate>;
|
|
7
|
+
}
|
|
8
|
+
export declare const withRouter: <Props extends WithRouterProps>(Component: React.ComponentType<Props>) => (props: Omit<Props, keyof WithRouterProps>) => JSX.Element;
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
import { Store } from '@modern-js-reduck/store';
|
|
3
3
|
import { createLoaderManager } from './core/loader/loaderManager';
|
|
4
4
|
import { runtime } from './core/plugin';
|
|
5
|
-
import { SSRServerContext } from './ssr/serverRender/
|
|
5
|
+
import { SSRServerContext } from './ssr/serverRender/types';
|
|
6
6
|
export interface BaseRuntimeContext {
|
|
7
7
|
loaderManager: ReturnType<typeof createLoaderManager>;
|
|
8
8
|
runner: ReturnType<typeof runtime.init>;
|
|
@@ -13,6 +13,7 @@ export interface RuntimeContext extends BaseRuntimeContext {
|
|
|
13
13
|
[key: string]: any;
|
|
14
14
|
}
|
|
15
15
|
export declare const RuntimeReactContext: import("react").Context<RuntimeContext>;
|
|
16
|
+
export declare const ServerRouterContext: import("react").Context<any>;
|
|
16
17
|
export interface BaseTRuntimeContext {
|
|
17
18
|
initialData?: Record<string, unknown>;
|
|
18
19
|
request?: SSRServerContext['request'];
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import type { Plugin } from '../core';
|
|
2
|
-
import { RenderLevel,
|
|
2
|
+
import { RenderLevel, SSRServerContext, SSRPluginConfig } from './serverRender/types';
|
|
3
3
|
declare module '../core' {
|
|
4
4
|
interface SSRContainer {
|
|
5
5
|
renderLevel: RenderLevel;
|
|
6
6
|
context?: SSRServerContext;
|
|
7
7
|
}
|
|
8
8
|
}
|
|
9
|
-
export declare const ssr: (
|
|
9
|
+
export declare const ssr: (config: SSRPluginConfig) => Plugin;
|
|
10
10
|
export default ssr;
|
|
11
11
|
export * from './react';
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import type { Plugin } from '../core';
|
|
2
|
-
import
|
|
2
|
+
import { SSRPluginConfig } from './serverRender/types';
|
|
3
3
|
export declare const ssr: (config?: SSRPluginConfig) => Plugin;
|
|
4
4
|
export default ssr;
|
|
5
5
|
export * from './react';
|
|
@@ -1,2 +1,4 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
|
-
export declare const NoSSR: (props: React.PropsWithChildren<unknown>) => React.FunctionComponentElement<{
|
|
2
|
+
export declare const NoSSR: (props: React.PropsWithChildren<unknown>) => React.FunctionComponentElement<{
|
|
3
|
+
children?: React.ReactNode;
|
|
4
|
+
}>;
|
|
@@ -1,3 +1,2 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
export declare const render: (ctx: RuntimeContext, config: SSRPluginConfig, App: ModernSSRReactComponent) => Promise<string>;
|
|
1
|
+
import { ServerRenderOptions } from './types';
|
|
2
|
+
export default function serverRender(options: ServerRenderOptions): Promise<any>;
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { RuntimeContext } from 'src/runtime-context';
|
|
2
|
+
declare type BuildShellAfterTemplateOptions = {
|
|
3
|
+
context: RuntimeContext;
|
|
4
|
+
};
|
|
5
|
+
export declare function buildShellAfterTemplate(afterAppTemplate: string, options: BuildShellAfterTemplateOptions): string;
|
|
6
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function buildShellBeforeTemplate(beforeAppTemplate: string): string;
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { ChunkExtractor } from '@loadable/server';
|
|
3
|
+
import { RuntimeContext } from '../types';
|
|
4
|
+
export declare function getLoadableChunks({
|
|
5
|
+
context,
|
|
6
|
+
jsx
|
|
7
|
+
}: {
|
|
8
|
+
context: RuntimeContext;
|
|
9
|
+
jsx: React.ReactElement;
|
|
10
|
+
}): {
|
|
11
|
+
jsx: import("react").ReactElement<any, string | import("react").JSXElementConstructor<any>>;
|
|
12
|
+
chunkExtractor?: undefined;
|
|
13
|
+
} | {
|
|
14
|
+
jsx: ReactElement<any, any>;
|
|
15
|
+
chunkExtractor: ChunkExtractor;
|
|
16
|
+
};
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
/// <reference types="react" />
|
|
3
|
+
import { Writable } from 'stream';
|
|
4
|
+
import { RenderToPipeableStreamOptions } from 'react-dom/server';
|
|
5
|
+
import { InjectTemplate } from './type';
|
|
6
|
+
export declare type Pipe<T extends Writable> = (output: T) => Promise<T>;
|
|
7
|
+
declare function renderToPipe(rootElement: React.ReactElement, getTemplates: () => InjectTemplate, options?: RenderToPipeableStreamOptions): Pipe<Writable>;
|
|
8
|
+
export default renderToPipe;
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { ServerStyleSheet } from 'styled-components';
|
|
3
|
+
export declare function getStyledComponentCss({
|
|
4
|
+
jsx
|
|
5
|
+
}: {
|
|
6
|
+
jsx: React.ReactElement;
|
|
7
|
+
}): {
|
|
8
|
+
styleSheet: ServerStyleSheet;
|
|
9
|
+
jsx: import("react").ReactElement<{
|
|
10
|
+
sheet: ServerStyleSheet;
|
|
11
|
+
}, string | import("react").JSXElementConstructor<any>>;
|
|
12
|
+
};
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { RuntimeContext } from '
|
|
2
|
-
import {
|
|
1
|
+
import { RuntimeContext, ModernSSRReactComponent, SSRPluginConfig } from '../types';
|
|
2
|
+
import { SSRServerContext, RenderResult } from './type';
|
|
3
3
|
declare type EntryOptions = {
|
|
4
4
|
ctx: SSRServerContext;
|
|
5
5
|
App: ModernSSRReactComponent;
|
|
File without changes
|
|
File without changes
|
package/dist/types/ssr/serverRender/{styledComponent.d.ts → renderToString/styledComponent.d.ts}
RENAMED
|
File without changes
|
|
File without changes
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
2
|
import type { BaseSSRServerContext } from '@modern-js/types';
|
|
3
|
-
import type {
|
|
3
|
+
import type { SSRPluginConfig } from '../types';
|
|
4
4
|
export declare enum RenderLevel {
|
|
5
5
|
CLIENT_RENDER = 0,
|
|
6
6
|
SERVER_PREFETCH = 1,
|
|
@@ -12,10 +12,6 @@ export declare type SSRServerContext = BaseSSRServerContext & {
|
|
|
12
12
|
cookie: string;
|
|
13
13
|
};
|
|
14
14
|
};
|
|
15
|
-
export declare type ModernSSRReactComponent = React.ComponentType<any> & {
|
|
16
|
-
init: (context: RuntimeContext) => Promise<void>;
|
|
17
|
-
prefetch: (context: RuntimeContext) => Promise<Record<string, any>>;
|
|
18
|
-
};
|
|
19
15
|
export interface RenderEntry {
|
|
20
16
|
entryName: string;
|
|
21
17
|
host: string;
|
|
@@ -31,7 +27,4 @@ export declare type RenderResult = {
|
|
|
31
27
|
js: string;
|
|
32
28
|
css: string;
|
|
33
29
|
};
|
|
34
|
-
};
|
|
35
|
-
export declare type SSRPluginConfig = {
|
|
36
|
-
crossorigin?: boolean | 'anonymous' | 'use-credentials';
|
|
37
30
|
};
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import type { ServerConfig } from '@modern-js/core';
|
|
3
|
+
import type { RuntimeContext } from '../../core';
|
|
4
|
+
import { RenderLevel } from './renderToString/type';
|
|
5
|
+
export type { SSRServerContext } from './renderToString/type';
|
|
6
|
+
export declare type ModernSSRReactComponent = React.ComponentType<any> & {
|
|
7
|
+
init: (context: RuntimeContext) => Promise<void>;
|
|
8
|
+
prefetch: (context: RuntimeContext) => Promise<Record<string, any>>;
|
|
9
|
+
};
|
|
10
|
+
export { RuntimeContext, RenderLevel };
|
|
11
|
+
export declare type SSRPluginConfig = {
|
|
12
|
+
crossorigin?: boolean | 'anonymous' | 'use-credentials';
|
|
13
|
+
} & Exclude<ServerConfig['ssr'], boolean>;
|
|
14
|
+
export declare type ServerRenderOptions = {
|
|
15
|
+
App: ModernSSRReactComponent;
|
|
16
|
+
config: SSRPluginConfig;
|
|
17
|
+
context: RuntimeContext;
|
|
18
|
+
};
|
|
@@ -1,9 +1,11 @@
|
|
|
1
1
|
import { BaseSSRServerContext } from '@modern-js/types';
|
|
2
|
-
import { SSRServerContext } from './serverRender/
|
|
2
|
+
import { SSRServerContext } from './serverRender/types';
|
|
3
|
+
export declare const isReact18: () => boolean;
|
|
3
4
|
export declare const formatServer: (request: BaseSSRServerContext['request']) => SSRServerContext['request'];
|
|
4
5
|
export declare const formatClient: (request: BaseSSRServerContext['request']) => SSRServerContext['request'];
|
|
5
6
|
export declare const mockResponse: () => {
|
|
6
7
|
setHeader(): void;
|
|
7
8
|
status(): void;
|
|
9
|
+
readonly locals: {};
|
|
8
10
|
};
|
|
9
|
-
export declare const isCrossOrigin: (url: string, base: string) => boolean;
|
|
11
|
+
export declare const isCrossOrigin: (url: string | undefined, base: string) => boolean;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import type { Plugin } from '../../core';
|
|
2
2
|
export declare type StatePluginType = 'immer' | 'effects' | 'autoActions' | 'devtools';
|
|
3
|
-
export declare type StateConfig = Record<
|
|
3
|
+
export declare type StateConfig = Partial<Record<StatePluginType, boolean>>;
|
|
4
4
|
declare const state: (config: StateConfig) => Plugin;
|
|
5
5
|
export default state;
|
|
6
6
|
export * from '../plugins';
|