@modern-js/plugin-data-loader 2.5.0-alpha.0 → 2.6.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.
@@ -1,3 +1,11 @@
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
+ }
1
9
  function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
2
10
  try {
3
11
  var info = gen[key](arg);
@@ -27,6 +35,96 @@ function _asyncToGenerator(fn) {
27
35
  });
28
36
  };
29
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 _objectSpread(target) {
79
+ for(var i = 1; i < arguments.length; i++){
80
+ var source = arguments[i] != null ? arguments[i] : {};
81
+ var ownKeys = Object.keys(source);
82
+ if (typeof Object.getOwnPropertySymbols === "function") {
83
+ ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {
84
+ return Object.getOwnPropertyDescriptor(source, sym).enumerable;
85
+ }));
86
+ }
87
+ ownKeys.forEach(function(key) {
88
+ _defineProperty(target, key, source[key]);
89
+ });
90
+ }
91
+ return target;
92
+ }
93
+ function ownKeys(object, enumerableOnly) {
94
+ var keys = Object.keys(object);
95
+ if (Object.getOwnPropertySymbols) {
96
+ var symbols = Object.getOwnPropertySymbols(object);
97
+ if (enumerableOnly) {
98
+ symbols = symbols.filter(function(sym) {
99
+ return Object.getOwnPropertyDescriptor(object, sym).enumerable;
100
+ });
101
+ }
102
+ keys.push.apply(keys, symbols);
103
+ }
104
+ return keys;
105
+ }
106
+ function _objectSpreadProps(target, source) {
107
+ source = source != null ? source : {};
108
+ if (Object.getOwnPropertyDescriptors) {
109
+ Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
110
+ } else {
111
+ ownKeys(Object(source)).forEach(function(key) {
112
+ Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
113
+ });
114
+ }
115
+ return target;
116
+ }
117
+ function _slicedToArray(arr, i) {
118
+ return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest();
119
+ }
120
+ function _unsupportedIterableToArray(o, minLen) {
121
+ if (!o) return;
122
+ if (typeof o === "string") return _arrayLikeToArray(o, minLen);
123
+ var n = Object.prototype.toString.call(o).slice(8, -1);
124
+ if (n === "Object" && o.constructor) n = o.constructor.name;
125
+ if (n === "Map" || n === "Set") return Array.from(n);
126
+ if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);
127
+ }
30
128
  var __generator = this && this.__generator || function(thisArg, body) {
31
129
  var f, y, t, g, _ = {
32
130
  label: 0,
@@ -123,8 +221,332 @@ var __generator = this && this.__generator || function(thisArg, body) {
123
221
  }
124
222
  };
125
223
  import path from "path";
224
+ import { installGlobals, writeReadableStreamToWritable, Response as NodeResponse } from "@remix-run/node";
225
+ import { matchRoutes } from "react-router-dom";
126
226
  import { MAIN_ENTRY_NAME, SERVER_BUNDLE_DIRECTORY } from "@modern-js/utils";
127
- import { matchEntry } from "../runtime";
227
+ import { LOADER_ID_PARAM } from "../common/constants";
228
+ installGlobals();
229
+ var redirectStatusCodes = /* @__PURE__ */ new Set([
230
+ 301,
231
+ 302,
232
+ 303,
233
+ 307,
234
+ 308
235
+ ]);
236
+ function isRedirectResponse(response) {
237
+ return redirectStatusCodes.has(response.status);
238
+ }
239
+ function isResponse(value) {
240
+ return value != null && typeof value.status === "number" && typeof value.statusText === "string" && typeof value.headers === "object" && typeof value.body !== "undefined";
241
+ }
242
+ var json = function(data) {
243
+ var init = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {};
244
+ var responseInit = typeof init === "number" ? {
245
+ status: init
246
+ } : init;
247
+ var headers = new Headers(responseInit.headers);
248
+ if (!headers.has("Content-Type")) {
249
+ headers.set("Content-Type", "application/json; charset=utf-8");
250
+ }
251
+ return new NodeResponse(JSON.stringify(data), _objectSpreadProps(_objectSpread({}, responseInit), {
252
+ headers: headers
253
+ }));
254
+ };
255
+ var callRouteLoader = function() {
256
+ var _ref = _asyncToGenerator(function(param) {
257
+ var routeId, loader, params, request, // eslint-disable-next-line @typescript-eslint/no-unused-vars
258
+ loadContext, result, error;
259
+ return __generator(this, function(_state) {
260
+ switch(_state.label){
261
+ case 0:
262
+ routeId = param.routeId, loader = param.loader, params = param.params, request = param.request, loadContext = param.loadContext;
263
+ if (!loader) {
264
+ throw new Error("You made a ".concat(request.method, " request to ").concat(request.url, ' but did not provide a default component or `loader` for route "').concat(routeId, '", so there is no way to handle the request.'));
265
+ }
266
+ _state.label = 1;
267
+ case 1:
268
+ _state.trys.push([
269
+ 1,
270
+ 3,
271
+ ,
272
+ 4
273
+ ]);
274
+ return [
275
+ 4,
276
+ loader({
277
+ request: request,
278
+ params: params
279
+ })
280
+ ];
281
+ case 2:
282
+ result = _state.sent();
283
+ return [
284
+ 3,
285
+ 4
286
+ ];
287
+ case 3:
288
+ error = _state.sent();
289
+ if (!isResponse(error)) {
290
+ throw error;
291
+ }
292
+ result = error;
293
+ return [
294
+ 3,
295
+ 4
296
+ ];
297
+ case 4:
298
+ if (result === void 0) {
299
+ throw new Error('You defined a loader for route "'.concat(routeId, "\" but didn't return anything from your `loader` function. Please return a value or `null`."));
300
+ }
301
+ return [
302
+ 2,
303
+ isResponse(result) ? result : json(result)
304
+ ];
305
+ }
306
+ });
307
+ });
308
+ return function callRouteLoader(_) {
309
+ return _ref.apply(this, arguments);
310
+ };
311
+ }();
312
+ var createLoaderHeaders = function(requestHeaders) {
313
+ var headers = new Headers();
314
+ var _iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = undefined;
315
+ try {
316
+ for(var _iterator = Object.entries(requestHeaders)[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true){
317
+ var _step_value = _slicedToArray(_step.value, 2), key = _step_value[0], values = _step_value[1];
318
+ if (values) {
319
+ if (Array.isArray(values)) {
320
+ var _iteratorNormalCompletion1 = true, _didIteratorError1 = false, _iteratorError1 = undefined;
321
+ try {
322
+ for(var _iterator1 = values[Symbol.iterator](), _step1; !(_iteratorNormalCompletion1 = (_step1 = _iterator1.next()).done); _iteratorNormalCompletion1 = true){
323
+ var value = _step1.value;
324
+ headers.append(key, value);
325
+ }
326
+ } catch (err) {
327
+ _didIteratorError1 = true;
328
+ _iteratorError1 = err;
329
+ } finally{
330
+ try {
331
+ if (!_iteratorNormalCompletion1 && _iterator1.return != null) {
332
+ _iterator1.return();
333
+ }
334
+ } finally{
335
+ if (_didIteratorError1) {
336
+ throw _iteratorError1;
337
+ }
338
+ }
339
+ }
340
+ } else {
341
+ headers.set(key, values);
342
+ }
343
+ }
344
+ }
345
+ } catch (err) {
346
+ _didIteratorError = true;
347
+ _iteratorError = err;
348
+ } finally{
349
+ try {
350
+ if (!_iteratorNormalCompletion && _iterator.return != null) {
351
+ _iterator.return();
352
+ }
353
+ } finally{
354
+ if (_didIteratorError) {
355
+ throw _iteratorError;
356
+ }
357
+ }
358
+ }
359
+ return headers;
360
+ };
361
+ var createLoaderRequest = function(context) {
362
+ var origin = "".concat(context.protocol, "://").concat(context.host);
363
+ var url = new URL(context.url, origin);
364
+ var controller = new AbortController();
365
+ var init = {
366
+ method: context.method,
367
+ headers: createLoaderHeaders(context.headers),
368
+ signal: controller.signal
369
+ };
370
+ return new Request(url.href, init);
371
+ };
372
+ var sendLoaderResponse = function() {
373
+ var _ref = _asyncToGenerator(function(res, nodeResponse) {
374
+ var _iteratorNormalCompletion, _didIteratorError, _iteratorError, _iterator, _step, _step_value, key, value;
375
+ return __generator(this, function(_state) {
376
+ switch(_state.label){
377
+ case 0:
378
+ res.statusMessage = nodeResponse.statusText;
379
+ res.statusCode = nodeResponse.status;
380
+ _iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = undefined;
381
+ try {
382
+ for(_iterator = nodeResponse.headers.entries()[Symbol.iterator](); !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true){
383
+ _step_value = _slicedToArray(_step.value, 2), key = _step_value[0], value = _step_value[1];
384
+ res.setHeader(key, value);
385
+ }
386
+ } catch (err) {
387
+ _didIteratorError = true;
388
+ _iteratorError = err;
389
+ } finally{
390
+ try {
391
+ if (!_iteratorNormalCompletion && _iterator.return != null) {
392
+ _iterator.return();
393
+ }
394
+ } finally{
395
+ if (_didIteratorError) {
396
+ throw _iteratorError;
397
+ }
398
+ }
399
+ }
400
+ if (!nodeResponse.body) return [
401
+ 3,
402
+ 2
403
+ ];
404
+ return [
405
+ 4,
406
+ writeReadableStreamToWritable(nodeResponse.body, res)
407
+ ];
408
+ case 1:
409
+ _state.sent();
410
+ return [
411
+ 3,
412
+ 3
413
+ ];
414
+ case 2:
415
+ res.end();
416
+ _state.label = 3;
417
+ case 3:
418
+ return [
419
+ 2
420
+ ];
421
+ }
422
+ });
423
+ });
424
+ return function sendLoaderResponse(res, nodeResponse) {
425
+ return _ref.apply(this, arguments);
426
+ };
427
+ }();
428
+ var getPathWithoutEntry = function(pathname, entryPath) {
429
+ if (entryPath === "/") {
430
+ return pathname;
431
+ }
432
+ return pathname.replace(entryPath, "");
433
+ };
434
+ var matchEntry = function(pathname, entries) {
435
+ return entries.find(function(entry) {
436
+ return pathname.startsWith(entry.urlPath);
437
+ });
438
+ };
439
+ var handleRequest = function() {
440
+ var _ref = _asyncToGenerator(function(param) {
441
+ var context, serverRoutes, distDir, method, query, routeId, entry, routesPath, routes, res, pathname, matches, match, request, response, headers, error, message;
442
+ return __generator(this, function(_state) {
443
+ switch(_state.label){
444
+ case 0:
445
+ context = param.context, serverRoutes = param.serverRoutes, distDir = param.distDir;
446
+ method = context.method, query = context.query;
447
+ routeId = query[LOADER_ID_PARAM];
448
+ if (!routeId || method.toLowerCase() !== "get") {
449
+ return [
450
+ 2
451
+ ];
452
+ }
453
+ entry = matchEntry(context.path, serverRoutes);
454
+ if (!entry) {
455
+ return [
456
+ 2
457
+ ];
458
+ }
459
+ routesPath = path.join(distDir, SERVER_BUNDLE_DIRECTORY, "".concat(entry.entryName || MAIN_ENTRY_NAME, "-server-loaders"));
460
+ return [
461
+ 4,
462
+ import(routesPath)
463
+ ];
464
+ case 1:
465
+ routes = _state.sent().routes;
466
+ if (!routes) {
467
+ return [
468
+ 2
469
+ ];
470
+ }
471
+ res = context.res;
472
+ pathname = getPathWithoutEntry(context.path, entry.urlPath);
473
+ matches = matchRoutes(routes, pathname);
474
+ if (!matches) {
475
+ res.statusCode = 403;
476
+ res.end("Route ".concat(pathname, " was not matched"));
477
+ return [
478
+ 2
479
+ ];
480
+ }
481
+ match = matches === null || matches === void 0 ? void 0 : matches.find(function(match2) {
482
+ return match2.route.id === routeId;
483
+ });
484
+ if (!match) {
485
+ res.statusCode = 403;
486
+ res.end("Route ".concat(routeId, " does not match URL ").concat(context.path));
487
+ return [
488
+ 2
489
+ ];
490
+ }
491
+ request = createLoaderRequest(context);
492
+ _state.label = 2;
493
+ case 2:
494
+ _state.trys.push([
495
+ 2,
496
+ 4,
497
+ ,
498
+ 5
499
+ ]);
500
+ return [
501
+ 4,
502
+ callRouteLoader({
503
+ loader: match.route.loader,
504
+ routeId: match.route.id,
505
+ params: match.params,
506
+ request: request,
507
+ loadContext: {}
508
+ })
509
+ ];
510
+ case 3:
511
+ response = _state.sent();
512
+ if (isRedirectResponse(response)) {
513
+ headers = new Headers(response.headers);
514
+ headers.set("X-Modernjs-Redirect", headers.get("Location"));
515
+ headers.delete("Location");
516
+ response = new NodeResponse(null, {
517
+ status: 204,
518
+ headers: headers
519
+ });
520
+ }
521
+ return [
522
+ 3,
523
+ 5
524
+ ];
525
+ case 4:
526
+ error = _state.sent();
527
+ message = String(error);
528
+ response = new NodeResponse(message, {
529
+ status: 500,
530
+ headers: {
531
+ "Content-Type": "text/plain"
532
+ }
533
+ });
534
+ return [
535
+ 3,
536
+ 5
537
+ ];
538
+ case 5:
539
+ sendLoaderResponse(res, response);
540
+ return [
541
+ 2
542
+ ];
543
+ }
544
+ });
545
+ });
546
+ return function handleRequest(_) {
547
+ return _ref.apply(this, arguments);
548
+ };
549
+ }();
128
550
  var server_default = function() {
129
551
  return {
130
552
  name: "@modern-js/plugin-data-loader",
@@ -134,34 +556,15 @@ var server_default = function() {
134
556
  var serverRoutes = param.serverRoutes, distDir = param.distDir;
135
557
  return function() {
136
558
  var _ref = _asyncToGenerator(function(context) {
137
- var entry, routesPath, _ref, routes, handleRequest;
138
559
  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
- }
560
+ return [
561
+ 2,
562
+ handleRequest({
563
+ serverRoutes: serverRoutes,
564
+ distDir: distDir,
565
+ context: context
566
+ })
567
+ ];
165
568
  });
166
569
  });
167
570
  return function(context) {
@@ -173,4 +576,4 @@ var server_default = function() {
173
576
  }
174
577
  };
175
578
  };
176
- export { server_default as default };
579
+ export { server_default as default, getPathWithoutEntry, handleRequest, isRedirectResponse, isResponse };
@@ -1,7 +1,6 @@
1
1
  import { compile } from "path-to-regexp";
2
2
  import { redirect } from "react-router-dom";
3
3
  import { LOADER_ID_PARAM, DIRECT_PARAM } from "../common/constants";
4
- import { parseDeferredReadableStream } from "./data";
5
4
  const getRequestUrl = ({
6
5
  params,
7
6
  request,
@@ -21,14 +20,7 @@ const handleRedirectResponse = (res) => {
21
20
  const { headers } = res;
22
21
  const location = headers.get("X-Modernjs-Redirect");
23
22
  if (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);
23
+ return redirect(location);
32
24
  }
33
25
  return res;
34
26
  };
@@ -38,17 +30,14 @@ const createRequest = (routeId, method = "get") => {
38
30
  request
39
31
  }) => {
40
32
  const url = getRequestUrl({ params, request, routeId });
41
- let res;
42
- res = await fetch(url, {
33
+ const res = await fetch(url, {
43
34
  method,
44
35
  signal: request.signal
45
36
  });
46
37
  if (!res.ok) {
47
38
  throw res;
48
39
  }
49
- res = handleRedirectResponse(res);
50
- res = await handleDeferredResponse(res);
51
- return res;
40
+ return handleRedirectResponse(res);
52
41
  };
53
42
  };
54
43
  export {
@@ -6,6 +6,9 @@ async function loader(source) {
6
6
  if (target === "node") {
7
7
  return source;
8
8
  }
9
+ if (target === "webworker") {
10
+ return source;
11
+ }
9
12
  const options = this.getOptions();
10
13
  const code = generateClient({
11
14
  mapFile: options.mapFile,