@modern-js/plugin-data-loader 2.4.1-beta.0 → 2.5.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 (33) hide show
  1. package/dist/{js/node → cjs}/cli/create-request.js +17 -26
  2. package/dist/cjs/cli/data.js +162 -0
  3. package/dist/{js/node → cjs}/cli/generate-client.js +1 -1
  4. package/dist/{js/node → cjs}/cli/loader.js +12 -34
  5. package/dist/{js/node → cjs}/common/constants.js +0 -0
  6. package/dist/cjs/runtime/index.js +159 -0
  7. package/dist/cjs/runtime/response.js +102 -0
  8. package/dist/cjs/server/index.js +64 -0
  9. package/dist/{js/treeshaking → esm}/cli/create-request.js +41 -2
  10. package/dist/esm/cli/data.js +820 -0
  11. package/dist/{js/treeshaking → esm}/cli/generate-client.js +1 -1
  12. package/dist/{js/treeshaking → esm}/cli/loader.js +0 -0
  13. package/dist/{js/treeshaking → esm}/common/constants.js +0 -0
  14. package/dist/{js/treeshaking/server → esm/runtime}/index.js +66 -222
  15. package/dist/esm/runtime/response.js +284 -0
  16. package/dist/esm/server/index.js +176 -0
  17. package/dist/{js/modern → esm-node}/cli/create-request.js +17 -26
  18. package/dist/esm-node/cli/data.js +142 -0
  19. package/dist/{js/modern → esm-node}/cli/generate-client.js +1 -1
  20. package/dist/esm-node/cli/loader.js +18 -0
  21. package/dist/{js/modern → esm-node}/common/constants.js +0 -0
  22. package/dist/esm-node/runtime/index.js +143 -0
  23. package/dist/esm-node/runtime/response.js +79 -0
  24. package/dist/esm-node/server/index.js +40 -0
  25. package/dist/types/cli/create-request.d.ts +2 -1
  26. package/dist/types/cli/data.d.ts +6 -0
  27. package/dist/types/runtime/index.d.ts +15 -0
  28. package/dist/types/runtime/response.d.ts +2 -0
  29. package/dist/types/server/index.d.ts +0 -15
  30. package/package.json +24 -14
  31. package/dist/js/modern/cli/loader.js +0 -40
  32. package/dist/js/modern/server/index.js +0 -237
  33. package/dist/js/node/server/index.js +0 -261
@@ -0,0 +1,176 @@
1
+ function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
2
+ try {
3
+ var info = gen[key](arg);
4
+ var value = info.value;
5
+ } catch (error) {
6
+ reject(error);
7
+ return;
8
+ }
9
+ if (info.done) {
10
+ resolve(value);
11
+ } else {
12
+ Promise.resolve(value).then(_next, _throw);
13
+ }
14
+ }
15
+ function _asyncToGenerator(fn) {
16
+ return function() {
17
+ var self = this, args = arguments;
18
+ return new Promise(function(resolve, reject) {
19
+ var gen = fn.apply(self, args);
20
+ function _next(value) {
21
+ asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
22
+ }
23
+ function _throw(err) {
24
+ asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
25
+ }
26
+ _next(undefined);
27
+ });
28
+ };
29
+ }
30
+ var __generator = this && this.__generator || function(thisArg, body) {
31
+ var f, y, t, g, _ = {
32
+ label: 0,
33
+ sent: function() {
34
+ if (t[0] & 1) throw t[1];
35
+ return t[1];
36
+ },
37
+ trys: [],
38
+ ops: []
39
+ };
40
+ return(g = {
41
+ next: verb(0),
42
+ "throw": verb(1),
43
+ "return": verb(2)
44
+ }, typeof Symbol === "function" && (g[Symbol.iterator] = function() {
45
+ return this;
46
+ }), g);
47
+ function verb(n) {
48
+ return function(v) {
49
+ return step([
50
+ n,
51
+ v
52
+ ]);
53
+ };
54
+ }
55
+ function step(op) {
56
+ if (f) throw new TypeError("Generator is already executing.");
57
+ while(_)try {
58
+ 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;
59
+ if (y = 0, t) op = [
60
+ op[0] & 2,
61
+ t.value
62
+ ];
63
+ switch(op[0]){
64
+ case 0:
65
+ case 1:
66
+ t = op;
67
+ break;
68
+ case 4:
69
+ _.label++;
70
+ return {
71
+ value: op[1],
72
+ done: false
73
+ };
74
+ case 5:
75
+ _.label++;
76
+ y = op[1];
77
+ op = [
78
+ 0
79
+ ];
80
+ continue;
81
+ case 7:
82
+ op = _.ops.pop();
83
+ _.trys.pop();
84
+ continue;
85
+ default:
86
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {
87
+ _ = 0;
88
+ continue;
89
+ }
90
+ if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {
91
+ _.label = op[1];
92
+ break;
93
+ }
94
+ if (op[0] === 6 && _.label < t[1]) {
95
+ _.label = t[1];
96
+ t = op;
97
+ break;
98
+ }
99
+ if (t && _.label < t[2]) {
100
+ _.label = t[2];
101
+ _.ops.push(op);
102
+ break;
103
+ }
104
+ if (t[2]) _.ops.pop();
105
+ _.trys.pop();
106
+ continue;
107
+ }
108
+ op = body.call(thisArg, _);
109
+ } catch (e) {
110
+ op = [
111
+ 6,
112
+ e
113
+ ];
114
+ y = 0;
115
+ } finally{
116
+ f = t = 0;
117
+ }
118
+ if (op[0] & 5) throw op[1];
119
+ return {
120
+ value: op[0] ? op[1] : void 0,
121
+ done: true
122
+ };
123
+ }
124
+ };
125
+ import path from "path";
126
+ import { MAIN_ENTRY_NAME, SERVER_BUNDLE_DIRECTORY } from "@modern-js/utils";
127
+ import { matchEntry } from "../runtime";
128
+ var server_default = function() {
129
+ return {
130
+ name: "@modern-js/plugin-data-loader",
131
+ setup: function() {
132
+ return {
133
+ preparebeforeRouteHandler: function preparebeforeRouteHandler(param) {
134
+ var serverRoutes = param.serverRoutes, distDir = param.distDir;
135
+ return function() {
136
+ var _ref = _asyncToGenerator(function(context) {
137
+ var entry, routesPath, _ref, routes, handleRequest;
138
+ return __generator(this, function(_state) {
139
+ switch(_state.label){
140
+ case 0:
141
+ entry = matchEntry(context.path, serverRoutes);
142
+ if (!entry) {
143
+ throw new Error("Route is not matched");
144
+ }
145
+ routesPath = path.join(distDir, SERVER_BUNDLE_DIRECTORY, "".concat(entry.entryName || MAIN_ENTRY_NAME, "-server-loaders"));
146
+ return [
147
+ 4,
148
+ import(routesPath)
149
+ ];
150
+ case 1:
151
+ _ref = _state.sent(), routes = _ref.routes, handleRequest = _ref.handleRequest;
152
+ if (!routes) {
153
+ throw new Error("Missing route info");
154
+ ;
155
+ }
156
+ return [
157
+ 2,
158
+ handleRequest({
159
+ serverRoutes: serverRoutes,
160
+ context: context,
161
+ routes: routes
162
+ })
163
+ ];
164
+ }
165
+ });
166
+ });
167
+ return function(context) {
168
+ return _ref.apply(this, arguments);
169
+ };
170
+ }();
171
+ }
172
+ };
173
+ }
174
+ };
175
+ };
176
+ export { server_default as default };
@@ -1,26 +1,7 @@
1
- var __async = (__this, __arguments, generator) => {
2
- return new Promise((resolve, reject) => {
3
- var fulfilled = (value) => {
4
- try {
5
- step(generator.next(value));
6
- } catch (e) {
7
- reject(e);
8
- }
9
- };
10
- var rejected = (value) => {
11
- try {
12
- step(generator.throw(value));
13
- } catch (e) {
14
- reject(e);
15
- }
16
- };
17
- var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
18
- step((generator = generator.apply(__this, __arguments)).next());
19
- });
20
- };
21
1
  import { compile } from "path-to-regexp";
22
2
  import { redirect } from "react-router-dom";
23
3
  import { LOADER_ID_PARAM, DIRECT_PARAM } from "../common/constants";
4
+ import { parseDeferredReadableStream } from "./data";
24
5
  const getRequestUrl = ({
25
6
  params,
26
7
  request,
@@ -40,25 +21,35 @@ const handleRedirectResponse = (res) => {
40
21
  const { headers } = res;
41
22
  const location = headers.get("X-Modernjs-Redirect");
42
23
  if (location) {
43
- return redirect(location);
24
+ throw redirect(location);
25
+ }
26
+ return res;
27
+ };
28
+ const handleDeferredResponse = async (res) => {
29
+ var _a;
30
+ if (((_a = res.headers.get("Content-Type")) == null ? void 0 : _a.match(/text\/modernjs-deferred/)) && res.body) {
31
+ return await parseDeferredReadableStream(res.body);
44
32
  }
45
33
  return res;
46
34
  };
47
35
  const createRequest = (routeId, method = "get") => {
48
- return (_0) => __async(void 0, [_0], function* ({
36
+ return async ({
49
37
  params,
50
38
  request
51
- }) {
39
+ }) => {
52
40
  const url = getRequestUrl({ params, request, routeId });
53
- const res = yield fetch(url, {
41
+ let res;
42
+ res = await fetch(url, {
54
43
  method,
55
44
  signal: request.signal
56
45
  });
57
46
  if (!res.ok) {
58
47
  throw res;
59
48
  }
60
- return handleRedirectResponse(res);
61
- });
49
+ res = handleRedirectResponse(res);
50
+ res = await handleDeferredResponse(res);
51
+ return res;
52
+ };
62
53
  };
63
54
  export {
64
55
  createRequest,
@@ -0,0 +1,142 @@
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
+ };
@@ -7,7 +7,7 @@ const generateClient = ({
7
7
  const loadersMap = require(mapFile);
8
8
  let requestCode = ``;
9
9
  let exportsCode = ``;
10
- const requestCreatorPath = path.join(__dirname, "./create-request").replace("/node/cli/", "/treeshaking/cli/").replace(/\\/g, "/");
10
+ const requestCreatorPath = path.join(__dirname, "./create-request").replace("/cjs/cli/", "/esm/cli/").replace(/\\/g, "/");
11
11
  const importCode = `
12
12
  import { createRequest } from '${requestCreatorPath}';
13
13
  `;
@@ -0,0 +1,18 @@
1
+ import { generateClient } from "./generate-client";
2
+ async function loader(source) {
3
+ var _a;
4
+ this.cacheable();
5
+ const target = (_a = this._compiler) == null ? void 0 : _a.options.target;
6
+ if (target === "node") {
7
+ return source;
8
+ }
9
+ const options = this.getOptions();
10
+ const code = generateClient({
11
+ mapFile: options.mapFile,
12
+ loaderId: options.loaderId
13
+ });
14
+ return code;
15
+ }
16
+ export {
17
+ loader as default
18
+ };
File without changes
@@ -0,0 +1,143 @@
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
+ };
@@ -0,0 +1,79 @@
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
+ };
@@ -0,0 +1,40 @@
1
+ import path from "path";
2
+ import {
3
+ MAIN_ENTRY_NAME,
4
+ SERVER_BUNDLE_DIRECTORY
5
+ } from "@modern-js/utils";
6
+ import { matchEntry } from "../runtime";
7
+ var server_default = () => ({
8
+ name: "@modern-js/plugin-data-loader",
9
+ setup: () => ({
10
+ preparebeforeRouteHandler({
11
+ serverRoutes,
12
+ distDir
13
+ }) {
14
+ return async (context) => {
15
+ const entry = matchEntry(context.path, serverRoutes);
16
+ if (!entry) {
17
+ throw new Error("Route is not matched");
18
+ }
19
+ const routesPath = path.join(
20
+ distDir,
21
+ SERVER_BUNDLE_DIRECTORY,
22
+ `${entry.entryName || MAIN_ENTRY_NAME}-server-loaders`
23
+ );
24
+ const { routes, handleRequest } = await import(routesPath);
25
+ if (!routes) {
26
+ throw new Error("Missing route info");
27
+ ;
28
+ }
29
+ return handleRequest({
30
+ serverRoutes,
31
+ context,
32
+ routes
33
+ });
34
+ };
35
+ }
36
+ })
37
+ });
38
+ export {
39
+ server_default as default
40
+ };
@@ -1,3 +1,4 @@
1
+ import { type UNSAFE_DeferredData as DeferredData } from '@modern-js/utils/remix-router';
1
2
  export declare const getRequestUrl: ({
2
3
  params,
3
4
  request,
@@ -13,4 +14,4 @@ export declare const createRequest: (routeId: string, method?: string) => ({
13
14
  }: {
14
15
  params: Record<string, string>;
15
16
  request: Request;
16
- }) => Promise<Response>;
17
+ }) => Promise<DeferredData | Response>;