react-server-dom-parcel 19.2.1 → 19.2.3

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.
@@ -425,13 +425,23 @@
425
425
  pendingParts--;
426
426
  }
427
427
  }
428
+ parentReference = writtenObjects.get(value);
428
429
  if ("function" === typeof value.then) {
430
+ if (void 0 !== parentReference)
431
+ if (modelRoot === value) modelRoot = null;
432
+ else return parentReference;
429
433
  null === formData && (formData = new FormData());
430
434
  pendingParts++;
431
435
  var promiseId = nextPartId++;
436
+ key = "$@" + promiseId.toString(16);
437
+ writtenObjects.set(value, key);
432
438
  value.then(function (partValue) {
433
439
  try {
434
- var _partJSON3 = serializeModel(partValue, promiseId);
440
+ var previousReference = writtenObjects.get(partValue);
441
+ var _partJSON3 =
442
+ void 0 !== previousReference
443
+ ? JSON.stringify(previousReference)
444
+ : serializeModel(partValue, promiseId);
435
445
  partValue = formData;
436
446
  partValue.append(formFieldPrefix + promiseId, _partJSON3);
437
447
  pendingParts--;
@@ -440,9 +450,8 @@
440
450
  reject(reason);
441
451
  }
442
452
  }, reject);
443
- return "$@" + promiseId.toString(16);
453
+ return key;
444
454
  }
445
- parentReference = writtenObjects.get(value);
446
455
  if (void 0 !== parentReference)
447
456
  if (modelRoot === value) modelRoot = null;
448
457
  else return parentReference;
@@ -600,7 +609,7 @@
600
609
  null === formData && (formData = new FormData()),
601
610
  (parentReference = nextPartId++),
602
611
  formData.set(formFieldPrefix + parentReference, key),
603
- "$F" + parentReference.toString(16)
612
+ "$h" + parentReference.toString(16)
604
613
  );
605
614
  if (
606
615
  void 0 !== temporaryReferences &&
@@ -1617,13 +1626,24 @@
1617
1626
  var listener = resolveListeners[i];
1618
1627
  if ("function" !== typeof listener) {
1619
1628
  var cyclicHandler = resolveBlockedCycle(chunk, listener);
1620
- null !== cyclicHandler &&
1621
- (fulfillReference(listener, cyclicHandler.value, chunk),
1622
- resolveListeners.splice(i, 1),
1623
- i--,
1624
- null !== rejectListeners &&
1625
- ((listener = rejectListeners.indexOf(listener)),
1626
- -1 !== listener && rejectListeners.splice(listener, 1)));
1629
+ if (null !== cyclicHandler)
1630
+ switch (
1631
+ (fulfillReference(listener, cyclicHandler.value, chunk),
1632
+ resolveListeners.splice(i, 1),
1633
+ i--,
1634
+ null !== rejectListeners &&
1635
+ ((listener = rejectListeners.indexOf(listener)),
1636
+ -1 !== listener && rejectListeners.splice(listener, 1)),
1637
+ chunk.status)
1638
+ ) {
1639
+ case "fulfilled":
1640
+ wakeChunk(resolveListeners, chunk.value, chunk);
1641
+ return;
1642
+ case "rejected":
1643
+ null !== rejectListeners &&
1644
+ rejectChunk(rejectListeners, chunk.reason);
1645
+ return;
1646
+ }
1627
1647
  }
1628
1648
  }
1629
1649
  case "pending":
@@ -1713,6 +1733,7 @@
1713
1733
  var rejectListeners = chunk.reason;
1714
1734
  chunk.status = "resolved_module";
1715
1735
  chunk.value = value;
1736
+ chunk.reason = null;
1716
1737
  null !== response &&
1717
1738
  (initializeModuleChunk(chunk),
1718
1739
  wakeChunkIfInitialized(chunk, response, rejectListeners));
@@ -1834,8 +1855,11 @@
1834
1855
  response._closed = !0;
1835
1856
  response._closedReason = error;
1836
1857
  response._chunks.forEach(function (chunk) {
1837
- "pending" === chunk.status &&
1838
- triggerErrorOnChunk(response, chunk, error);
1858
+ "pending" === chunk.status
1859
+ ? triggerErrorOnChunk(response, chunk, error)
1860
+ : "fulfilled" === chunk.status &&
1861
+ null !== chunk.reason &&
1862
+ chunk.reason.error(error);
1839
1863
  });
1840
1864
  weakResponse = response._debugChannel;
1841
1865
  void 0 !== weakResponse &&
@@ -1940,122 +1964,129 @@
1940
1964
  return chunk;
1941
1965
  }
1942
1966
  function fulfillReference(reference, value, fulfilledChunk) {
1943
- for (
1944
- var response = reference.response,
1945
- handler = reference.handler,
1946
- parentObject = reference.parentObject,
1947
- key = reference.key,
1948
- map = reference.map,
1949
- path = reference.path,
1950
- i = 1;
1951
- i < path.length;
1952
- i++
1953
- ) {
1967
+ var response = reference.response,
1968
+ handler = reference.handler,
1969
+ parentObject = reference.parentObject,
1970
+ key = reference.key,
1971
+ map = reference.map,
1972
+ path = reference.path;
1973
+ try {
1974
+ for (var i = 1; i < path.length; i++) {
1975
+ for (
1976
+ ;
1977
+ "object" === typeof value &&
1978
+ null !== value &&
1979
+ value.$$typeof === REACT_LAZY_TYPE;
1980
+
1981
+ ) {
1982
+ var referencedChunk = value._payload;
1983
+ if (referencedChunk === handler.chunk) value = handler.value;
1984
+ else {
1985
+ switch (referencedChunk.status) {
1986
+ case "resolved_model":
1987
+ initializeModelChunk(referencedChunk);
1988
+ break;
1989
+ case "resolved_module":
1990
+ initializeModuleChunk(referencedChunk);
1991
+ }
1992
+ switch (referencedChunk.status) {
1993
+ case "fulfilled":
1994
+ value = referencedChunk.value;
1995
+ continue;
1996
+ case "blocked":
1997
+ var cyclicHandler = resolveBlockedCycle(
1998
+ referencedChunk,
1999
+ reference
2000
+ );
2001
+ if (null !== cyclicHandler) {
2002
+ value = cyclicHandler.value;
2003
+ continue;
2004
+ }
2005
+ case "pending":
2006
+ path.splice(0, i - 1);
2007
+ null === referencedChunk.value
2008
+ ? (referencedChunk.value = [reference])
2009
+ : referencedChunk.value.push(reference);
2010
+ null === referencedChunk.reason
2011
+ ? (referencedChunk.reason = [reference])
2012
+ : referencedChunk.reason.push(reference);
2013
+ return;
2014
+ case "halted":
2015
+ return;
2016
+ default:
2017
+ rejectReference(reference, referencedChunk.reason);
2018
+ return;
2019
+ }
2020
+ }
2021
+ }
2022
+ value = value[path[i]];
2023
+ }
1954
2024
  for (
1955
2025
  ;
1956
2026
  "object" === typeof value &&
1957
2027
  null !== value &&
1958
2028
  value.$$typeof === REACT_LAZY_TYPE;
1959
2029
 
1960
- )
1961
- if (((value = value._payload), value === handler.chunk))
1962
- value = handler.value;
2030
+ ) {
2031
+ var _referencedChunk = value._payload;
2032
+ if (_referencedChunk === handler.chunk) value = handler.value;
1963
2033
  else {
1964
- switch (value.status) {
2034
+ switch (_referencedChunk.status) {
1965
2035
  case "resolved_model":
1966
- initializeModelChunk(value);
2036
+ initializeModelChunk(_referencedChunk);
1967
2037
  break;
1968
2038
  case "resolved_module":
1969
- initializeModuleChunk(value);
2039
+ initializeModuleChunk(_referencedChunk);
1970
2040
  }
1971
- switch (value.status) {
2041
+ switch (_referencedChunk.status) {
1972
2042
  case "fulfilled":
1973
- value = value.value;
2043
+ value = _referencedChunk.value;
1974
2044
  continue;
1975
- case "blocked":
1976
- var cyclicHandler = resolveBlockedCycle(value, reference);
1977
- if (null !== cyclicHandler) {
1978
- value = cyclicHandler.value;
1979
- continue;
1980
- }
1981
- case "pending":
1982
- path.splice(0, i - 1);
1983
- null === value.value
1984
- ? (value.value = [reference])
1985
- : value.value.push(reference);
1986
- null === value.reason
1987
- ? (value.reason = [reference])
1988
- : value.reason.push(reference);
1989
- return;
1990
- case "halted":
1991
- return;
1992
- default:
1993
- rejectReference(reference, value.reason);
1994
- return;
1995
2045
  }
2046
+ break;
1996
2047
  }
1997
- value = value[path[i]];
1998
- }
1999
- for (
2000
- ;
2001
- "object" === typeof value &&
2002
- null !== value &&
2003
- value.$$typeof === REACT_LAZY_TYPE;
2004
-
2005
- )
2006
- if (((path = value._payload), path === handler.chunk))
2007
- value = handler.value;
2008
- else {
2009
- switch (path.status) {
2010
- case "resolved_model":
2011
- initializeModelChunk(path);
2048
+ }
2049
+ var mappedValue = map(response, value, parentObject, key);
2050
+ parentObject[key] = mappedValue;
2051
+ "" === key && null === handler.value && (handler.value = mappedValue);
2052
+ if (
2053
+ parentObject[0] === REACT_ELEMENT_TYPE &&
2054
+ "object" === typeof handler.value &&
2055
+ null !== handler.value &&
2056
+ handler.value.$$typeof === REACT_ELEMENT_TYPE
2057
+ ) {
2058
+ var element = handler.value;
2059
+ switch (key) {
2060
+ case "3":
2061
+ transferReferencedDebugInfo(handler.chunk, fulfilledChunk);
2062
+ element.props = mappedValue;
2012
2063
  break;
2013
- case "resolved_module":
2014
- initializeModuleChunk(path);
2015
- }
2016
- switch (path.status) {
2017
- case "fulfilled":
2018
- value = path.value;
2019
- continue;
2064
+ case "4":
2065
+ element._owner = mappedValue;
2066
+ break;
2067
+ case "5":
2068
+ element._debugStack = mappedValue;
2069
+ break;
2070
+ default:
2071
+ transferReferencedDebugInfo(handler.chunk, fulfilledChunk);
2020
2072
  }
2021
- break;
2022
- }
2023
- response = map(response, value, parentObject, key);
2024
- parentObject[key] = response;
2025
- "" === key && null === handler.value && (handler.value = response);
2026
- if (
2027
- parentObject[0] === REACT_ELEMENT_TYPE &&
2028
- "object" === typeof handler.value &&
2029
- null !== handler.value &&
2030
- handler.value.$$typeof === REACT_ELEMENT_TYPE
2031
- )
2032
- switch (((reference = handler.value), key)) {
2033
- case "3":
2034
- transferReferencedDebugInfo(handler.chunk, fulfilledChunk);
2035
- reference.props = response;
2036
- break;
2037
- case "4":
2038
- reference._owner = response;
2039
- break;
2040
- case "5":
2041
- reference._debugStack = response;
2042
- break;
2043
- default:
2073
+ } else
2074
+ reference.isDebug ||
2044
2075
  transferReferencedDebugInfo(handler.chunk, fulfilledChunk);
2045
- }
2046
- else
2047
- reference.isDebug ||
2048
- transferReferencedDebugInfo(handler.chunk, fulfilledChunk);
2076
+ } catch (error) {
2077
+ rejectReference(reference, error);
2078
+ return;
2079
+ }
2049
2080
  handler.deps--;
2050
2081
  0 === handler.deps &&
2051
- ((fulfilledChunk = handler.chunk),
2052
- null !== fulfilledChunk &&
2053
- "blocked" === fulfilledChunk.status &&
2054
- ((key = fulfilledChunk.value),
2055
- (fulfilledChunk.status = "fulfilled"),
2056
- (fulfilledChunk.value = handler.value),
2057
- (fulfilledChunk.reason = handler.reason),
2058
- null !== key && wakeChunk(key, handler.value, fulfilledChunk)));
2082
+ ((reference = handler.chunk),
2083
+ null !== reference &&
2084
+ "blocked" === reference.status &&
2085
+ ((value = reference.value),
2086
+ (reference.status = "fulfilled"),
2087
+ (reference.value = handler.value),
2088
+ (reference.reason = handler.reason),
2089
+ null !== value && wakeChunk(value, handler.value, reference)));
2059
2090
  }
2060
2091
  function rejectReference(reference, error) {
2061
2092
  var handler = reference.handler;
@@ -2211,6 +2242,7 @@
2211
2242
  ((boundArgs = resolvedValue.value),
2212
2243
  (resolvedValue.status = "fulfilled"),
2213
2244
  (resolvedValue.value = handler.value),
2245
+ (resolvedValue.reason = null),
2214
2246
  null !== boundArgs &&
2215
2247
  wakeChunk(boundArgs, handler.value, resolvedValue)));
2216
2248
  },
@@ -2530,7 +2562,7 @@
2530
2562
  );
2531
2563
  case "S":
2532
2564
  return Symbol.for(value.slice(2));
2533
- case "F":
2565
+ case "h":
2534
2566
  var ref = value.slice(2);
2535
2567
  return getOutlinedModel(
2536
2568
  response,
@@ -2879,7 +2911,8 @@
2879
2911
  chunks.set(id, response);
2880
2912
  }
2881
2913
  function startReadableStream(response, id, type, streamState) {
2882
- var controller = null;
2914
+ var controller = null,
2915
+ closed = !1;
2883
2916
  type = new ReadableStream({
2884
2917
  type: type,
2885
2918
  start: function (c) {
@@ -2934,24 +2967,28 @@
2934
2967
  }
2935
2968
  },
2936
2969
  close: function () {
2937
- if (null === previousBlockedChunk) controller.close();
2938
- else {
2939
- var blockedChunk = previousBlockedChunk;
2940
- previousBlockedChunk = null;
2941
- blockedChunk.then(function () {
2942
- return controller.close();
2943
- });
2944
- }
2970
+ if (!closed)
2971
+ if (((closed = !0), null === previousBlockedChunk))
2972
+ controller.close();
2973
+ else {
2974
+ var blockedChunk = previousBlockedChunk;
2975
+ previousBlockedChunk = null;
2976
+ blockedChunk.then(function () {
2977
+ return controller.close();
2978
+ });
2979
+ }
2945
2980
  },
2946
2981
  error: function (error) {
2947
- if (null === previousBlockedChunk) controller.error(error);
2948
- else {
2949
- var blockedChunk = previousBlockedChunk;
2950
- previousBlockedChunk = null;
2951
- blockedChunk.then(function () {
2952
- return controller.error(error);
2953
- });
2954
- }
2982
+ if (!closed)
2983
+ if (((closed = !0), null === previousBlockedChunk))
2984
+ controller.error(error);
2985
+ else {
2986
+ var blockedChunk = previousBlockedChunk;
2987
+ previousBlockedChunk = null;
2988
+ blockedChunk.then(function () {
2989
+ return controller.error(error);
2990
+ });
2991
+ }
2955
2992
  }
2956
2993
  },
2957
2994
  streamState
@@ -3007,6 +3044,7 @@
3007
3044
  rejectListeners = chunk.reason;
3008
3045
  chunk.status = "fulfilled";
3009
3046
  chunk.value = { done: !1, value: value };
3047
+ chunk.reason = null;
3010
3048
  null !== resolveListeners &&
3011
3049
  wakeChunkIfInitialized(
3012
3050
  chunk,
@@ -3032,36 +3070,39 @@
3032
3070
  nextWriteIndex++;
3033
3071
  },
3034
3072
  close: function (value) {
3035
- closed = !0;
3036
- nextWriteIndex === buffer.length
3037
- ? (buffer[nextWriteIndex] = createResolvedIteratorResultChunk(
3038
- response,
3039
- value,
3040
- !0
3041
- ))
3042
- : resolveIteratorResultChunk(
3073
+ if (!closed)
3074
+ for (
3075
+ closed = !0,
3076
+ nextWriteIndex === buffer.length
3077
+ ? (buffer[nextWriteIndex] =
3078
+ createResolvedIteratorResultChunk(response, value, !0))
3079
+ : resolveIteratorResultChunk(
3080
+ response,
3081
+ buffer[nextWriteIndex],
3082
+ value,
3083
+ !0
3084
+ ),
3085
+ nextWriteIndex++;
3086
+ nextWriteIndex < buffer.length;
3087
+
3088
+ )
3089
+ resolveIteratorResultChunk(
3043
3090
  response,
3044
- buffer[nextWriteIndex],
3045
- value,
3091
+ buffer[nextWriteIndex++],
3092
+ '"$undefined"',
3046
3093
  !0
3047
3094
  );
3048
- for (nextWriteIndex++; nextWriteIndex < buffer.length; )
3049
- resolveIteratorResultChunk(
3050
- response,
3051
- buffer[nextWriteIndex++],
3052
- '"$undefined"',
3053
- !0
3054
- );
3055
3095
  },
3056
3096
  error: function (error) {
3057
- closed = !0;
3058
- for (
3059
- nextWriteIndex === buffer.length &&
3060
- (buffer[nextWriteIndex] = createPendingChunk(response));
3061
- nextWriteIndex < buffer.length;
3097
+ if (!closed)
3098
+ for (
3099
+ closed = !0,
3100
+ nextWriteIndex === buffer.length &&
3101
+ (buffer[nextWriteIndex] = createPendingChunk(response));
3102
+ nextWriteIndex < buffer.length;
3062
3103
 
3063
- )
3064
- triggerErrorOnChunk(response, buffer[nextWriteIndex++], error);
3104
+ )
3105
+ triggerErrorOnChunk(response, buffer[nextWriteIndex++], error);
3065
3106
  }
3066
3107
  },
3067
3108
  streamState