@modern-js/plugin-data-loader 2.69.5 → 3.0.0-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 (47) hide show
  1. package/dist/cjs/cli/createRequest.js +122 -141
  2. package/dist/cjs/cli/data.js +129 -148
  3. package/dist/cjs/cli/generateClient.js +52 -52
  4. package/dist/cjs/cli/loader.js +63 -62
  5. package/dist/cjs/common/constants.js +41 -31
  6. package/dist/cjs/runtime/errors.js +84 -89
  7. package/dist/cjs/runtime/index.js +143 -155
  8. package/dist/cjs/runtime/response.js +66 -77
  9. package/dist/esm/cli/createRequest.mjs +93 -0
  10. package/dist/esm/cli/data.mjs +111 -0
  11. package/dist/esm/cli/generateClient.mjs +22 -0
  12. package/dist/esm/cli/loader.mjs +34 -0
  13. package/dist/esm/common/constants.mjs +4 -0
  14. package/dist/esm/runtime/errors.mjs +52 -0
  15. package/dist/esm/runtime/index.mjs +114 -0
  16. package/dist/esm/runtime/response.mjs +42 -0
  17. package/dist/esm-node/cli/createRequest.mjs +93 -0
  18. package/dist/esm-node/cli/data.mjs +111 -0
  19. package/dist/esm-node/cli/generateClient.mjs +22 -0
  20. package/dist/esm-node/cli/loader.mjs +34 -0
  21. package/dist/esm-node/common/constants.mjs +4 -0
  22. package/dist/esm-node/runtime/errors.mjs +52 -0
  23. package/dist/esm-node/runtime/index.mjs +114 -0
  24. package/dist/esm-node/runtime/response.mjs +42 -0
  25. package/dist/types/cli/createRequest.d.ts +1 -2
  26. package/dist/types/cli/loader.d.ts +2 -2
  27. package/dist/types/runtime/errors.d.ts +1 -1
  28. package/dist/types/runtime/response.d.ts +1 -1
  29. package/package.json +22 -26
  30. package/rslib.config.mts +4 -0
  31. package/rstest.config.ts +18 -0
  32. package/dist/esm/cli/createRequest.js +0 -297
  33. package/dist/esm/cli/data.js +0 -491
  34. package/dist/esm/cli/generateClient.js +0 -21
  35. package/dist/esm/cli/loader.js +0 -93
  36. package/dist/esm/common/constants.js +0 -8
  37. package/dist/esm/runtime/errors.js +0 -90
  38. package/dist/esm/runtime/index.js +0 -191
  39. package/dist/esm/runtime/response.js +0 -107
  40. package/dist/esm-node/cli/createRequest.js +0 -126
  41. package/dist/esm-node/cli/data.js +0 -140
  42. package/dist/esm-node/cli/generateClient.js +0 -32
  43. package/dist/esm-node/cli/loader.js +0 -47
  44. package/dist/esm-node/common/constants.js +0 -8
  45. package/dist/esm-node/runtime/errors.js +0 -75
  46. package/dist/esm-node/runtime/index.js +0 -142
  47. package/dist/esm-node/runtime/response.js +0 -63
@@ -1,90 +0,0 @@
1
- import { _ as _define_property } from "@swc/helpers/_/_define_property";
2
- import { _ as _instanceof } from "@swc/helpers/_/_instanceof";
3
- import { _ as _object_spread } from "@swc/helpers/_/_object_spread";
4
- import { _ as _object_spread_props } from "@swc/helpers/_/_object_spread_props";
5
- import { _ as _sliced_to_array } from "@swc/helpers/_/_sliced_to_array";
6
- import { isRouteErrorResponse } from "@modern-js/runtime-utils/remix-router";
7
- function sanitizeError(error) {
8
- if (_instanceof(error, Error) && process.env.NODE_ENV !== "development" && process.env.NODE_ENV !== "test") {
9
- var sanitized = new Error(error.message || "Unexpected Server Error");
10
- sanitized.stack = void 0;
11
- return sanitized;
12
- }
13
- return error;
14
- }
15
- function sanitizeErrors(errors) {
16
- return Object.entries(errors).reduce(function(acc, param) {
17
- var _param = _sliced_to_array(param, 2), routeId = _param[0], error = _param[1];
18
- return Object.assign(acc, _define_property({}, routeId, sanitizeError(error)));
19
- }, {});
20
- }
21
- function serializeError(error) {
22
- var sanitized = sanitizeError(error);
23
- return {
24
- message: sanitized.message,
25
- stack: sanitized.stack
26
- };
27
- }
28
- function serializeErrors(errors) {
29
- if (!errors) {
30
- return null;
31
- }
32
- var entries = Object.entries(errors);
33
- var serialized = {};
34
- var _iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = void 0;
35
- try {
36
- for (var _iterator = entries[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
37
- var _step_value = _sliced_to_array(_step.value, 2), key = _step_value[0], val = _step_value[1];
38
- if (isRouteErrorResponse(val)) {
39
- serialized[key] = _object_spread_props(_object_spread({}, val), {
40
- __type: "RouteErrorResponse"
41
- });
42
- } else if (_instanceof(val, Error)) {
43
- var sanitized = sanitizeError(val);
44
- serialized[key] = _object_spread({
45
- message: sanitized.message,
46
- stack: sanitized.stack,
47
- __type: "Error"
48
- }, sanitized.name !== "Error" ? {
49
- __subType: sanitized.name
50
- } : {});
51
- } else {
52
- serialized[key] = val;
53
- }
54
- }
55
- } catch (err) {
56
- _didIteratorError = true;
57
- _iteratorError = err;
58
- } finally {
59
- try {
60
- if (!_iteratorNormalCompletion && _iterator.return != null) {
61
- _iterator.return();
62
- }
63
- } finally {
64
- if (_didIteratorError) {
65
- throw _iteratorError;
66
- }
67
- }
68
- }
69
- return serialized;
70
- }
71
- function errorResponseToJson(errorResponse) {
72
- return Response.json(
73
- // @ts-expect-error This is "private" from users but intended for internal use
74
- serializeError(errorResponse.error || new Error("Unexpected Server Error")),
75
- {
76
- status: errorResponse.status,
77
- statusText: errorResponse.statusText,
78
- headers: {
79
- "X-Modernjs-Error": "yes"
80
- }
81
- }
82
- );
83
- }
84
- export {
85
- errorResponseToJson,
86
- sanitizeError,
87
- sanitizeErrors,
88
- serializeError,
89
- serializeErrors
90
- };
@@ -1,191 +0,0 @@
1
- import { _ as _async_to_generator } from "@swc/helpers/_/_async_to_generator";
2
- import { _ as _instanceof } from "@swc/helpers/_/_instanceof";
3
- import { _ as _type_of } from "@swc/helpers/_/_type_of";
4
- import { _ as _ts_generator } from "@swc/helpers/_/_ts_generator";
5
- import { transformNestedRoutes } from "@modern-js/runtime-utils/browser";
6
- import { createRequestContext, reporterCtx } from "@modern-js/runtime-utils/node";
7
- import { storage } from "@modern-js/runtime-utils/node";
8
- import { DEFERRED_SYMBOL, createStaticHandler, isRouteErrorResponse } from "@modern-js/runtime-utils/remix-router";
9
- import { matchEntry } from "@modern-js/runtime-utils/server";
10
- import { time } from "@modern-js/runtime-utils/time";
11
- import { parseHeaders } from "@modern-js/runtime-utils/universal/request";
12
- import { isPlainObject } from "@modern-js/utils/lodash";
13
- import { LOADER_REPORTER_NAME } from "@modern-js/utils/universal/constants";
14
- import { CONTENT_TYPE_DEFERRED, LOADER_ID_PARAM } from "../common/constants";
15
- import { errorResponseToJson, serializeError } from "./errors";
16
- import { createDeferredReadableStream } from "./response";
17
- var redirectStatusCodes = /* @__PURE__ */ new Set([
18
- 301,
19
- 302,
20
- 303,
21
- 307,
22
- 308
23
- ]);
24
- function isRedirectResponse(status) {
25
- return redirectStatusCodes.has(status);
26
- }
27
- function isResponse(value) {
28
- return value != null && typeof value.status === "number" && typeof value.statusText === "string" && _type_of(value.headers) === "object" && typeof value.body !== "undefined";
29
- }
30
- function convertModernRedirectResponse(headers, basename) {
31
- var newHeaders = new Headers(headers);
32
- var redirectUrl = headers.get("Location");
33
- if (basename !== "/") {
34
- redirectUrl = redirectUrl.replace(basename, "");
35
- }
36
- newHeaders.set("X-Modernjs-Redirect", redirectUrl);
37
- newHeaders.delete("Location");
38
- return new Response(null, {
39
- status: 204,
40
- headers: newHeaders
41
- });
42
- }
43
- function hasFileExtension(pathname) {
44
- var lastSegment = pathname.split("/").pop() || "";
45
- var dotIndex = lastSegment.lastIndexOf(".");
46
- if (dotIndex === -1) {
47
- return false;
48
- }
49
- var extension = lastSegment.substring(dotIndex).toLowerCase();
50
- return extension !== ".html";
51
- }
52
- var handleRequest = function() {
53
- var _ref = _async_to_generator(function(param) {
54
- var request, serverRoutes, routesConfig, context, onTiming, url, routeId, entry, basename, end, reporter, loaderContext, monitors, headersData, activeDeferreds;
55
- return _ts_generator(this, function(_state) {
56
- request = param.request, serverRoutes = param.serverRoutes, routesConfig = param.routes, context = param.context, onTiming = param.onTiming;
57
- url = new URL(request.url);
58
- routeId = url.searchParams.get(LOADER_ID_PARAM);
59
- if (hasFileExtension(url.pathname)) {
60
- return [
61
- 2
62
- ];
63
- }
64
- entry = matchEntry(url.pathname, serverRoutes);
65
- if (!routeId || !entry) {
66
- return [
67
- 2
68
- ];
69
- }
70
- basename = entry.urlPath;
71
- end = time();
72
- reporter = context.reporter, loaderContext = context.loaderContext, monitors = context.monitors;
73
- headersData = parseHeaders(request);
74
- activeDeferreds = /* @__PURE__ */ new Map();
75
- return [
76
- 2,
77
- storage.run({
78
- headers: headersData,
79
- monitors,
80
- request,
81
- activeDeferreds
82
- }, /* @__PURE__ */ _async_to_generator(function() {
83
- var routes, queryRoute, requestContext, response, deferredData, body, init, headers, cost, error, errorInstance;
84
- return _ts_generator(this, function(_state2) {
85
- switch (_state2.label) {
86
- case 0:
87
- routes = transformNestedRoutes(routesConfig);
88
- queryRoute = createStaticHandler(routes, {
89
- basename
90
- }).queryRoute;
91
- requestContext = createRequestContext(loaderContext);
92
- requestContext.set(reporterCtx, reporter);
93
- _state2.label = 1;
94
- case 1:
95
- _state2.trys.push([
96
- 1,
97
- 3,
98
- ,
99
- 4
100
- ]);
101
- return [
102
- 4,
103
- queryRoute(request, {
104
- routeId,
105
- requestContext
106
- })
107
- ];
108
- case 2:
109
- response = _state2.sent();
110
- if (isResponse(response) && isRedirectResponse(response.status)) {
111
- response = convertModernRedirectResponse(response.headers, basename);
112
- } else if (isPlainObject(response) && (DEFERRED_SYMBOL in response || activeDeferreds.get(routeId))) {
113
- ;
114
- if (DEFERRED_SYMBOL in response) {
115
- deferredData = response[DEFERRED_SYMBOL];
116
- } else {
117
- deferredData = activeDeferreds.get(routeId);
118
- }
119
- body = createDeferredReadableStream(
120
- // @ts-ignore
121
- deferredData,
122
- request.signal
123
- );
124
- init = deferredData.init || {};
125
- if (init.status && isRedirectResponse(init.status)) {
126
- if (!init.headers) {
127
- throw new Error("redirect response includes no headers");
128
- }
129
- response = convertModernRedirectResponse(new Headers(init.headers), basename);
130
- } else {
131
- headers = new Headers(init.headers);
132
- headers.set("Content-Type", "".concat(CONTENT_TYPE_DEFERRED, "; charset=UTF-8"));
133
- init.headers = headers;
134
- response = new Response(body, init);
135
- }
136
- } else {
137
- response = isResponse(response) ? response : new Response(JSON.stringify(response), {
138
- headers: {
139
- "Content-Type": "application/json; charset=utf-8"
140
- }
141
- });
142
- }
143
- cost = end();
144
- response.headers.set("X-Modernjs-Response", "yes");
145
- onTiming === null || onTiming === void 0 ? void 0 : onTiming("".concat(LOADER_REPORTER_NAME, "-navigation"), cost);
146
- return [
147
- 3,
148
- 4
149
- ];
150
- case 3:
151
- error = _state2.sent();
152
- if (isResponse(error)) {
153
- error.headers.set("X-Modernjs-Catch", "yes");
154
- response = error;
155
- } else if (isRouteErrorResponse(error)) {
156
- response = errorResponseToJson(error);
157
- } else {
158
- errorInstance = _instanceof(error, Error) || _instanceof(error, DOMException) ? error : new Error("Unexpected Server Error");
159
- response = new Response(JSON.stringify(serializeError(errorInstance)), {
160
- status: 500,
161
- headers: {
162
- "X-Modernjs-Error": "yes",
163
- "Content-Type": "application/json"
164
- }
165
- });
166
- }
167
- return [
168
- 3,
169
- 4
170
- ];
171
- case 4:
172
- return [
173
- 2,
174
- response
175
- ];
176
- }
177
- });
178
- }))
179
- ];
180
- });
181
- });
182
- return function handleRequest2(_) {
183
- return _ref.apply(this, arguments);
184
- };
185
- }();
186
- export {
187
- handleRequest,
188
- hasFileExtension,
189
- isRedirectResponse,
190
- isResponse
191
- };
@@ -1,107 +0,0 @@
1
- import { _ as _async_to_generator } from "@swc/helpers/_/_async_to_generator";
2
- import { _ as _define_property } from "@swc/helpers/_/_define_property";
3
- import { _ as _sliced_to_array } from "@swc/helpers/_/_sliced_to_array";
4
- import { _ as _ts_generator } from "@swc/helpers/_/_ts_generator";
5
- import { TextEncoder } from "util";
6
- import { serializeJson } from "@modern-js/runtime-utils/node";
7
- function isTrackedPromise(value) {
8
- return value != null && typeof value.then === "function" && value._tracked === true;
9
- }
10
- var DEFERRED_VALUE_PLACEHOLDER_PREFIX = "__deferred_promise:";
11
- function createDeferredReadableStream(deferredData, signal) {
12
- var encoder = new TextEncoder();
13
- var stream = new ReadableStream({
14
- start: function start(controller) {
15
- return _async_to_generator(function() {
16
- var criticalData, preresolvedKeys, _iteratorNormalCompletion, _didIteratorError, _iteratorError, _iterator, _step, _step_value, key, value, _iteratorNormalCompletion1, _didIteratorError1, _iteratorError1, _iterator1, _step1, preresolvedKey, unsubscribe;
17
- return _ts_generator(this, function(_state) {
18
- switch (_state.label) {
19
- case 0:
20
- criticalData = {};
21
- preresolvedKeys = [];
22
- _iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = void 0;
23
- try {
24
- for (_iterator = Object.entries(deferredData.data)[Symbol.iterator](); !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
25
- _step_value = _sliced_to_array(_step.value, 2), key = _step_value[0], value = _step_value[1];
26
- if (isTrackedPromise(value)) {
27
- criticalData[key] = "".concat(DEFERRED_VALUE_PLACEHOLDER_PREFIX).concat(key);
28
- if (typeof value._data !== "undefined" || typeof value._error !== "undefined") {
29
- preresolvedKeys.push(key);
30
- }
31
- } else {
32
- criticalData[key] = value;
33
- }
34
- }
35
- } catch (err) {
36
- _didIteratorError = true;
37
- _iteratorError = err;
38
- } finally {
39
- try {
40
- if (!_iteratorNormalCompletion && _iterator.return != null) {
41
- _iterator.return();
42
- }
43
- } finally {
44
- if (_didIteratorError) {
45
- throw _iteratorError;
46
- }
47
- }
48
- }
49
- controller.enqueue(encoder.encode("".concat(JSON.stringify(criticalData), "\n\n")));
50
- _iteratorNormalCompletion1 = true, _didIteratorError1 = false, _iteratorError1 = void 0;
51
- try {
52
- for (_iterator1 = preresolvedKeys[Symbol.iterator](); !(_iteratorNormalCompletion1 = (_step1 = _iterator1.next()).done); _iteratorNormalCompletion1 = true) {
53
- preresolvedKey = _step1.value;
54
- enqueueTrackedPromise(controller, encoder, preresolvedKey, deferredData.data[preresolvedKey]);
55
- }
56
- } catch (err) {
57
- _didIteratorError1 = true;
58
- _iteratorError1 = err;
59
- } finally {
60
- try {
61
- if (!_iteratorNormalCompletion1 && _iterator1.return != null) {
62
- _iterator1.return();
63
- }
64
- } finally {
65
- if (_didIteratorError1) {
66
- throw _iteratorError1;
67
- }
68
- }
69
- }
70
- unsubscribe = deferredData.subscribe(function(aborted, settledKey) {
71
- if (settledKey) {
72
- enqueueTrackedPromise(controller, encoder, settledKey, deferredData.data[settledKey]);
73
- }
74
- });
75
- return [
76
- 4,
77
- deferredData.resolveData(signal)
78
- ];
79
- case 1:
80
- _state.sent();
81
- unsubscribe();
82
- controller.close();
83
- return [
84
- 2
85
- ];
86
- }
87
- });
88
- })();
89
- }
90
- });
91
- return stream;
92
- }
93
- function enqueueTrackedPromise(controller, encoder, settledKey, promise) {
94
- if ("_error" in promise) {
95
- var _error = promise._error;
96
- controller.enqueue(encoder.encode("error:".concat(serializeJson(_define_property({}, settledKey, {
97
- message: _error.message,
98
- stack: _error.stack
99
- })), "\n\n")));
100
- } else {
101
- var _promise__data;
102
- controller.enqueue(encoder.encode("data:".concat(JSON.stringify(_define_property({}, settledKey, (_promise__data = promise._data) !== null && _promise__data !== void 0 ? _promise__data : null)), "\n\n")));
103
- }
104
- }
105
- export {
106
- createDeferredReadableStream
107
- };
@@ -1,126 +0,0 @@
1
- import { redirect } from "@modern-js/runtime-utils/router";
2
- import { compile } from "path-to-regexp";
3
- import { CONTENT_TYPE_DEFERRED, DIRECT_PARAM, LOADER_ID_PARAM } from "../common/constants";
4
- import { parseDeferredReadableStream } from "./data";
5
- const getRequestUrl = ({ params, request, routeId }) => {
6
- const url = new URL(request.url);
7
- const toPath = compile(url.pathname, {
8
- encode: encodeURIComponent
9
- });
10
- const newPathName = toPath(params);
11
- url.pathname = newPathName;
12
- url.searchParams.append(LOADER_ID_PARAM, routeId);
13
- url.searchParams.append(DIRECT_PARAM, "true");
14
- return url;
15
- };
16
- const handleRedirectResponse = (res) => {
17
- const { headers } = res;
18
- const location = headers.get("X-Modernjs-Redirect");
19
- if (location) {
20
- throw redirect(location);
21
- }
22
- return res;
23
- };
24
- const isDeferredResponse = (res) => {
25
- var _res_headers_get;
26
- return ((_res_headers_get = res.headers.get("Content-Type")) === null || _res_headers_get === void 0 ? void 0 : _res_headers_get.match(CONTENT_TYPE_DEFERRED)) && res.body;
27
- };
28
- const isRedirectResponse = (res) => {
29
- return res.headers.get("X-Modernjs-Redirect") != null;
30
- };
31
- const isErrorResponse = (res) => {
32
- return res.headers.get("X-Modernjs-Error") != null;
33
- };
34
- function isOtherErrorResponse(res) {
35
- return res.status >= 400 && res.headers.get("X-Modernjs-Error") == null && res.headers.get("X-Modernjs-Catch") == null && res.headers.get("X-Modernjs-Response") == null;
36
- }
37
- const isCatchResponse = (res) => {
38
- return res.headers.get("X-Modernjs-Catch") != null;
39
- };
40
- const handleErrorResponse = async (res) => {
41
- const data = await res.json();
42
- const error = new Error(data.message);
43
- error.stack = data.stack;
44
- throw error;
45
- };
46
- const handleNetworkErrorResponse = async (res) => {
47
- const text = await res.text();
48
- const error = new Error(text);
49
- error.stack = void 0;
50
- throw error;
51
- };
52
- const createRequest = (routeId, method = "get") => {
53
- const isRouterV7 = process.env._MODERN_ROUTER_VERSION === "v7";
54
- return async ({ params, request }) => {
55
- const url = getRequestUrl({
56
- params,
57
- request,
58
- routeId
59
- });
60
- let res;
61
- res = await fetch(url, {
62
- method,
63
- signal: request.signal
64
- }).catch((error) => {
65
- throw error;
66
- });
67
- if (isRedirectResponse(res)) {
68
- return handleRedirectResponse(res);
69
- }
70
- if (isErrorResponse(res)) {
71
- return await handleErrorResponse(res);
72
- }
73
- if (isCatchResponse(res)) {
74
- throw res;
75
- }
76
- if (isDeferredResponse(res)) {
77
- const deferredData = await parseDeferredReadableStream(res.body);
78
- return isRouterV7 ? deferredData.data : deferredData;
79
- }
80
- if (isOtherErrorResponse(res)) {
81
- return await handleNetworkErrorResponse(res);
82
- }
83
- return res;
84
- };
85
- };
86
- const createActionRequest = (routeId) => {
87
- return async ({ params, request }) => {
88
- const url = getRequestUrl({
89
- params,
90
- request,
91
- routeId
92
- });
93
- const init = {
94
- signal: request.signal
95
- };
96
- if (request.method !== "GET") {
97
- init.method = request.method;
98
- const contentType = request.headers.get("Content-Type");
99
- if (contentType && /\bapplication\/json\b/.test(contentType)) {
100
- init.headers = {
101
- "Content-Type": contentType
102
- };
103
- init.body = JSON.stringify(await request.json());
104
- } else if (contentType && /\btext\/plain\b/.test(contentType)) {
105
- init.headers = {
106
- "Content-Type": contentType
107
- };
108
- init.body = await request.text();
109
- } else if (contentType && /\bapplication\/x-www-form-urlencoded\b/.test(contentType)) {
110
- init.body = new URLSearchParams(await request.text());
111
- } else {
112
- init.body = await request.formData();
113
- }
114
- }
115
- const res = await fetch(url, init);
116
- if (!res.ok) {
117
- throw res;
118
- }
119
- return res;
120
- };
121
- };
122
- export {
123
- createActionRequest,
124
- createRequest,
125
- getRequestUrl
126
- };
@@ -1,140 +0,0 @@
1
- import { AbortedDeferredError, DeferredData } from "@modern-js/runtime-utils/browser";
2
- const DEFERRED_VALUE_PLACEHOLDER_PREFIX = "__deferred_promise:";
3
- async function parseDeferredReadableStream(stream) {
4
- if (!stream) {
5
- throw new Error("parseDeferredReadableStream requires stream argument");
6
- }
7
- let deferredData;
8
- const deferredResolvers = {};
9
- try {
10
- const sectionReader = readStreamSections(stream);
11
- const initialSectionResult = await sectionReader.next();
12
- const initialSection = initialSectionResult.value;
13
- if (!initialSection) {
14
- throw new Error("no critical data");
15
- }
16
- const criticalData = JSON.parse(initialSection);
17
- if (typeof criticalData === "object" && criticalData !== null) {
18
- for (const [eventKey, value] of Object.entries(criticalData)) {
19
- if (typeof value !== "string" || !value.startsWith(DEFERRED_VALUE_PLACEHOLDER_PREFIX)) {
20
- continue;
21
- }
22
- deferredData = deferredData || {};
23
- deferredData[eventKey] = new Promise((resolve, reject) => {
24
- deferredResolvers[eventKey] = {
25
- resolve: (value2) => {
26
- resolve(value2);
27
- delete deferredResolvers[eventKey];
28
- },
29
- reject: (error) => {
30
- reject(error);
31
- delete deferredResolvers[eventKey];
32
- }
33
- };
34
- });
35
- }
36
- }
37
- (async () => {
38
- try {
39
- for await (const section of sectionReader) {
40
- const [event, ...sectionDataStrings] = section.split(":");
41
- const sectionDataString = sectionDataStrings.join(":");
42
- const data = JSON.parse(sectionDataString);
43
- if (event === "data") {
44
- for (const [key, value] of Object.entries(data)) {
45
- if (deferredResolvers[key]) {
46
- deferredResolvers[key].resolve(value);
47
- }
48
- }
49
- } else if (event === "error") {
50
- for (const [key, value] of Object.entries(data)) {
51
- const err = new Error(value.message);
52
- err.stack = value.stack;
53
- if (deferredResolvers[key]) {
54
- deferredResolvers[key].reject(err);
55
- }
56
- }
57
- }
58
- }
59
- for (const [key, resolver] of Object.entries(deferredResolvers)) {
60
- resolver.reject(new AbortedDeferredError(`Deferred ${key} will never resolved`));
61
- }
62
- } catch (error) {
63
- for (const resolver of Object.values(deferredResolvers)) {
64
- resolver.reject(error);
65
- }
66
- }
67
- })();
68
- return new DeferredData({
69
- ...criticalData,
70
- ...deferredData
71
- });
72
- } catch (error) {
73
- for (const resolver of Object.values(deferredResolvers)) {
74
- resolver.reject(error);
75
- }
76
- throw error;
77
- }
78
- }
79
- async function* readStreamSections(stream) {
80
- const reader = stream.getReader();
81
- let buffer = [];
82
- let sections = [];
83
- let closed = false;
84
- const encoder = new TextEncoder();
85
- const decoder = new TextDecoder();
86
- const readStreamSection = async () => {
87
- if (sections.length > 0) {
88
- return sections.shift();
89
- }
90
- while (!closed && sections.length === 0) {
91
- const chunk = await reader.read();
92
- if (chunk.done) {
93
- closed = true;
94
- break;
95
- }
96
- buffer.push(chunk.value);
97
- try {
98
- const bufferedString = decoder.decode(mergeArrays(...buffer));
99
- const splitSections = bufferedString.split("\n\n");
100
- if (splitSections.length >= 2) {
101
- sections.push(...splitSections.slice(0, -1));
102
- buffer = [
103
- encoder.encode(splitSections.slice(-1).join("\n\n"))
104
- ];
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(arrays.reduce((total, arr) => total + arr.length, 0));
131
- let offset = 0;
132
- for (const arr of arrays) {
133
- out.set(arr, offset);
134
- offset += arr.length;
135
- }
136
- return out;
137
- }
138
- export {
139
- parseDeferredReadableStream
140
- };
@@ -1,32 +0,0 @@
1
- import path from "path";
2
- const generateClient = ({ inline, action, routeId }) => {
3
- let requestCode = ``;
4
- const requestCreatorPath = path.join(__dirname, "./createRequest").replace("/cjs/cli/", "/esm/cli/").replace(/\\/g, "/");
5
- const importCode = `
6
- import { createRequest, createActionRequest } from '${requestCreatorPath}';
7
- `;
8
- if (inline) {
9
- if (action) {
10
- requestCode = `
11
- export const loader = createRequest('${routeId}');
12
- export const action = createActionRequest('${routeId}')
13
- `;
14
- } else {
15
- requestCode = `
16
- export const loader = createRequest('${routeId}');
17
- `;
18
- }
19
- } else {
20
- requestCode = `
21
- export default createRequest('${routeId}');
22
- `;
23
- }
24
- const generatedCode = `
25
- ${importCode}
26
- ${requestCode}
27
- `;
28
- return generatedCode;
29
- };
30
- export {
31
- generateClient
32
- };