@modern-js/plugin-data-loader 2.5.0-alpha.0 → 2.5.1-alpha.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 (39) hide show
  1. package/dist/cjs/cli/create-request.js +3 -14
  2. package/dist/cjs/cli/generate-client.js +4 -0
  3. package/dist/cjs/cli/loader.js +3 -0
  4. package/dist/cjs/server/index.js +200 -19
  5. package/dist/esm/cli/create-request.js +2 -41
  6. package/dist/esm/cli/loader.js +6 -0
  7. package/dist/esm/server/index.js +447 -29
  8. package/dist/esm-node/cli/create-request.js +3 -14
  9. package/dist/esm-node/cli/loader.js +3 -0
  10. package/dist/esm-node/server/index.js +196 -21
  11. package/dist/js/modern/cli/create-request.js +66 -0
  12. package/dist/js/modern/cli/generate-client.js +42 -0
  13. package/dist/js/modern/cli/loader.js +40 -0
  14. package/dist/js/modern/common/constants.js +6 -0
  15. package/dist/js/modern/server/index.js +237 -0
  16. package/dist/js/node/cli/create-request.js +90 -0
  17. package/dist/js/node/cli/generate-client.js +71 -0
  18. package/dist/js/node/cli/loader.js +61 -0
  19. package/dist/js/node/common/constants.js +30 -0
  20. package/dist/js/node/server/index.js +261 -0
  21. package/dist/js/treeshaking/cli/create-request.js +186 -0
  22. package/dist/js/treeshaking/cli/generate-client.js +45 -0
  23. package/dist/js/treeshaking/cli/loader.js +154 -0
  24. package/dist/js/treeshaking/common/constants.js +3 -0
  25. package/dist/{esm/runtime → js/treeshaking/server}/index.js +222 -66
  26. package/dist/types/cli/create-request.d.ts +1 -2
  27. package/dist/types/server/index.d.ts +15 -0
  28. package/package.json +10 -21
  29. package/dist/cjs/cli/data.js +0 -162
  30. package/dist/cjs/runtime/index.js +0 -159
  31. package/dist/cjs/runtime/response.js +0 -102
  32. package/dist/esm/cli/data.js +0 -820
  33. package/dist/esm/runtime/response.js +0 -284
  34. package/dist/esm-node/cli/data.js +0 -142
  35. package/dist/esm-node/runtime/index.js +0 -143
  36. package/dist/esm-node/runtime/response.js +0 -79
  37. package/dist/types/cli/data.d.ts +0 -6
  38. package/dist/types/runtime/index.d.ts +0 -15
  39. package/dist/types/runtime/response.d.ts +0 -2
@@ -1,284 +0,0 @@
1
- function _arrayLikeToArray(arr, len) {
2
- if (len == null || len > arr.length) len = arr.length;
3
- for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];
4
- return arr2;
5
- }
6
- function _arrayWithHoles(arr) {
7
- if (Array.isArray(arr)) return arr;
8
- }
9
- function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
10
- try {
11
- var info = gen[key](arg);
12
- var value = info.value;
13
- } catch (error) {
14
- reject(error);
15
- return;
16
- }
17
- if (info.done) {
18
- resolve(value);
19
- } else {
20
- Promise.resolve(value).then(_next, _throw);
21
- }
22
- }
23
- function _asyncToGenerator(fn) {
24
- return function() {
25
- var self = this, args = arguments;
26
- return new Promise(function(resolve, reject) {
27
- var gen = fn.apply(self, args);
28
- function _next(value) {
29
- asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
30
- }
31
- function _throw(err) {
32
- asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
33
- }
34
- _next(undefined);
35
- });
36
- };
37
- }
38
- function _defineProperty(obj, key, value) {
39
- if (key in obj) {
40
- Object.defineProperty(obj, key, {
41
- value: value,
42
- enumerable: true,
43
- configurable: true,
44
- writable: true
45
- });
46
- } else {
47
- obj[key] = value;
48
- }
49
- return obj;
50
- }
51
- function _iterableToArrayLimit(arr, i) {
52
- var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];
53
- if (_i == null) return;
54
- var _arr = [];
55
- var _n = true;
56
- var _d = false;
57
- var _s, _e;
58
- try {
59
- for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){
60
- _arr.push(_s.value);
61
- if (i && _arr.length === i) break;
62
- }
63
- } catch (err) {
64
- _d = true;
65
- _e = err;
66
- } finally{
67
- try {
68
- if (!_n && _i["return"] != null) _i["return"]();
69
- } finally{
70
- if (_d) throw _e;
71
- }
72
- }
73
- return _arr;
74
- }
75
- function _nonIterableRest() {
76
- throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
77
- }
78
- function _slicedToArray(arr, i) {
79
- return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest();
80
- }
81
- function _unsupportedIterableToArray(o, minLen) {
82
- if (!o) return;
83
- if (typeof o === "string") return _arrayLikeToArray(o, minLen);
84
- var n = Object.prototype.toString.call(o).slice(8, -1);
85
- if (n === "Object" && o.constructor) n = o.constructor.name;
86
- if (n === "Map" || n === "Set") return Array.from(n);
87
- if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);
88
- }
89
- var __generator = this && this.__generator || function(thisArg, body) {
90
- var f, y, t, g, _ = {
91
- label: 0,
92
- sent: function() {
93
- if (t[0] & 1) throw t[1];
94
- return t[1];
95
- },
96
- trys: [],
97
- ops: []
98
- };
99
- return g = {
100
- next: verb(0),
101
- "throw": verb(1),
102
- "return": verb(2)
103
- }, typeof Symbol === "function" && (g[Symbol.iterator] = function() {
104
- return this;
105
- }), g;
106
- function verb(n) {
107
- return function(v) {
108
- return step([
109
- n,
110
- v
111
- ]);
112
- };
113
- }
114
- function step(op) {
115
- if (f) throw new TypeError("Generator is already executing.");
116
- while(_)try {
117
- if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
118
- if (y = 0, t) op = [
119
- op[0] & 2,
120
- t.value
121
- ];
122
- switch(op[0]){
123
- case 0:
124
- case 1:
125
- t = op;
126
- break;
127
- case 4:
128
- _.label++;
129
- return {
130
- value: op[1],
131
- done: false
132
- };
133
- case 5:
134
- _.label++;
135
- y = op[1];
136
- op = [
137
- 0
138
- ];
139
- continue;
140
- case 7:
141
- op = _.ops.pop();
142
- _.trys.pop();
143
- continue;
144
- default:
145
- if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {
146
- _ = 0;
147
- continue;
148
- }
149
- if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {
150
- _.label = op[1];
151
- break;
152
- }
153
- if (op[0] === 6 && _.label < t[1]) {
154
- _.label = t[1];
155
- t = op;
156
- break;
157
- }
158
- if (t && _.label < t[2]) {
159
- _.label = t[2];
160
- _.ops.push(op);
161
- break;
162
- }
163
- if (t[2]) _.ops.pop();
164
- _.trys.pop();
165
- continue;
166
- }
167
- op = body.call(thisArg, _);
168
- } catch (e) {
169
- op = [
170
- 6,
171
- e
172
- ];
173
- y = 0;
174
- } finally{
175
- f = t = 0;
176
- }
177
- if (op[0] & 5) throw op[1];
178
- return {
179
- value: op[0] ? op[1] : void 0,
180
- done: true
181
- };
182
- }
183
- };
184
- import { TextEncoder } from "util";
185
- import { serializeJson } from "@modern-js/utils";
186
- function isTrackedPromise(value) {
187
- return value != null && typeof value.then === "function" && value._tracked === true;
188
- }
189
- var DEFERRED_VALUE_PLACEHOLDER_PREFIX = "__deferred_promise:";
190
- function createDeferredReadableStream(deferredData, signal) {
191
- var encoder = new TextEncoder();
192
- var stream = new ReadableStream({
193
- start: function start(controller) {
194
- return _asyncToGenerator(function() {
195
- var criticalData, preresolvedKeys, _iteratorNormalCompletion, _didIteratorError, _iteratorError, _iterator, _step, _step_value, key, value, _iteratorNormalCompletion1, _didIteratorError1, _iteratorError1, _iterator1, _step1, preresolvedKey, unsubscribe;
196
- return __generator(this, function(_state) {
197
- switch(_state.label){
198
- case 0:
199
- criticalData = {};
200
- preresolvedKeys = [];
201
- _iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = undefined;
202
- try {
203
- for(_iterator = Object.entries(deferredData.data)[Symbol.iterator](); !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true){
204
- _step_value = _slicedToArray(_step.value, 2), key = _step_value[0], value = _step_value[1];
205
- if (isTrackedPromise(value)) {
206
- criticalData[key] = "".concat(DEFERRED_VALUE_PLACEHOLDER_PREFIX).concat(key);
207
- if (typeof value._data !== "undefined" || typeof value._error !== "undefined") {
208
- preresolvedKeys.push(key);
209
- }
210
- } else {
211
- criticalData[key] = value;
212
- }
213
- }
214
- } catch (err) {
215
- _didIteratorError = true;
216
- _iteratorError = err;
217
- } finally{
218
- try {
219
- if (!_iteratorNormalCompletion && _iterator.return != null) {
220
- _iterator.return();
221
- }
222
- } finally{
223
- if (_didIteratorError) {
224
- throw _iteratorError;
225
- }
226
- }
227
- }
228
- controller.enqueue(encoder.encode("".concat(JSON.stringify(criticalData), "\n\n")));
229
- _iteratorNormalCompletion1 = true, _didIteratorError1 = false, _iteratorError1 = undefined;
230
- try {
231
- for(_iterator1 = preresolvedKeys[Symbol.iterator](); !(_iteratorNormalCompletion1 = (_step1 = _iterator1.next()).done); _iteratorNormalCompletion1 = true){
232
- preresolvedKey = _step1.value;
233
- enqueueTrackedPromise(controller, encoder, preresolvedKey, deferredData.data[preresolvedKey]);
234
- }
235
- } catch (err) {
236
- _didIteratorError1 = true;
237
- _iteratorError1 = err;
238
- } finally{
239
- try {
240
- if (!_iteratorNormalCompletion1 && _iterator1.return != null) {
241
- _iterator1.return();
242
- }
243
- } finally{
244
- if (_didIteratorError1) {
245
- throw _iteratorError1;
246
- }
247
- }
248
- }
249
- unsubscribe = deferredData.subscribe(function(aborted, settledKey) {
250
- if (settledKey) {
251
- enqueueTrackedPromise(controller, encoder, settledKey, deferredData.data[settledKey]);
252
- }
253
- });
254
- return [
255
- 4,
256
- deferredData.resolveData(signal)
257
- ];
258
- case 1:
259
- _state.sent();
260
- unsubscribe();
261
- controller.close();
262
- return [
263
- 2
264
- ];
265
- }
266
- });
267
- })();
268
- }
269
- });
270
- return stream;
271
- }
272
- function enqueueTrackedPromise(controller, encoder, settledKey, promise) {
273
- if ("_error" in promise) {
274
- var _error = promise._error;
275
- controller.enqueue(encoder.encode("error:".concat(serializeJson(_defineProperty({}, settledKey, {
276
- message: _error.message,
277
- stack: _error.stack
278
- })), "\n\n")));
279
- } else {
280
- var _promise__data;
281
- controller.enqueue(encoder.encode("data:".concat(JSON.stringify(_defineProperty({}, settledKey, (_promise__data = promise._data) !== null && _promise__data !== void 0 ? _promise__data : null)), "\n\n")));
282
- }
283
- }
284
- export { createDeferredReadableStream };
@@ -1,142 +0,0 @@
1
- import {
2
- UNSAFE_DeferredData as DeferredData,
3
- AbortedDeferredError
4
- } from "@modern-js/utils/remix-router";
5
- const DEFERRED_VALUE_PLACEHOLDER_PREFIX = "__deferred_promise:";
6
- async function parseDeferredReadableStream(stream) {
7
- if (!stream) {
8
- throw new Error("parseDeferredReadableStream requires stream argument");
9
- }
10
- let deferredData;
11
- const deferredResolvers = {};
12
- try {
13
- const sectionReader = readStreamSections(stream);
14
- const initialSectionResult = await sectionReader.next();
15
- const initialSection = initialSectionResult.value;
16
- if (!initialSection) {
17
- throw new Error("no critical data");
18
- }
19
- const criticalData = JSON.parse(initialSection);
20
- if (typeof criticalData === "object" && criticalData !== null) {
21
- for (const [eventKey, value] of Object.entries(criticalData)) {
22
- if (typeof value !== "string" || !value.startsWith(DEFERRED_VALUE_PLACEHOLDER_PREFIX)) {
23
- continue;
24
- }
25
- deferredData = deferredData || {};
26
- deferredData[eventKey] = new Promise((resolve, reject) => {
27
- deferredResolvers[eventKey] = {
28
- resolve: (value2) => {
29
- resolve(value2);
30
- delete deferredResolvers[eventKey];
31
- },
32
- reject: (error) => {
33
- reject(error);
34
- delete deferredResolvers[eventKey];
35
- }
36
- };
37
- });
38
- }
39
- }
40
- (async () => {
41
- try {
42
- for await (const section of sectionReader) {
43
- const [event, ...sectionDataStrings] = section.split(":");
44
- const sectionDataString = sectionDataStrings.join(":");
45
- const data = JSON.parse(sectionDataString);
46
- if (event === "data") {
47
- for (const [key, value] of Object.entries(data)) {
48
- if (deferredResolvers[key]) {
49
- deferredResolvers[key].resolve(value);
50
- }
51
- }
52
- } else if (event === "error") {
53
- for (const [key, value] of Object.entries(data)) {
54
- const err = new Error(value.message);
55
- err.stack = value.stack;
56
- if (deferredResolvers[key]) {
57
- deferredResolvers[key].reject(err);
58
- }
59
- }
60
- }
61
- }
62
- for (const [key, resolver] of Object.entries(deferredResolvers)) {
63
- resolver.reject(
64
- new AbortedDeferredError(`Deferred ${key} will never resolved`)
65
- );
66
- }
67
- } catch (error) {
68
- for (const resolver of Object.values(deferredResolvers)) {
69
- resolver.reject(error);
70
- }
71
- }
72
- })();
73
- return new DeferredData({ ...criticalData, ...deferredData });
74
- } catch (error) {
75
- for (const resolver of Object.values(deferredResolvers)) {
76
- resolver.reject(error);
77
- }
78
- throw error;
79
- }
80
- }
81
- async function* readStreamSections(stream) {
82
- const reader = stream.getReader();
83
- let buffer = [];
84
- let sections = [];
85
- let closed = false;
86
- const encoder = new TextEncoder();
87
- const decoder = new TextDecoder();
88
- const readStreamSection = async () => {
89
- if (sections.length > 0) {
90
- return sections.shift();
91
- }
92
- while (!closed && sections.length === 0) {
93
- const chunk = await reader.read();
94
- if (chunk.done) {
95
- closed = true;
96
- break;
97
- }
98
- buffer.push(chunk.value);
99
- try {
100
- const bufferedString = decoder.decode(mergeArrays(...buffer));
101
- const splitSections = bufferedString.split("\n\n");
102
- if (splitSections.length >= 2) {
103
- sections.push(...splitSections.slice(0, -1));
104
- buffer = [encoder.encode(splitSections.slice(-1).join("\n\n"))];
105
- }
106
- if (sections.length > 0) {
107
- break;
108
- }
109
- } catch {
110
- continue;
111
- }
112
- }
113
- if (sections.length > 0) {
114
- return sections.shift();
115
- }
116
- if (buffer.length > 0) {
117
- const bufferedString = decoder.decode(mergeArrays(...buffer));
118
- sections = bufferedString.split("\n\n").filter((s) => s);
119
- buffer = [];
120
- }
121
- return sections.shift();
122
- };
123
- let section = await readStreamSection();
124
- while (section) {
125
- yield section;
126
- section = await readStreamSection();
127
- }
128
- }
129
- function mergeArrays(...arrays) {
130
- const out = new Uint8Array(
131
- arrays.reduce((total, arr) => total + arr.length, 0)
132
- );
133
- let offset = 0;
134
- for (const arr of arrays) {
135
- out.set(arr, offset);
136
- offset += arr.length;
137
- }
138
- return out;
139
- }
140
- export {
141
- parseDeferredReadableStream
142
- };
@@ -1,143 +0,0 @@
1
- import {
2
- installGlobals,
3
- writeReadableStreamToWritable,
4
- Response as NodeResponse
5
- } from "@remix-run/node";
6
- import {
7
- transformNestedRoutes
8
- } from "@modern-js/utils";
9
- import {
10
- createStaticHandler,
11
- ErrorResponse,
12
- UNSAFE_DEFERRED_SYMBOL as DEFERRED_SYMBOL
13
- } from "@modern-js/utils/remix-router";
14
- import { LOADER_ID_PARAM } from "../common/constants";
15
- import { createDeferredReadableStream } from "./response";
16
- installGlobals();
17
- const redirectStatusCodes = /* @__PURE__ */ new Set([301, 302, 303, 307, 308]);
18
- function isRedirectResponse(status) {
19
- return redirectStatusCodes.has(status);
20
- }
21
- function isResponse(value) {
22
- return value != null && typeof value.status === "number" && typeof value.statusText === "string" && typeof value.headers === "object" && typeof value.body !== "undefined";
23
- }
24
- function convertModernRedirectResponse(headers) {
25
- const newHeaders = new Headers(headers);
26
- newHeaders.set("X-Modernjs-Redirect", headers.get("Location"));
27
- newHeaders.delete("Location");
28
- return new NodeResponse(null, {
29
- status: 204,
30
- headers: newHeaders
31
- });
32
- }
33
- const createLoaderHeaders = (requestHeaders) => {
34
- const headers = new Headers();
35
- for (const [key, values] of Object.entries(requestHeaders)) {
36
- if (values) {
37
- if (Array.isArray(values)) {
38
- for (const value of values) {
39
- headers.append(key, value);
40
- }
41
- } else {
42
- headers.set(key, values);
43
- }
44
- }
45
- }
46
- return headers;
47
- };
48
- const createLoaderRequest = (context) => {
49
- const origin = `${context.protocol}://${context.host}`;
50
- const url = new URL(context.url, origin);
51
- const controller = new AbortController();
52
- const init = {
53
- method: context.method,
54
- headers: createLoaderHeaders(context.headers),
55
- signal: controller.signal
56
- };
57
- return new Request(url.href, init);
58
- };
59
- const sendLoaderResponse = async (res, nodeResponse) => {
60
- res.statusMessage = nodeResponse.statusText;
61
- res.statusCode = nodeResponse.status;
62
- for (const [key, value] of nodeResponse.headers.entries()) {
63
- res.setHeader(key, value);
64
- }
65
- if (nodeResponse.body) {
66
- await writeReadableStreamToWritable(nodeResponse.body, res);
67
- } else {
68
- res.end();
69
- }
70
- };
71
- const matchEntry = (pathname, entries) => {
72
- return entries.find((entry) => pathname.startsWith(entry.urlPath));
73
- };
74
- const handleRequest = async ({
75
- context,
76
- serverRoutes,
77
- routes
78
- }) => {
79
- const { method, query } = context;
80
- const routeId = query[LOADER_ID_PARAM];
81
- if (!routeId) {
82
- throw new Error(`Missing parameter: ${LOADER_ID_PARAM}`);
83
- }
84
- if (method.toLowerCase() !== "get") {
85
- throw new Error("Only support httpp GET method");
86
- }
87
- const entry = matchEntry(context.path, serverRoutes);
88
- if (!entry) {
89
- throw new Error("Route is not matched");
90
- }
91
- const dataRoutes = transformNestedRoutes(routes);
92
- const staticHandler = createStaticHandler(dataRoutes, {
93
- basename: entry.urlPath
94
- });
95
- const { res } = context;
96
- const request = createLoaderRequest(context);
97
- let response;
98
- try {
99
- response = await staticHandler.queryRoute(request, {
100
- routeId,
101
- requestContext: context
102
- });
103
- if (isResponse(response) && isRedirectResponse(response.status)) {
104
- response = convertModernRedirectResponse(response.headers);
105
- } else if (DEFERRED_SYMBOL in response) {
106
- const deferredData = response[DEFERRED_SYMBOL];
107
- const body = createDeferredReadableStream(deferredData, request.signal);
108
- const init = deferredData.init || {};
109
- if (init.status && isRedirectResponse(init.status)) {
110
- if (!init.headers) {
111
- throw new Error("redirect response includes no headers");
112
- }
113
- response = convertModernRedirectResponse(new Headers(init.headers));
114
- } else {
115
- const headers = new Headers(init.headers);
116
- headers.set("Content-Type", "text/modernjs-deferred");
117
- init.headers = headers;
118
- response = new NodeResponse(body, init);
119
- }
120
- } else {
121
- response = isResponse(response) ? response : new NodeResponse(JSON.stringify(response), {
122
- headers: {
123
- "Content-Type": "application/json; charset=utf-8"
124
- }
125
- });
126
- }
127
- } catch (error) {
128
- const message = error instanceof ErrorResponse ? error.data : String(error);
129
- response = new NodeResponse(message, {
130
- status: 500,
131
- headers: {
132
- "Content-Type": "text/plain"
133
- }
134
- });
135
- }
136
- sendLoaderResponse(res, response);
137
- };
138
- export {
139
- handleRequest,
140
- isRedirectResponse,
141
- isResponse,
142
- matchEntry
143
- };
@@ -1,79 +0,0 @@
1
- import { TextEncoder } from "util";
2
- import { serializeJson } from "@modern-js/utils";
3
- function isTrackedPromise(value) {
4
- return value != null && typeof value.then === "function" && value._tracked === true;
5
- }
6
- const DEFERRED_VALUE_PLACEHOLDER_PREFIX = "__deferred_promise:";
7
- function createDeferredReadableStream(deferredData, signal) {
8
- const encoder = new TextEncoder();
9
- const stream = new ReadableStream({
10
- async start(controller) {
11
- const criticalData = {};
12
- const preresolvedKeys = [];
13
- for (const [key, value] of Object.entries(deferredData.data)) {
14
- if (isTrackedPromise(value)) {
15
- criticalData[key] = `${DEFERRED_VALUE_PLACEHOLDER_PREFIX}${key}`;
16
- if (typeof value._data !== "undefined" || typeof value._error !== "undefined") {
17
- preresolvedKeys.push(key);
18
- }
19
- } else {
20
- criticalData[key] = value;
21
- }
22
- }
23
- controller.enqueue(encoder.encode(`${JSON.stringify(criticalData)}
24
-
25
- `));
26
- for (const preresolvedKey of preresolvedKeys) {
27
- enqueueTrackedPromise(
28
- controller,
29
- encoder,
30
- preresolvedKey,
31
- deferredData.data[preresolvedKey]
32
- );
33
- }
34
- const unsubscribe = deferredData.subscribe((aborted, settledKey) => {
35
- if (settledKey) {
36
- enqueueTrackedPromise(
37
- controller,
38
- encoder,
39
- settledKey,
40
- deferredData.data[settledKey]
41
- );
42
- }
43
- });
44
- await deferredData.resolveData(signal);
45
- unsubscribe();
46
- controller.close();
47
- }
48
- });
49
- return stream;
50
- }
51
- function enqueueTrackedPromise(controller, encoder, settledKey, promise) {
52
- var _a;
53
- if ("_error" in promise) {
54
- const { _error } = promise;
55
- controller.enqueue(
56
- encoder.encode(
57
- `error:${serializeJson({
58
- [settledKey]: {
59
- message: _error.message,
60
- stack: _error.stack
61
- }
62
- })}
63
-
64
- `
65
- )
66
- );
67
- } else {
68
- controller.enqueue(
69
- encoder.encode(
70
- `data:${JSON.stringify({ [settledKey]: (_a = promise._data) != null ? _a : null })}
71
-
72
- `
73
- )
74
- );
75
- }
76
- }
77
- export {
78
- createDeferredReadableStream
79
- };
@@ -1,6 +0,0 @@
1
- /**
2
- * modified from https://github.com/remix-run/remix/blob/main/packages/remix-react/data.ts
3
- * license at https://github.com/remix-run/remix/blob/main/LICENSE.md
4
- */
5
- import { UNSAFE_DeferredData as DeferredData } from '@modern-js/utils/remix-router';
6
- export declare function parseDeferredReadableStream(stream: ReadableStream<Uint8Array>): Promise<DeferredData>;
@@ -1,15 +0,0 @@
1
- import type { ModernServerContext, NestedRoute, ServerRoute } from '@modern-js/types';
2
- import { Response as NodeResponse } from '@remix-run/node';
3
- export type ServerContext = Pick<ModernServerContext, 'req' | 'res' | 'params' | 'headers' | 'method' | 'url' | 'host' | 'protocol' | 'origin' | 'href' | 'path' | 'query'>;
4
- export declare function isRedirectResponse(status: number): boolean;
5
- export declare function isResponse(value: any): value is NodeResponse;
6
- export declare const matchEntry: (pathname: string, entries: ServerRoute[]) => ServerRoute | undefined;
7
- export declare const handleRequest: ({
8
- context,
9
- serverRoutes,
10
- routes
11
- }: {
12
- context: ServerContext;
13
- serverRoutes: ServerRoute[];
14
- routes: NestedRoute[];
15
- }) => Promise<void>;
@@ -1,2 +0,0 @@
1
- import { type UNSAFE_DeferredData as DeferredData } from '@modern-js/utils/remix-router';
2
- export declare function createDeferredReadableStream(deferredData: DeferredData, signal: AbortSignal): any;