@modern-js/plugin-data-loader 2.20.0 → 2.21.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 +22 -0
- package/dist/cjs/cli/data.js +3 -3
- package/dist/cjs/runtime/index.js +7 -6
- package/dist/esm/cli/data.js +1 -1
- package/dist/esm/runtime/index.js +2 -1
- package/dist/esm-node/cli/data.js +1 -1
- package/dist/esm-node/runtime/index.js +2 -1
- package/dist/types/cli/createRequest.d.ts +1 -1
- package/dist/types/cli/data.d.ts +1 -1
- package/dist/types/runtime/response.d.ts +1 -1
- package/dist/types/server/index.d.ts +0 -2
- package/package.json +11 -11
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,27 @@
|
|
|
1
1
|
# @modern-js/plugin-data-loader
|
|
2
2
|
|
|
3
|
+
## 2.21.0
|
|
4
|
+
|
|
5
|
+
### Patch Changes
|
|
6
|
+
|
|
7
|
+
- e81eeaf: refactor: guard react-router version consistency
|
|
8
|
+
refactor: 保证 react-router 相关包的版本一致性
|
|
9
|
+
- 26dcf3a: chore: bump typescript to v5 in devDependencies
|
|
10
|
+
|
|
11
|
+
chore: 升级 devDependencies 中的 typescript 版本到 v5
|
|
12
|
+
|
|
13
|
+
- ad78387: chore(deps): bump babel-related dependencies to latest version
|
|
14
|
+
|
|
15
|
+
chore(deps): 升级 babel 相关依赖到最新版本
|
|
16
|
+
|
|
17
|
+
- Updated dependencies [e81eeaf]
|
|
18
|
+
- Updated dependencies [26dcf3a]
|
|
19
|
+
- Updated dependencies [056627f]
|
|
20
|
+
- Updated dependencies [0fc15ca]
|
|
21
|
+
- Updated dependencies [43b4e83]
|
|
22
|
+
- Updated dependencies [ad78387]
|
|
23
|
+
- @modern-js/utils@2.21.0
|
|
24
|
+
|
|
3
25
|
## 2.20.0
|
|
4
26
|
|
|
5
27
|
### Patch Changes
|
package/dist/cjs/cli/data.js
CHANGED
|
@@ -6,7 +6,7 @@ Object.defineProperty(exports, "parseDeferredReadableStream", {
|
|
|
6
6
|
enumerable: true,
|
|
7
7
|
get: () => parseDeferredReadableStream
|
|
8
8
|
});
|
|
9
|
-
const
|
|
9
|
+
const _remixrouter = require("@modern-js/utils/runtime/remix-router");
|
|
10
10
|
const DEFERRED_VALUE_PLACEHOLDER_PREFIX = "__deferred_promise:";
|
|
11
11
|
async function parseDeferredReadableStream(stream) {
|
|
12
12
|
if (!stream) {
|
|
@@ -65,7 +65,7 @@ async function parseDeferredReadableStream(stream) {
|
|
|
65
65
|
}
|
|
66
66
|
}
|
|
67
67
|
for (const [key, resolver] of Object.entries(deferredResolvers)) {
|
|
68
|
-
resolver.reject(new
|
|
68
|
+
resolver.reject(new _remixrouter.AbortedDeferredError(`Deferred ${key} will never resolved`));
|
|
69
69
|
}
|
|
70
70
|
} catch (error) {
|
|
71
71
|
for (const resolver of Object.values(deferredResolvers)) {
|
|
@@ -73,7 +73,7 @@ async function parseDeferredReadableStream(stream) {
|
|
|
73
73
|
}
|
|
74
74
|
}
|
|
75
75
|
})();
|
|
76
|
-
return new
|
|
76
|
+
return new _remixrouter.UNSAFE_DeferredData({
|
|
77
77
|
...criticalData,
|
|
78
78
|
...deferredData
|
|
79
79
|
});
|
|
@@ -15,7 +15,8 @@ _export(exports, {
|
|
|
15
15
|
handleRequest: () => handleRequest
|
|
16
16
|
});
|
|
17
17
|
const _node = require("@remix-run/node");
|
|
18
|
-
const
|
|
18
|
+
const _remixrouter = require("@modern-js/utils/runtime/remix-router");
|
|
19
|
+
const _nestedroutes = require("@modern-js/utils/runtime/nested-routes");
|
|
19
20
|
const _lodash = require("@modern-js/utils/lodash");
|
|
20
21
|
const _constants = require("../common/constants");
|
|
21
22
|
const _utils = require("../common/utils");
|
|
@@ -96,8 +97,8 @@ const handleRequest = async ({ context, serverRoutes, routes: routesConfig }) =>
|
|
|
96
97
|
throw new Error("CSR data loader request only support http GET method");
|
|
97
98
|
}
|
|
98
99
|
const basename = entry.urlPath;
|
|
99
|
-
const routes = (0,
|
|
100
|
-
const { queryRoute } = (0,
|
|
100
|
+
const routes = (0, _nestedroutes.transformNestedRoutes)(routesConfig);
|
|
101
|
+
const { queryRoute } = (0, _remixrouter.createStaticHandler)(routes, {
|
|
101
102
|
basename
|
|
102
103
|
});
|
|
103
104
|
const { res, logger } = context;
|
|
@@ -109,8 +110,8 @@ const handleRequest = async ({ context, serverRoutes, routes: routesConfig }) =>
|
|
|
109
110
|
});
|
|
110
111
|
if (isResponse(response) && isRedirectResponse(response.status)) {
|
|
111
112
|
response = convertModernRedirectResponse(response.headers, basename);
|
|
112
|
-
} else if ((0, _lodash.isPlainObject)(response) &&
|
|
113
|
-
const deferredData = response[
|
|
113
|
+
} else if ((0, _lodash.isPlainObject)(response) && _remixrouter.UNSAFE_DEFERRED_SYMBOL in response) {
|
|
114
|
+
const deferredData = response[_remixrouter.UNSAFE_DEFERRED_SYMBOL];
|
|
114
115
|
const body = (0, _response.createDeferredReadableStream)(deferredData, request.signal);
|
|
115
116
|
const init = deferredData.init || {};
|
|
116
117
|
if (init.status && isRedirectResponse(init.status)) {
|
|
@@ -132,7 +133,7 @@ const handleRequest = async ({ context, serverRoutes, routes: routesConfig }) =>
|
|
|
132
133
|
});
|
|
133
134
|
}
|
|
134
135
|
} catch (error) {
|
|
135
|
-
const message = error instanceof
|
|
136
|
+
const message = error instanceof _remixrouter.ErrorResponse ? error.data : String(error);
|
|
136
137
|
logger === null || logger === void 0 ? void 0 : logger.error(message);
|
|
137
138
|
response = new _node.Response(message, {
|
|
138
139
|
status: 500,
|
package/dist/esm/cli/data.js
CHANGED
|
@@ -7,7 +7,7 @@ import { _ as _to_array } from "@swc/helpers/_/_to_array";
|
|
|
7
7
|
import { _ as _to_consumable_array } from "@swc/helpers/_/_to_consumable_array";
|
|
8
8
|
import { _ as _wrap_async_generator } from "@swc/helpers/_/_wrap_async_generator";
|
|
9
9
|
import { _ as _ts_generator } from "@swc/helpers/_/_ts_generator";
|
|
10
|
-
import { UNSAFE_DeferredData as DeferredData, AbortedDeferredError } from "@modern-js/utils/runtime/router";
|
|
10
|
+
import { UNSAFE_DeferredData as DeferredData, AbortedDeferredError } from "@modern-js/utils/runtime/remix-router";
|
|
11
11
|
var DEFERRED_VALUE_PLACEHOLDER_PREFIX = "__deferred_promise:";
|
|
12
12
|
export function parseDeferredReadableStream(stream) {
|
|
13
13
|
return _parseDeferredReadableStream.apply(this, arguments);
|
|
@@ -3,7 +3,8 @@ import { _ as _instanceof } from "@swc/helpers/_/_instanceof";
|
|
|
3
3
|
import { _ as _sliced_to_array } from "@swc/helpers/_/_sliced_to_array";
|
|
4
4
|
import { _ as _ts_generator } from "@swc/helpers/_/_ts_generator";
|
|
5
5
|
import { installGlobals, writeReadableStreamToWritable, Response as NodeResponse } from "@remix-run/node";
|
|
6
|
-
import { createStaticHandler, ErrorResponse, UNSAFE_DEFERRED_SYMBOL as DEFERRED_SYMBOL
|
|
6
|
+
import { createStaticHandler, ErrorResponse, UNSAFE_DEFERRED_SYMBOL as DEFERRED_SYMBOL } from "@modern-js/utils/runtime/remix-router";
|
|
7
|
+
import { transformNestedRoutes } from "@modern-js/utils/runtime/nested-routes";
|
|
7
8
|
import { isPlainObject } from "@modern-js/utils/lodash";
|
|
8
9
|
import { CONTENT_TYPE_DEFERRED, LOADER_ID_PARAM } from "../common/constants";
|
|
9
10
|
import { matchEntry } from "../common/utils";
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { UNSAFE_DeferredData as DeferredData, AbortedDeferredError } from "@modern-js/utils/runtime/router";
|
|
1
|
+
import { UNSAFE_DeferredData as DeferredData, AbortedDeferredError } from "@modern-js/utils/runtime/remix-router";
|
|
2
2
|
const DEFERRED_VALUE_PLACEHOLDER_PREFIX = "__deferred_promise:";
|
|
3
3
|
export async function parseDeferredReadableStream(stream) {
|
|
4
4
|
if (!stream) {
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { installGlobals, writeReadableStreamToWritable, Response as NodeResponse } from "@remix-run/node";
|
|
2
|
-
import { createStaticHandler, ErrorResponse, UNSAFE_DEFERRED_SYMBOL as DEFERRED_SYMBOL
|
|
2
|
+
import { createStaticHandler, ErrorResponse, UNSAFE_DEFERRED_SYMBOL as DEFERRED_SYMBOL } from "@modern-js/utils/runtime/remix-router";
|
|
3
|
+
import { transformNestedRoutes } from "@modern-js/utils/runtime/nested-routes";
|
|
3
4
|
import { isPlainObject } from "@modern-js/utils/lodash";
|
|
4
5
|
import { CONTENT_TYPE_DEFERRED, LOADER_ID_PARAM } from "../common/constants";
|
|
5
6
|
import { matchEntry } from "../common/utils";
|
package/dist/types/cli/data.d.ts
CHANGED
|
@@ -7,5 +7,5 @@
|
|
|
7
7
|
* Copyright 2021 Remix Software Inc.
|
|
8
8
|
* https://github.com/remix-run/remix/blob/2b5e1a72fc628d0408e27cf4d72e537762f1dc5b/LICENSE.md
|
|
9
9
|
*/
|
|
10
|
-
import { UNSAFE_DeferredData as DeferredData } from '@modern-js/utils/runtime/router';
|
|
10
|
+
import { UNSAFE_DeferredData as DeferredData } from '@modern-js/utils/runtime/remix-router';
|
|
11
11
|
export declare function parseDeferredReadableStream(stream: ReadableStream<Uint8Array>): Promise<DeferredData>;
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { type UNSAFE_DeferredData as DeferredData } from '@modern-js/utils/runtime/router';
|
|
1
|
+
import { type UNSAFE_DeferredData as DeferredData } from '@modern-js/utils/runtime/remix-router';
|
|
2
2
|
export declare function createDeferredReadableStream(deferredData: DeferredData, signal: AbortSignal): any;
|
package/package.json
CHANGED
|
@@ -15,7 +15,7 @@
|
|
|
15
15
|
"modern",
|
|
16
16
|
"modern.js"
|
|
17
17
|
],
|
|
18
|
-
"version": "2.
|
|
18
|
+
"version": "2.21.0",
|
|
19
19
|
"engines": {
|
|
20
20
|
"node": ">=14.17.6"
|
|
21
21
|
},
|
|
@@ -54,15 +54,15 @@
|
|
|
54
54
|
}
|
|
55
55
|
},
|
|
56
56
|
"dependencies": {
|
|
57
|
-
"@babel/core": "^7.
|
|
57
|
+
"@babel/core": "^7.21.8",
|
|
58
58
|
"@remix-run/node": "^1.12.0",
|
|
59
59
|
"path-to-regexp": "^6.2.0",
|
|
60
60
|
"react-router-dom": "^6.8.1",
|
|
61
61
|
"@swc/helpers": "0.5.1",
|
|
62
|
-
"@modern-js/utils": "2.
|
|
62
|
+
"@modern-js/utils": "2.21.0"
|
|
63
63
|
},
|
|
64
64
|
"devDependencies": {
|
|
65
|
-
"@types/babel__core": "^7.
|
|
65
|
+
"@types/babel__core": "^7.20.0",
|
|
66
66
|
"@types/jest": "^29",
|
|
67
67
|
"@types/node": "^14",
|
|
68
68
|
"@types/supertest": "^2.0.11",
|
|
@@ -70,17 +70,17 @@
|
|
|
70
70
|
"jest": "^29",
|
|
71
71
|
"memfs": "^3.3.0",
|
|
72
72
|
"supertest": "^6.1.6",
|
|
73
|
-
"ts-jest": "^29.0
|
|
74
|
-
"typescript": "^
|
|
73
|
+
"ts-jest": "^29.1.0",
|
|
74
|
+
"typescript": "^5",
|
|
75
75
|
"webpack": "^5.82.1",
|
|
76
76
|
"webpack-chain": "^6.5.1",
|
|
77
77
|
"react": ">=17.0.0",
|
|
78
78
|
"react-router-dom": "^6.8.1",
|
|
79
|
-
"@modern-js/core": "2.
|
|
80
|
-
"@modern-js/server-core": "2.
|
|
81
|
-
"@modern-js/types": "2.
|
|
82
|
-
"@scripts/
|
|
83
|
-
"@scripts/
|
|
79
|
+
"@modern-js/core": "2.21.0",
|
|
80
|
+
"@modern-js/server-core": "2.21.0",
|
|
81
|
+
"@modern-js/types": "2.21.0",
|
|
82
|
+
"@scripts/jest-config": "2.21.0",
|
|
83
|
+
"@scripts/build": "2.21.0"
|
|
84
84
|
},
|
|
85
85
|
"peerDependencies": {
|
|
86
86
|
"react": ">=17.0.0",
|