@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.
Files changed (148) hide show
  1. package/CHANGELOG.md +52 -0
  2. package/dist/js/modern/cli/index.js +1 -1
  3. package/dist/js/modern/core/index.js +1 -1
  4. package/dist/js/modern/index.js +1 -0
  5. package/dist/js/modern/router/cli/index.js +24 -8
  6. package/dist/js/modern/router/runtime/index.js +1 -1
  7. package/dist/js/modern/router/runtime/plugin.js +26 -44
  8. package/dist/js/modern/router/runtime/plugin.node.js +143 -0
  9. package/dist/js/modern/router/runtime/types.js +1 -0
  10. package/dist/js/modern/router/runtime/utils.js +97 -37
  11. package/dist/js/modern/router/runtime/withRouter.js +22 -0
  12. package/dist/js/modern/runtime-context.js +2 -1
  13. package/dist/js/modern/ssr/cli/index.js +44 -5
  14. package/dist/js/modern/ssr/index.js +67 -43
  15. package/dist/js/modern/ssr/index.node.js +6 -2
  16. package/dist/js/modern/ssr/serverRender/index.js +12 -26
  17. package/dist/js/modern/ssr/serverRender/renderToStream/buildTemplate.after.js +38 -0
  18. package/dist/js/modern/ssr/serverRender/renderToStream/buildTemplate.share.js +5 -0
  19. package/dist/js/modern/ssr/serverRender/renderToStream/bulidTemplate.before.js +24 -0
  20. package/dist/js/modern/ssr/serverRender/renderToStream/index.js +73 -0
  21. package/dist/js/modern/ssr/serverRender/renderToStream/loadable.js +26 -0
  22. package/dist/js/modern/ssr/serverRender/renderToStream/renderToPipe.js +61 -0
  23. package/dist/js/modern/ssr/serverRender/renderToStream/styledComponent.js +11 -0
  24. package/dist/js/modern/ssr/serverRender/renderToStream/template.js +22 -0
  25. package/dist/js/modern/ssr/serverRender/renderToStream/type.js +0 -0
  26. package/dist/js/modern/ssr/serverRender/{entry.js → renderToString/entry.js} +4 -6
  27. package/dist/js/modern/ssr/serverRender/renderToString/index.js +31 -0
  28. package/dist/js/modern/ssr/serverRender/{loadable.js → renderToString/loadable.js} +5 -13
  29. package/dist/js/modern/ssr/serverRender/{reduce.js → renderToString/reduce.js} +0 -0
  30. package/dist/js/modern/ssr/serverRender/{styledComponent.js → renderToString/styledComponent.js} +0 -0
  31. package/dist/js/modern/ssr/serverRender/{template.js → renderToString/template.js} +0 -0
  32. package/dist/js/modern/ssr/serverRender/{type.js → renderToString/type.js} +0 -1
  33. package/dist/js/modern/ssr/serverRender/types.js +2 -0
  34. package/dist/js/modern/ssr/serverRender/utils.js +24 -0
  35. package/dist/js/modern/ssr/utils.js +9 -3
  36. package/dist/js/node/cli/index.js +1 -1
  37. package/dist/js/node/core/index.js +8 -1
  38. package/dist/js/node/index.js +8 -0
  39. package/dist/js/node/router/cli/index.js +24 -8
  40. package/dist/js/node/router/runtime/index.js +4 -4
  41. package/dist/js/node/router/runtime/plugin.js +24 -49
  42. package/dist/js/node/router/runtime/plugin.node.js +169 -0
  43. package/dist/js/node/router/runtime/types.js +5 -0
  44. package/dist/js/node/router/runtime/utils.js +97 -35
  45. package/dist/js/node/router/runtime/withRouter.js +35 -0
  46. package/dist/js/node/runtime-context.js +4 -2
  47. package/dist/js/node/ssr/cli/index.js +43 -5
  48. package/dist/js/node/ssr/index.js +66 -43
  49. package/dist/js/node/ssr/index.node.js +7 -3
  50. package/dist/js/node/ssr/serverRender/index.js +13 -35
  51. package/dist/js/node/ssr/serverRender/renderToStream/buildTemplate.after.js +49 -0
  52. package/dist/js/node/ssr/serverRender/renderToStream/buildTemplate.share.js +14 -0
  53. package/dist/js/node/ssr/serverRender/renderToStream/bulidTemplate.before.js +37 -0
  54. package/dist/js/node/ssr/serverRender/renderToStream/index.js +90 -0
  55. package/dist/js/node/ssr/serverRender/renderToStream/loadable.js +34 -0
  56. package/dist/js/node/ssr/serverRender/renderToStream/renderToPipe.js +70 -0
  57. package/dist/js/node/ssr/serverRender/renderToStream/styledComponent.js +19 -0
  58. package/dist/js/node/ssr/serverRender/renderToStream/template.js +32 -0
  59. package/dist/js/node/ssr/serverRender/renderToStream/type.js +0 -0
  60. package/dist/js/node/ssr/serverRender/{entry.js → renderToString/entry.js} +13 -15
  61. package/dist/js/node/ssr/serverRender/renderToString/index.js +47 -0
  62. package/dist/js/node/ssr/serverRender/{loadable.js → renderToString/loadable.js} +7 -14
  63. package/dist/js/node/ssr/serverRender/{reduce.js → renderToString/reduce.js} +0 -0
  64. package/dist/js/node/ssr/serverRender/{styledComponent.js → renderToString/styledComponent.js} +0 -0
  65. package/dist/js/node/ssr/serverRender/{template.js → renderToString/template.js} +0 -0
  66. package/dist/js/node/ssr/serverRender/{type.js → renderToString/type.js} +0 -1
  67. package/dist/js/node/ssr/serverRender/types.js +13 -0
  68. package/dist/js/node/ssr/serverRender/utils.js +34 -0
  69. package/dist/js/node/ssr/utils.js +13 -4
  70. package/dist/js/treeshaking/cli/index.js +1 -1
  71. package/dist/js/treeshaking/core/index.js +1 -1
  72. package/dist/js/treeshaking/index.js +1 -0
  73. package/dist/js/treeshaking/router/cli/index.js +24 -8
  74. package/dist/js/treeshaking/router/runtime/index.js +1 -1
  75. package/dist/js/treeshaking/router/runtime/plugin.js +25 -43
  76. package/dist/js/treeshaking/router/runtime/plugin.node.js +174 -0
  77. package/dist/js/treeshaking/router/runtime/types.js +1 -0
  78. package/dist/js/treeshaking/router/runtime/utils.js +100 -36
  79. package/dist/js/treeshaking/router/runtime/withRouter.js +17 -0
  80. package/dist/js/treeshaking/runtime-context.js +2 -1
  81. package/dist/js/treeshaking/ssr/cli/index.js +47 -5
  82. package/dist/js/treeshaking/ssr/index.js +74 -45
  83. package/dist/js/treeshaking/ssr/index.node.js +6 -2
  84. package/dist/js/treeshaking/ssr/serverRender/index.js +41 -55
  85. package/dist/js/treeshaking/ssr/serverRender/renderToStream/buildTemplate.after.js +33 -0
  86. package/dist/js/treeshaking/ssr/serverRender/renderToStream/buildTemplate.share.js +7 -0
  87. package/dist/js/treeshaking/ssr/serverRender/renderToStream/bulidTemplate.before.js +29 -0
  88. package/dist/js/treeshaking/ssr/serverRender/renderToStream/index.js +120 -0
  89. package/dist/js/treeshaking/ssr/serverRender/renderToStream/loadable.js +24 -0
  90. package/dist/js/treeshaking/ssr/serverRender/renderToStream/renderToPipe.js +57 -0
  91. package/dist/js/treeshaking/ssr/serverRender/renderToStream/styledComponent.js +10 -0
  92. package/dist/js/treeshaking/ssr/serverRender/renderToStream/template.js +29 -0
  93. package/dist/js/treeshaking/ssr/serverRender/renderToStream/type.js +0 -0
  94. package/dist/js/treeshaking/ssr/serverRender/{entry.js → renderToString/entry.js} +3 -3
  95. package/dist/js/treeshaking/ssr/serverRender/renderToString/index.js +48 -0
  96. package/dist/js/treeshaking/ssr/serverRender/{loadable.js → renderToString/loadable.js} +5 -17
  97. package/dist/js/treeshaking/ssr/serverRender/{reduce.js → renderToString/reduce.js} +0 -0
  98. package/dist/js/treeshaking/ssr/serverRender/{styledComponent.js → renderToString/styledComponent.js} +0 -0
  99. package/dist/js/treeshaking/ssr/serverRender/{template.js → renderToString/template.js} +0 -0
  100. package/dist/js/treeshaking/ssr/serverRender/{type.js → renderToString/type.js} +0 -1
  101. package/dist/js/treeshaking/ssr/serverRender/types.js +2 -0
  102. package/dist/js/treeshaking/ssr/serverRender/{measure.js → utils.js} +16 -0
  103. package/dist/js/treeshaking/ssr/utils.js +15 -3
  104. package/dist/types/common.d.ts +0 -2
  105. package/dist/types/core/index.d.ts +1 -1
  106. package/dist/types/core/plugin.d.ts +1 -1
  107. package/dist/types/exports/server.d.ts +21 -1
  108. package/dist/types/index.d.ts +1 -0
  109. package/dist/types/router/runtime/DefaultNotFound.d.ts +1 -0
  110. package/dist/types/router/runtime/index.d.ts +3 -3
  111. package/dist/types/router/runtime/plugin.d.ts +2 -45
  112. package/dist/types/router/runtime/plugin.node.d.ts +8 -0
  113. package/dist/types/router/runtime/types.d.ts +38 -0
  114. package/dist/types/router/runtime/utils.d.ts +5 -2
  115. package/dist/types/router/runtime/withRouter.d.ts +8 -0
  116. package/dist/types/runtime-context.d.ts +2 -1
  117. package/dist/types/ssr/index.d.ts +2 -2
  118. package/dist/types/ssr/index.node.d.ts +1 -1
  119. package/dist/types/ssr/react/nossr/index.d.ts +3 -1
  120. package/dist/types/ssr/serverRender/index.d.ts +2 -3
  121. package/dist/types/ssr/serverRender/renderToStream/buildTemplate.after.d.ts +6 -0
  122. package/dist/types/ssr/serverRender/renderToStream/buildTemplate.share.d.ts +3 -0
  123. package/dist/types/ssr/serverRender/renderToStream/bulidTemplate.before.d.ts +1 -0
  124. package/dist/types/ssr/serverRender/renderToStream/index.d.ts +6 -0
  125. package/dist/types/ssr/serverRender/renderToStream/loadable.d.ts +16 -0
  126. package/dist/types/ssr/serverRender/renderToStream/renderToPipe.d.ts +8 -0
  127. package/dist/types/ssr/serverRender/renderToStream/styledComponent.d.ts +12 -0
  128. package/dist/types/ssr/serverRender/renderToStream/template.d.ts +3 -0
  129. package/dist/types/ssr/serverRender/renderToStream/type.d.ts +4 -0
  130. package/dist/types/ssr/serverRender/{entry.d.ts → renderToString/entry.d.ts} +2 -2
  131. package/dist/types/ssr/serverRender/renderToString/index.d.ts +6 -0
  132. package/dist/types/ssr/serverRender/{loadable.d.ts → renderToString/loadable.d.ts} +0 -0
  133. package/dist/types/ssr/serverRender/{reduce.d.ts → renderToString/reduce.d.ts} +0 -0
  134. package/dist/types/ssr/serverRender/{styledComponent.d.ts → renderToString/styledComponent.d.ts} +0 -0
  135. package/dist/types/ssr/serverRender/{template.d.ts → renderToString/template.d.ts} +0 -0
  136. package/dist/types/ssr/serverRender/{type.d.ts → renderToString/type.d.ts} +1 -8
  137. package/dist/types/ssr/serverRender/types.d.ts +18 -0
  138. package/dist/types/ssr/serverRender/utils.d.ts +3 -0
  139. package/dist/types/ssr/utils.d.ts +4 -2
  140. package/dist/types/state/runtime/plugin.d.ts +1 -1
  141. package/package.json +57 -73
  142. package/types/index.d.ts +13 -0
  143. package/types/router.d.ts +14 -0
  144. package/dist/js/modern/ssr/serverRender/measure.js +0 -11
  145. package/dist/js/node/ssr/serverRender/measure.js +0 -20
  146. package/dist/types/ssr/serverRender/measure.d.ts +0 -1
  147. package/lib/types.d.ts +0 -10
  148. 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 "../utils";
3
+ import { isCrossOrigin } from "../../utils";
4
+ import { getLoadableScripts } from "../utils";
4
5
 
5
6
  var extname = function extname(uri) {
6
- return uri.match(/\.[^.]+$/) || '';
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 scripts.split('</script>') // 前两个 script为 loadable 必须的 script
21
- .slice(0, 2).map(function (i) {
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,
@@ -1,4 +1,3 @@
1
- // import { IncomingHttpHeaders } from 'http';
2
1
  export var RenderLevel;
3
2
 
4
3
  (function (RenderLevel) {
@@ -0,0 +1,2 @@
1
+ import { RenderLevel } from "./renderToString/type";
2
+ export { RenderLevel };
@@ -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.info('setHeader can only be used in the server side');
55
+ console.warn('response.setHeader() can only be used in the server side');
53
56
  },
54
57
  status: function status() {
55
- console.info('status can only be used in the server side');
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(url, base) {
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)) {
@@ -1,8 +1,6 @@
1
1
  import type { StateConfig } from './state';
2
- import type { RouterConfig } from './router';
3
2
  export declare const isBrowser: () => boolean;
4
3
  export interface AppConfig {
5
- router?: RouterConfig | boolean;
6
4
  state?: StateConfig | boolean;
7
5
  [key: string]: any;
8
6
  }
@@ -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>>> | undefined) => import("@modern-js/plugin").Plugin<{
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
- export declare const hook: (attacher: any) => any;
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;
@@ -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 +1,2 @@
1
+ /// <reference types="react" />
1
2
  export declare const DefaultNotFound: () => JSX.Element;
@@ -1,6 +1,6 @@
1
1
  import { routerPlugin } from './plugin';
2
- import type { SingleRouteConfig, HistoryConfig, RouterConfig } from './plugin';
3
- export type { SingleRouteConfig, HistoryConfig, RouterConfig };
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 'history';
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
- declare global {
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
- historyOptions
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 { RouterConfig } from './plugin';
2
- export declare function renderRoutes(routesConfig: RouterConfig['routesConfig'], extraProps?: any): JSX.Element;
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/type';
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, SSRPluginConfig, SSRServerContext } from './serverRender/type';
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: (_: SSRPluginConfig) => Plugin;
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 type { SSRPluginConfig } from './serverRender/type';
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 { RuntimeContext } from '../../core';
2
- import { ModernSSRReactComponent, SSRPluginConfig } from './type';
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,3 @@
1
+ export declare const HEAD_REG_EXP: RegExp;
2
+ export declare type BuildTemplateCb = (headTemplate: string) => string;
3
+ export declare function buildTemplate(template: string, callbacks: BuildTemplateCb[]): string;
@@ -0,0 +1 @@
1
+ export declare function buildShellBeforeTemplate(beforeAppTemplate: string): string;
@@ -0,0 +1,6 @@
1
+ /// <reference types="node" />
2
+ import { ServerRenderOptions } from '../types';
3
+ export declare const render: ({
4
+ App,
5
+ context
6
+ }: ServerRenderOptions) => Promise<import("./renderToPipe").Pipe<import("stream").Writable>>;
@@ -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
+ };
@@ -0,0 +1,3 @@
1
+ import { RuntimeContext } from '../types';
2
+ import { InjectTemplate } from './type';
3
+ export declare function createTemplates(context: RuntimeContext): () => InjectTemplate;
@@ -0,0 +1,4 @@
1
+ export declare type InjectTemplate = {
2
+ shellBefore?: string;
3
+ shellAfter?: string;
4
+ };
@@ -1,5 +1,5 @@
1
- import { RuntimeContext } from '../../core';
2
- import { ModernSSRReactComponent, SSRServerContext, RenderResult, SSRPluginConfig } from './type';
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;
@@ -0,0 +1,6 @@
1
+ import { ServerRenderOptions } from '../types';
2
+ export declare const render: ({
3
+ App,
4
+ context,
5
+ config
6
+ }: ServerRenderOptions) => Promise<string>;
@@ -1,6 +1,6 @@
1
1
  /// <reference types="react" />
2
2
  import type { BaseSSRServerContext } from '@modern-js/types';
3
- import type { RuntimeContext } from '../../core';
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
+ };
@@ -0,0 +1,3 @@
1
+ import { ChunkExtractor } from '@loadable/server';
2
+ export declare function getLoadableScripts(extractor: ChunkExtractor): string;
3
+ export declare const time: () => () => number;
@@ -1,9 +1,11 @@
1
1
  import { BaseSSRServerContext } from '@modern-js/types';
2
- import { SSRServerContext } from './serverRender/type';
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<Partial<StatePluginType>, boolean>;
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';