bun-framework-react
Version:
React framework integration with RSC, for the Bun Rendering API
1,448 lines (1,446 loc) • 94.1 kB
JavaScript
/**
* @license React
* react-server-dom-bun-server.node.production.js
*
* Copyright (c) Meta Platforms, Inc. and affiliates.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*/
"use strict";
var stream = require("stream"),
ReactDOM = require("react-dom"),
React = require("react"),
util = require("util");
require("crypto");
var REACT_LEGACY_ELEMENT_TYPE = Symbol.for("react.element"),
REACT_ELEMENT_TYPE = Symbol.for("react.transitional.element"),
REACT_FRAGMENT_TYPE = Symbol.for("react.fragment"),
REACT_CONTEXT_TYPE = Symbol.for("react.context"),
REACT_FORWARD_REF_TYPE = Symbol.for("react.forward_ref"),
REACT_SUSPENSE_TYPE = Symbol.for("react.suspense"),
REACT_SUSPENSE_LIST_TYPE = Symbol.for("react.suspense_list"),
REACT_MEMO_TYPE = Symbol.for("react.memo"),
REACT_LAZY_TYPE = Symbol.for("react.lazy"),
REACT_MEMO_CACHE_SENTINEL = Symbol.for("react.memo_cache_sentinel");
Symbol.for("react.postpone");
var MAYBE_ITERATOR_SYMBOL = Symbol.iterator;
function getIteratorFn(maybeIterable) {
if (null === maybeIterable || "object" !== typeof maybeIterable) return null;
maybeIterable =
(MAYBE_ITERATOR_SYMBOL && maybeIterable[MAYBE_ITERATOR_SYMBOL]) ||
maybeIterable["@@iterator"];
return "function" === typeof maybeIterable ? maybeIterable : null;
}
var ASYNC_ITERATOR = Symbol.asyncIterator,
scheduleMicrotask = queueMicrotask;
function byteLengthOfChunk(chunk) {
return Buffer.byteLength(chunk, "utf8");
}
function closeWithError(destination, error) {
"function" === typeof destination.error
? destination.error(error)
: destination.close();
}
var CLIENT_REFERENCE_TAG$1 = Symbol.for("react.client.reference"),
SERVER_REFERENCE_TAG = Symbol.for("react.server.reference");
function registerClientReferenceImpl(proxyImplementation, id, async) {
return Object.defineProperties(proxyImplementation, {
$$typeof: { value: CLIENT_REFERENCE_TAG$1 },
$$id: { value: id },
$$async: { value: async }
});
}
var FunctionBind = Function.prototype.bind,
ArraySlice = Array.prototype.slice;
function bind() {
var newFn = FunctionBind.apply(this, arguments);
if (this.$$typeof === SERVER_REFERENCE_TAG) {
var args = ArraySlice.call(arguments, 1),
$$typeof = { value: SERVER_REFERENCE_TAG },
$$id = { value: this.$$id };
args = { value: this.$$bound ? this.$$bound.concat(args) : args };
return Object.defineProperties(newFn, {
$$typeof: $$typeof,
$$id: $$id,
$$bound: args,
$$location: this.$$location
? { value: this.$$location }
: { value: void 0 },
bind: { value: bind, configurable: !0 }
});
}
return newFn;
}
var ReactDOMSharedInternals =
ReactDOM.__DOM_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE,
previousDispatcher = ReactDOMSharedInternals.d;
ReactDOMSharedInternals.d = {
f: previousDispatcher.f,
r: previousDispatcher.r,
D: prefetchDNS,
C: preconnect,
L: preload,
m: preloadModule$1,
X: preinitScript,
S: preinitStyle,
M: preinitModuleScript
};
function prefetchDNS(href) {
if ("string" === typeof href && href) {
var request = currentRequest ? currentRequest : null;
if (request) {
var hints = request.hints,
key = "D|" + href;
hints.has(key) || (hints.add(key), emitHint(request, "D", href));
} else previousDispatcher.D(href);
}
}
function preconnect(href, crossOrigin) {
if ("string" === typeof href) {
var request = currentRequest ? currentRequest : null;
if (request) {
var hints = request.hints,
key = "C|" + (null == crossOrigin ? "null" : crossOrigin) + "|" + href;
hints.has(key) ||
(hints.add(key),
"string" === typeof crossOrigin
? emitHint(request, "C", [href, crossOrigin])
: emitHint(request, "C", href));
} else previousDispatcher.C(href, crossOrigin);
}
}
function preload(href, as, options) {
if ("string" === typeof href) {
var request = currentRequest ? currentRequest : null;
if (request) {
var hints = request.hints,
key = "L";
if ("image" === as && options) {
var imageSrcSet = options.imageSrcSet,
imageSizes = options.imageSizes,
uniquePart = "";
"string" === typeof imageSrcSet && "" !== imageSrcSet
? ((uniquePart += "[" + imageSrcSet + "]"),
"string" === typeof imageSizes &&
(uniquePart += "[" + imageSizes + "]"))
: (uniquePart += "[][]" + href);
key += "[image]" + uniquePart;
} else key += "[" + as + "]" + href;
hints.has(key) ||
(hints.add(key),
(options = trimOptions(options))
? emitHint(request, "L", [href, as, options])
: emitHint(request, "L", [href, as]));
} else previousDispatcher.L(href, as, options);
}
}
function preloadModule$1(href, options) {
if ("string" === typeof href) {
var request = currentRequest ? currentRequest : null;
if (request) {
var hints = request.hints,
key = "m|" + href;
if (hints.has(key)) return;
hints.add(key);
return (options = trimOptions(options))
? emitHint(request, "m", [href, options])
: emitHint(request, "m", href);
}
previousDispatcher.m(href, options);
}
}
function preinitStyle(href, precedence, options) {
if ("string" === typeof href) {
var request = currentRequest ? currentRequest : null;
if (request) {
var hints = request.hints,
key = "S|" + href;
if (hints.has(key)) return;
hints.add(key);
return (options = trimOptions(options))
? emitHint(request, "S", [
href,
"string" === typeof precedence ? precedence : 0,
options
])
: "string" === typeof precedence
? emitHint(request, "S", [href, precedence])
: emitHint(request, "S", href);
}
previousDispatcher.S(href, precedence, options);
}
}
function preinitScript(src, options) {
if ("string" === typeof src) {
var request = currentRequest ? currentRequest : null;
if (request) {
var hints = request.hints,
key = "X|" + src;
if (hints.has(key)) return;
hints.add(key);
return (options = trimOptions(options))
? emitHint(request, "X", [src, options])
: emitHint(request, "X", src);
}
previousDispatcher.X(src, options);
}
}
function preinitModuleScript(src, options) {
if ("string" === typeof src) {
var request = currentRequest ? currentRequest : null;
if (request) {
var hints = request.hints,
key = "M|" + src;
if (hints.has(key)) return;
hints.add(key);
return (options = trimOptions(options))
? emitHint(request, "M", [src, options])
: emitHint(request, "M", src);
}
previousDispatcher.M(src, options);
}
}
function trimOptions(options) {
if (null == options) return null;
var hasProperties = !1,
trimmed = {},
key;
for (key in options)
null != options[key] &&
((hasProperties = !0), (trimmed[key] = options[key]));
return hasProperties ? trimmed : null;
}
var TEMPORARY_REFERENCE_TAG = Symbol.for("react.temporary.reference"),
proxyHandlers = {
get: function (target, name) {
switch (name) {
case "$$typeof":
return target.$$typeof;
case "name":
return;
case "displayName":
return;
case "defaultProps":
return;
case "_debugInfo":
return;
case "toJSON":
return;
case Symbol.toPrimitive:
return Object.prototype[Symbol.toPrimitive];
case Symbol.toStringTag:
return Object.prototype[Symbol.toStringTag];
case "Provider":
throw Error(
"Cannot render a Client Context Provider on the Server. Instead, you can export a Client Component wrapper that itself renders a Client Context Provider."
);
case "then":
return;
}
throw Error(
"Cannot access " +
String(name) +
" on the server. You cannot dot into a temporary client reference from a server component. You can only pass the value through to the client."
);
},
set: function () {
throw Error(
"Cannot assign to a temporary client reference from a server module."
);
}
};
function createTemporaryReference(temporaryReferences, id) {
var reference = Object.defineProperties(
function () {
throw Error(
"Attempted to call a temporary Client Reference from the server but it is on the client. It's not possible to invoke a client function from the server, it can only be rendered as a Component or passed to props of a Client Component."
);
},
{ $$typeof: { value: TEMPORARY_REFERENCE_TAG } }
);
reference = new Proxy(reference, proxyHandlers);
temporaryReferences.set(reference, id);
return reference;
}
function noop() {}
var SuspenseException = Error(
"Suspense Exception: This is not a real error! It's an implementation detail of `use` to interrupt the current render. You must either rethrow it immediately, or move the `use` call outside of the `try/catch` block. Capturing without rethrowing will lead to unexpected behavior.\n\nTo handle async errors, wrap your component in an error boundary, or call the promise's `.catch` method and pass the result to `use`."
);
function trackUsedThenable(thenableState, thenable, index) {
index = thenableState[index];
void 0 === index
? thenableState.push(thenable)
: index !== thenable && (thenable.then(noop, noop), (thenable = index));
switch (thenable.status) {
case "fulfilled":
return thenable.value;
case "rejected":
throw thenable.reason;
default:
"string" === typeof thenable.status
? thenable.then(noop, noop)
: ((thenableState = thenable),
(thenableState.status = "pending"),
thenableState.then(
function (fulfilledValue) {
if ("pending" === thenable.status) {
var fulfilledThenable = thenable;
fulfilledThenable.status = "fulfilled";
fulfilledThenable.value = fulfilledValue;
}
},
function (error) {
if ("pending" === thenable.status) {
var rejectedThenable = thenable;
rejectedThenable.status = "rejected";
rejectedThenable.reason = error;
}
}
));
switch (thenable.status) {
case "fulfilled":
return thenable.value;
case "rejected":
throw thenable.reason;
}
suspendedThenable = thenable;
throw SuspenseException;
}
}
var suspendedThenable = null;
function getSuspendedThenable() {
if (null === suspendedThenable)
throw Error(
"Expected a suspended thenable. This is a bug in React. Please file an issue."
);
var thenable = suspendedThenable;
suspendedThenable = null;
return thenable;
}
var currentRequest$1 = null,
thenableIndexCounter = 0,
thenableState = null;
function getThenableStateAfterSuspending() {
var state = thenableState || [];
thenableState = null;
return state;
}
var HooksDispatcher = {
readContext: unsupportedContext,
use: use,
useCallback: function (callback) {
return callback;
},
useContext: unsupportedContext,
useEffect: unsupportedHook,
useImperativeHandle: unsupportedHook,
useLayoutEffect: unsupportedHook,
useInsertionEffect: unsupportedHook,
useMemo: function (nextCreate) {
return nextCreate();
},
useReducer: unsupportedHook,
useRef: unsupportedHook,
useState: unsupportedHook,
useDebugValue: function () {},
useDeferredValue: unsupportedHook,
useTransition: unsupportedHook,
useSyncExternalStore: unsupportedHook,
useId: useId,
useHostTransitionStatus: unsupportedHook,
useFormState: unsupportedHook,
useActionState: unsupportedHook,
useOptimistic: unsupportedHook,
useMemoCache: function (size) {
for (var data = Array(size), i = 0; i < size; i++)
data[i] = REACT_MEMO_CACHE_SENTINEL;
return data;
},
useCacheRefresh: function () {
return unsupportedRefresh;
}
};
function unsupportedHook() {
throw Error("This Hook is not supported in Server Components.");
}
function unsupportedRefresh() {
throw Error("Refreshing the cache is not supported in Server Components.");
}
function unsupportedContext() {
throw Error("Cannot read a Client Context from a Server Component.");
}
function useId() {
if (null === currentRequest$1)
throw Error("useId can only be used while React is rendering");
var id = currentRequest$1.identifierCount++;
return "_" + currentRequest$1.identifierPrefix + "S_" + id.toString(32) + "_";
}
function use(usable) {
if (
(null !== usable && "object" === typeof usable) ||
"function" === typeof usable
) {
if ("function" === typeof usable.then) {
var index = thenableIndexCounter;
thenableIndexCounter += 1;
null === thenableState && (thenableState = []);
return trackUsedThenable(thenableState, usable, index);
}
usable.$$typeof === REACT_CONTEXT_TYPE && unsupportedContext();
}
if (usable.$$typeof === CLIENT_REFERENCE_TAG$1) {
if (null != usable.value && usable.value.$$typeof === REACT_CONTEXT_TYPE)
throw Error("Cannot read a Client Context from a Server Component.");
throw Error("Cannot use() an already resolved Client Reference.");
}
throw Error("An unsupported type was passed to use(): " + String(usable));
}
var DefaultAsyncDispatcher = {
getCacheForType: function (resourceType) {
var JSCompiler_inline_result = (JSCompiler_inline_result = currentRequest
? currentRequest
: null)
? JSCompiler_inline_result.cache
: new Map();
var entry = JSCompiler_inline_result.get(resourceType);
void 0 === entry &&
((entry = resourceType()),
JSCompiler_inline_result.set(resourceType, entry));
return entry;
},
cacheSignal: function () {
var request = currentRequest ? currentRequest : null;
return request ? request.cacheController.signal : null;
}
},
ReactSharedInternalsServer =
React.__SERVER_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE;
if (!ReactSharedInternalsServer)
throw Error(
'The "react" package in this environment is not configured correctly. The "react-server" condition must be enabled in any environment that runs React Server Components.'
);
var isArrayImpl = Array.isArray,
getPrototypeOf = Object.getPrototypeOf;
function objectName(object) {
object = Object.prototype.toString.call(object);
return object.slice(8, object.length - 1);
}
function describeValueForErrorMessage(value) {
switch (typeof value) {
case "string":
return JSON.stringify(
10 >= value.length ? value : value.slice(0, 10) + "..."
);
case "object":
if (isArrayImpl(value)) return "[...]";
if (null !== value && value.$$typeof === CLIENT_REFERENCE_TAG)
return "client";
value = objectName(value);
return "Object" === value ? "{...}" : value;
case "function":
return value.$$typeof === CLIENT_REFERENCE_TAG
? "client"
: (value = value.displayName || value.name)
? "function " + value
: "function";
default:
return String(value);
}
}
function describeElementType(type) {
if ("string" === typeof type) return type;
switch (type) {
case REACT_SUSPENSE_TYPE:
return "Suspense";
case REACT_SUSPENSE_LIST_TYPE:
return "SuspenseList";
}
if ("object" === typeof type)
switch (type.$$typeof) {
case REACT_FORWARD_REF_TYPE:
return describeElementType(type.render);
case REACT_MEMO_TYPE:
return describeElementType(type.type);
case REACT_LAZY_TYPE:
var payload = type._payload;
type = type._init;
try {
return describeElementType(type(payload));
} catch (x) {}
}
return "";
}
var CLIENT_REFERENCE_TAG = Symbol.for("react.client.reference");
function describeObjectForErrorMessage(objectOrArray, expandedName) {
var objKind = objectName(objectOrArray);
if ("Object" !== objKind && "Array" !== objKind) return objKind;
objKind = -1;
var length = 0;
if (isArrayImpl(objectOrArray)) {
var str = "[";
for (var i = 0; i < objectOrArray.length; i++) {
0 < i && (str += ", ");
var value = objectOrArray[i];
value =
"object" === typeof value && null !== value
? describeObjectForErrorMessage(value)
: describeValueForErrorMessage(value);
"" + i === expandedName
? ((objKind = str.length), (length = value.length), (str += value))
: (str =
10 > value.length && 40 > str.length + value.length
? str + value
: str + "...");
}
str += "]";
} else if (objectOrArray.$$typeof === REACT_ELEMENT_TYPE)
str = "<" + describeElementType(objectOrArray.type) + "/>";
else {
if (objectOrArray.$$typeof === CLIENT_REFERENCE_TAG) return "client";
str = "{";
i = Object.keys(objectOrArray);
for (value = 0; value < i.length; value++) {
0 < value && (str += ", ");
var name = i[value],
encodedKey = JSON.stringify(name);
str += ('"' + name + '"' === encodedKey ? name : encodedKey) + ": ";
encodedKey = objectOrArray[name];
encodedKey =
"object" === typeof encodedKey && null !== encodedKey
? describeObjectForErrorMessage(encodedKey)
: describeValueForErrorMessage(encodedKey);
name === expandedName
? ((objKind = str.length),
(length = encodedKey.length),
(str += encodedKey))
: (str =
10 > encodedKey.length && 40 > str.length + encodedKey.length
? str + encodedKey
: str + "...");
}
str += "}";
}
return void 0 === expandedName
? str
: -1 < objKind && 0 < length
? ((objectOrArray = " ".repeat(objKind) + "^".repeat(length)),
"\n " + str + "\n " + objectOrArray)
: "\n " + str;
}
var hasOwnProperty = Object.prototype.hasOwnProperty,
ObjectPrototype = Object.prototype,
stringify = JSON.stringify;
function defaultErrorHandler(error) {
console.error(error);
}
function RequestInstance(
type,
model,
bundlerConfig,
onError,
onPostpone,
onAllReady,
onFatalError,
identifierPrefix,
temporaryReferences
) {
if (
null !== ReactSharedInternalsServer.A &&
ReactSharedInternalsServer.A !== DefaultAsyncDispatcher
)
throw Error("Currently React only supports one RSC renderer at a time.");
ReactSharedInternalsServer.A = DefaultAsyncDispatcher;
var abortSet = new Set(),
pingedTasks = [],
hints = new Set();
this.type = type;
this.status = 10;
this.flushScheduled = !1;
this.destination = this.fatalError = null;
this.bundlerConfig = bundlerConfig;
this.cache = new Map();
this.cacheController = new AbortController();
this.pendingChunks = this.nextChunkId = 0;
this.hints = hints;
this.abortableTasks = abortSet;
this.pingedTasks = pingedTasks;
this.completedImportChunks = [];
this.completedHintChunks = [];
this.completedRegularChunks = [];
this.completedErrorChunks = [];
this.writtenSymbols = new Map();
this.writtenClientReferences = new Map();
this.writtenServerReferences = new Map();
this.writtenObjects = new WeakMap();
this.temporaryReferences = temporaryReferences;
this.identifierPrefix = identifierPrefix || "";
this.identifierCount = 1;
this.taintCleanupQueue = [];
this.onError = void 0 === onError ? defaultErrorHandler : onError;
this.onPostpone = void 0 === onPostpone ? noop : onPostpone;
this.onAllReady = onAllReady;
this.onFatalError = onFatalError;
type = createTask(this, model, null, !1, abortSet);
pingedTasks.push(type);
}
var currentRequest = null;
function serializeThenable(request, task, thenable) {
var newTask = createTask(
request,
thenable,
task.keyPath,
task.implicitSlot,
request.abortableTasks
);
switch (thenable.status) {
case "fulfilled":
return (
(newTask.model = thenable.value), pingTask(request, newTask), newTask.id
);
case "rejected":
return erroredTask(request, newTask, thenable.reason), newTask.id;
default:
if (12 === request.status)
return (
request.abortableTasks.delete(newTask),
(task = request.fatalError),
abortTask(newTask),
finishAbortedTask(newTask, request, task),
newTask.id
);
"string" !== typeof thenable.status &&
((thenable.status = "pending"),
thenable.then(
function (fulfilledValue) {
"pending" === thenable.status &&
((thenable.status = "fulfilled"),
(thenable.value = fulfilledValue));
},
function (error) {
"pending" === thenable.status &&
((thenable.status = "rejected"), (thenable.reason = error));
}
));
}
thenable.then(
function (value) {
newTask.model = value;
pingTask(request, newTask);
},
function (reason) {
0 === newTask.status &&
(erroredTask(request, newTask, reason), enqueueFlush(request));
}
);
return newTask.id;
}
function serializeReadableStream(request, task, stream) {
function progress(entry) {
if (0 === streamTask.status)
if (entry.done)
(streamTask.status = 1),
(entry = streamTask.id.toString(16) + ":C\n"),
request.completedRegularChunks.push(entry),
request.abortableTasks.delete(streamTask),
request.cacheController.signal.removeEventListener(
"abort",
abortStream
),
enqueueFlush(request),
callOnAllReadyIfReady(request);
else
try {
(streamTask.model = entry.value),
request.pendingChunks++,
tryStreamTask(request, streamTask),
enqueueFlush(request),
reader.read().then(progress, error);
} catch (x$8) {
error(x$8);
}
}
function error(reason) {
0 === streamTask.status &&
(request.cacheController.signal.removeEventListener("abort", abortStream),
erroredTask(request, streamTask, reason),
enqueueFlush(request),
reader.cancel(reason).then(error, error));
}
function abortStream() {
if (0 === streamTask.status) {
var signal = request.cacheController.signal;
signal.removeEventListener("abort", abortStream);
signal = signal.reason;
erroredTask(request, streamTask, signal);
enqueueFlush(request);
reader.cancel(signal).then(error, error);
}
}
var supportsBYOB = stream.supportsBYOB;
if (void 0 === supportsBYOB)
try {
stream.getReader({ mode: "byob" }).releaseLock(), (supportsBYOB = !0);
} catch (x) {
supportsBYOB = !1;
}
var reader = stream.getReader(),
streamTask = createTask(
request,
task.model,
task.keyPath,
task.implicitSlot,
request.abortableTasks
);
request.pendingChunks++;
task = streamTask.id.toString(16) + ":" + (supportsBYOB ? "r" : "R") + "\n";
request.completedRegularChunks.push(task);
request.cacheController.signal.addEventListener("abort", abortStream);
reader.read().then(progress, error);
return serializeByValueID(streamTask.id);
}
function serializeAsyncIterable(request, task, iterable, iterator) {
function progress(entry) {
if (0 === streamTask.status)
if (entry.done) {
streamTask.status = 1;
if (void 0 === entry.value)
var endStreamRow = streamTask.id.toString(16) + ":C\n";
else
try {
var chunkId = outlineModel(request, entry.value);
endStreamRow =
streamTask.id.toString(16) +
":C" +
stringify(serializeByValueID(chunkId)) +
"\n";
} catch (x) {
error(x);
return;
}
request.completedRegularChunks.push(endStreamRow);
request.abortableTasks.delete(streamTask);
request.cacheController.signal.removeEventListener(
"abort",
abortIterable
);
enqueueFlush(request);
callOnAllReadyIfReady(request);
} else
try {
(streamTask.model = entry.value),
request.pendingChunks++,
tryStreamTask(request, streamTask),
enqueueFlush(request),
iterator.next().then(progress, error);
} catch (x$9) {
error(x$9);
}
}
function error(reason) {
0 === streamTask.status &&
(request.cacheController.signal.removeEventListener(
"abort",
abortIterable
),
erroredTask(request, streamTask, reason),
enqueueFlush(request),
"function" === typeof iterator.throw &&
iterator.throw(reason).then(error, error));
}
function abortIterable() {
if (0 === streamTask.status) {
var signal = request.cacheController.signal;
signal.removeEventListener("abort", abortIterable);
var reason = signal.reason;
erroredTask(request, streamTask, signal.reason);
enqueueFlush(request);
"function" === typeof iterator.throw &&
iterator.throw(reason).then(error, error);
}
}
iterable = iterable === iterator;
var streamTask = createTask(
request,
task.model,
task.keyPath,
task.implicitSlot,
request.abortableTasks
);
request.pendingChunks++;
task = streamTask.id.toString(16) + ":" + (iterable ? "x" : "X") + "\n";
request.completedRegularChunks.push(task);
request.cacheController.signal.addEventListener("abort", abortIterable);
iterator.next().then(progress, error);
return serializeByValueID(streamTask.id);
}
function emitHint(request, code, model) {
model = stringify(model);
request.completedHintChunks.push(":H" + code + model + "\n");
enqueueFlush(request);
}
function readThenable(thenable) {
if ("fulfilled" === thenable.status) return thenable.value;
if ("rejected" === thenable.status) throw thenable.reason;
throw thenable;
}
function createLazyWrapperAroundWakeable(request, task, wakeable) {
switch (wakeable.status) {
case "fulfilled":
return wakeable.value;
case "rejected":
break;
default:
"string" !== typeof wakeable.status &&
((wakeable.status = "pending"),
wakeable.then(
function (fulfilledValue) {
"pending" === wakeable.status &&
((wakeable.status = "fulfilled"),
(wakeable.value = fulfilledValue));
},
function (error) {
"pending" === wakeable.status &&
((wakeable.status = "rejected"), (wakeable.reason = error));
}
));
}
return { $$typeof: REACT_LAZY_TYPE, _payload: wakeable, _init: readThenable };
}
function voidHandler() {}
function processServerComponentReturnValue(request, task, Component, result) {
if (
"object" !== typeof result ||
null === result ||
result.$$typeof === CLIENT_REFERENCE_TAG$1
)
return result;
if ("function" === typeof result.then)
return createLazyWrapperAroundWakeable(request, task, result);
var iteratorFn = getIteratorFn(result);
return iteratorFn
? ((request = {}),
(request[Symbol.iterator] = function () {
return iteratorFn.call(result);
}),
request)
: "function" !== typeof result[ASYNC_ITERATOR] ||
("function" === typeof ReadableStream &&
result instanceof ReadableStream)
? result
: ((request = {}),
(request[ASYNC_ITERATOR] = function () {
return result[ASYNC_ITERATOR]();
}),
request);
}
function renderFunctionComponent(request, task, key, Component, props) {
var prevThenableState = task.thenableState;
task.thenableState = null;
thenableIndexCounter = 0;
thenableState = prevThenableState;
props = Component(props, void 0);
if (12 === request.status)
throw (
("object" === typeof props &&
null !== props &&
"function" === typeof props.then &&
props.$$typeof !== CLIENT_REFERENCE_TAG$1 &&
props.then(voidHandler, voidHandler),
null)
);
props = processServerComponentReturnValue(request, task, Component, props);
Component = task.keyPath;
prevThenableState = task.implicitSlot;
null !== key
? (task.keyPath = null === Component ? key : Component + "," + key)
: null === Component && (task.implicitSlot = !0);
request = renderModelDestructive(request, task, emptyRoot, "", props);
task.keyPath = Component;
task.implicitSlot = prevThenableState;
return request;
}
function renderFragment(request, task, children) {
return null !== task.keyPath
? ((request = [
REACT_ELEMENT_TYPE,
REACT_FRAGMENT_TYPE,
task.keyPath,
{ children: children }
]),
task.implicitSlot ? [request] : request)
: children;
}
var serializedSize = 0;
function deferTask(request, task) {
task = createTask(
request,
task.model,
task.keyPath,
task.implicitSlot,
request.abortableTasks
);
pingTask(request, task);
return "$L" + task.id.toString(16);
}
function renderElement(request, task, type, key, ref, props) {
if (null !== ref && void 0 !== ref)
throw Error(
"Refs cannot be used in Server Components, nor passed to Client Components."
);
if (
"function" === typeof type &&
type.$$typeof !== CLIENT_REFERENCE_TAG$1 &&
type.$$typeof !== TEMPORARY_REFERENCE_TAG
)
return renderFunctionComponent(request, task, key, type, props);
if (type === REACT_FRAGMENT_TYPE && null === key)
return (
(type = task.implicitSlot),
null === task.keyPath && (task.implicitSlot = !0),
(props = renderModelDestructive(
request,
task,
emptyRoot,
"",
props.children
)),
(task.implicitSlot = type),
props
);
if (
null != type &&
"object" === typeof type &&
type.$$typeof !== CLIENT_REFERENCE_TAG$1
)
switch (type.$$typeof) {
case REACT_LAZY_TYPE:
var init = type._init;
type = init(type._payload);
if (12 === request.status) throw null;
return renderElement(request, task, type, key, ref, props);
case REACT_FORWARD_REF_TYPE:
return renderFunctionComponent(request, task, key, type.render, props);
case REACT_MEMO_TYPE:
return renderElement(request, task, type.type, key, ref, props);
}
request = key;
key = task.keyPath;
null === request
? (request = key)
: null !== key && (request = key + "," + request);
props = [REACT_ELEMENT_TYPE, type, request, props];
task = task.implicitSlot && null !== request ? [props] : props;
return task;
}
function pingTask(request, task) {
var pingedTasks = request.pingedTasks;
pingedTasks.push(task);
1 === pingedTasks.length &&
((request.flushScheduled = null !== request.destination),
21 === request.type || 10 === request.status
? scheduleMicrotask(function () {
return performWork(request);
})
: setTimeout(function () {
return performWork(request);
}, 0));
}
function createTask(request, model, keyPath, implicitSlot, abortSet) {
request.pendingChunks++;
var id = request.nextChunkId++;
"object" !== typeof model ||
null === model ||
null !== keyPath ||
implicitSlot ||
request.writtenObjects.set(model, serializeByValueID(id));
var task = {
id: id,
status: 0,
model: model,
keyPath: keyPath,
implicitSlot: implicitSlot,
ping: function () {
return pingTask(request, task);
},
toJSON: function (parentPropertyName, value) {
serializedSize += parentPropertyName.length;
var prevKeyPath = task.keyPath,
prevImplicitSlot = task.implicitSlot;
try {
var JSCompiler_inline_result = renderModelDestructive(
request,
task,
this,
parentPropertyName,
value
);
} catch (thrownValue) {
if (
((parentPropertyName = task.model),
(parentPropertyName =
"object" === typeof parentPropertyName &&
null !== parentPropertyName &&
(parentPropertyName.$$typeof === REACT_ELEMENT_TYPE ||
parentPropertyName.$$typeof === REACT_LAZY_TYPE)),
12 === request.status)
)
(task.status = 3),
(prevKeyPath = request.fatalError),
(JSCompiler_inline_result = parentPropertyName
? "$L" + prevKeyPath.toString(16)
: serializeByValueID(prevKeyPath));
else if (
((value =
thrownValue === SuspenseException
? getSuspendedThenable()
: thrownValue),
"object" === typeof value &&
null !== value &&
"function" === typeof value.then)
) {
JSCompiler_inline_result = createTask(
request,
task.model,
task.keyPath,
task.implicitSlot,
request.abortableTasks
);
var ping = JSCompiler_inline_result.ping;
value.then(ping, ping);
JSCompiler_inline_result.thenableState =
getThenableStateAfterSuspending();
task.keyPath = prevKeyPath;
task.implicitSlot = prevImplicitSlot;
JSCompiler_inline_result = parentPropertyName
? "$L" + JSCompiler_inline_result.id.toString(16)
: serializeByValueID(JSCompiler_inline_result.id);
} else
(task.keyPath = prevKeyPath),
(task.implicitSlot = prevImplicitSlot),
request.pendingChunks++,
(prevKeyPath = request.nextChunkId++),
(prevImplicitSlot = logRecoverableError(request, value, task)),
emitErrorChunk(request, prevKeyPath, prevImplicitSlot),
(JSCompiler_inline_result = parentPropertyName
? "$L" + prevKeyPath.toString(16)
: serializeByValueID(prevKeyPath));
}
return JSCompiler_inline_result;
},
thenableState: null
};
abortSet.add(task);
return task;
}
function serializeByValueID(id) {
return "$" + id.toString(16);
}
function encodeReferenceChunk(request, id, reference) {
request = stringify(reference);
return id.toString(16) + ":" + request + "\n";
}
function serializeClientReference(
request,
parent,
parentPropertyName,
clientReference
) {
var clientReferenceKey = clientReference.$$id,
writtenClientReferences = request.writtenClientReferences,
existingId = writtenClientReferences.get(clientReferenceKey);
if (void 0 !== existingId)
return parent[0] === REACT_ELEMENT_TYPE && "1" === parentPropertyName
? "$L" + existingId.toString(16)
: serializeByValueID(existingId);
try {
var config = request.bundlerConfig,
id = clientReference.$$id,
idx = id.lastIndexOf("#"),
exportName = id.slice(idx + 1),
entry = config[id];
var JSCompiler_inline_result = [
entry ? entry.id : id.slice(0, idx),
exportName,
!0 === clientReference.$$async
];
request.pendingChunks++;
var importId = request.nextChunkId++,
json = stringify(JSCompiler_inline_result),
processedChunk = importId.toString(16) + ":I" + json + "\n";
request.completedImportChunks.push(processedChunk);
writtenClientReferences.set(clientReferenceKey, importId);
return parent[0] === REACT_ELEMENT_TYPE && "1" === parentPropertyName
? "$L" + importId.toString(16)
: serializeByValueID(importId);
} catch (x) {
return (
request.pendingChunks++,
(parent = request.nextChunkId++),
(parentPropertyName = logRecoverableError(request, x, null)),
emitErrorChunk(request, parent, parentPropertyName),
serializeByValueID(parent)
);
}
}
function outlineModel(request, value) {
value = createTask(request, value, null, !1, request.abortableTasks);
retryTask(request, value);
return value.id;
}
function serializeTypedArray(request, tag, typedArray) {
request.pendingChunks++;
var bufferId = request.nextChunkId++;
emitTypedArrayChunk(request, bufferId, tag, typedArray, !1);
return serializeByValueID(bufferId);
}
function serializeBlob(request, blob) {
function progress(entry) {
if (0 === newTask.status)
if (entry.done)
request.cacheController.signal.removeEventListener("abort", abortBlob),
pingTask(request, newTask);
else
return (
model.push(entry.value), reader.read().then(progress).catch(error)
);
}
function error(reason) {
0 === newTask.status &&
(request.cacheController.signal.removeEventListener("abort", abortBlob),
erroredTask(request, newTask, reason),
enqueueFlush(request),
reader.cancel(reason).then(error, error));
}
function abortBlob() {
if (0 === newTask.status) {
var signal = request.cacheController.signal;
signal.removeEventListener("abort", abortBlob);
signal = signal.reason;
erroredTask(request, newTask, signal);
enqueueFlush(request);
reader.cancel(signal).then(error, error);
}
}
var model = [blob.type],
newTask = createTask(request, model, null, !1, request.abortableTasks),
reader = blob.stream().getReader();
request.cacheController.signal.addEventListener("abort", abortBlob);
reader.read().then(progress).catch(error);
return "$B" + newTask.id.toString(16);
}
var modelRoot = !1;
function renderModelDestructive(
request,
task,
parent,
parentPropertyName,
value
) {
task.model = value;
if (value === REACT_ELEMENT_TYPE) return "$";
if (null === value) return null;
if ("object" === typeof value) {
switch (value.$$typeof) {
case REACT_ELEMENT_TYPE:
var elementReference = null,
writtenObjects = request.writtenObjects;
if (null === task.keyPath && !task.implicitSlot) {
var existingReference = writtenObjects.get(value);
if (void 0 !== existingReference)
if (modelRoot === value) modelRoot = null;
else return existingReference;
else
-1 === parentPropertyName.indexOf(":") &&
((parent = writtenObjects.get(parent)),
void 0 !== parent &&
((elementReference = parent + ":" + parentPropertyName),
writtenObjects.set(value, elementReference)));
}
if (3200 < serializedSize) return deferTask(request, task);
parentPropertyName = value.props;
parent = parentPropertyName.ref;
request = renderElement(
request,
task,
value.type,
value.key,
void 0 !== parent ? parent : null,
parentPropertyName
);
"object" === typeof request &&
null !== request &&
null !== elementReference &&
(writtenObjects.has(request) ||
writtenObjects.set(request, elementReference));
return request;
case REACT_LAZY_TYPE:
if (3200 < serializedSize) return deferTask(request, task);
task.thenableState = null;
parentPropertyName = value._init;
value = parentPropertyName(value._payload);
if (12 === request.status) throw null;
return renderModelDestructive(request, task, emptyRoot, "", value);
case REACT_LEGACY_ELEMENT_TYPE:
throw Error(
'A React Element from an older version of React was rendered. This is not supported. It can happen if:\n- Multiple copies of the "react" package is used.\n- A library pre-bundled an old copy of "react" or "react/jsx-runtime".\n- A compiler tries to "inline" JSX instead of using the runtime.'
);
}
if (value.$$typeof === CLIENT_REFERENCE_TAG$1)
return serializeClientReference(
request,
parent,
parentPropertyName,
value
);
if (
void 0 !== request.temporaryReferences &&
((elementReference = request.temporaryReferences.get(value)),
void 0 !== elementReference)
)
return "$T" + elementReference;
elementReference = request.writtenObjects;
writtenObjects = elementReference.get(value);
if ("function" === typeof value.then) {
if (void 0 !== writtenObjects) {
if (null !== task.keyPath || task.implicitSlot)
return "$@" + serializeThenable(request, task, value).toString(16);
if (modelRoot === value) modelRoot = null;
else return writtenObjects;
}
request = "$@" + serializeThenable(request, task, value).toString(16);
elementReference.set(value, request);
return request;
}
if (void 0 !== writtenObjects)
if (modelRoot === value) {
if (writtenObjects !== serializeByValueID(task.id))
return writtenObjects;
modelRoot = null;
} else return writtenObjects;
else if (
-1 === parentPropertyName.indexOf(":") &&
((writtenObjects = elementReference.get(parent)),
void 0 !== writtenObjects)
) {
existingReference = parentPropertyName;
if (isArrayImpl(parent) && parent[0] === REACT_ELEMENT_TYPE)
switch (parentPropertyName) {
case "1":
existingReference = "type";
break;
case "2":
existingReference = "key";
break;
case "3":
existingReference = "props";
break;
case "4":
existingReference = "_owner";
}
elementReference.set(value, writtenObjects + ":" + existingReference);
}
if (isArrayImpl(value)) return renderFragment(request, task, value);
if (value instanceof Map)
return (
(value = Array.from(value)),
"$Q" + outlineModel(request, value).toString(16)
);
if (value instanceof Set)
return (
(value = Array.from(value)),
"$W" + outlineModel(request, value).toString(16)
);
if ("function" === typeof FormData && value instanceof FormData)
return (
(value = Array.from(value.entries())),
"$K" + outlineModel(request, value).toString(16)
);
if (value instanceof Error) return "$Z";
if (value instanceof ArrayBuffer)
return serializeTypedArray(request, "A", new Uint8Array(value));
if (value instanceof Int8Array)
return serializeTypedArray(request, "O", value);
if (value instanceof Uint8Array)
return serializeTypedArray(request, "o", value);
if (value instanceof Uint8ClampedArray)
return serializeTypedArray(request, "U", value);
if (value instanceof Int16Array)
return serializeTypedArray(request, "S", value);
if (value instanceof Uint16Array)
return serializeTypedArray(request, "s", value);
if (value instanceof Int32Array)
return serializeTypedArray(request, "L", value);
if (value instanceof Uint32Array)
return serializeTypedArray(request, "l", value);
if (value instanceof Float32Array)
return serializeTypedArray(request, "G", value);
if (value instanceof Float64Array)
return serializeTypedArray(request, "g", value);
if (value instanceof BigInt64Array)
return serializeTypedArray(request, "M", value);
if (value instanceof BigUint64Array)
return serializeTypedArray(request, "m", value);
if (value instanceof DataView)
return serializeTypedArray(request, "V", value);
if ("function" === typeof Blob && value instanceof Blob)
return serializeBlob(request, value);
if ((elementReference = getIteratorFn(value)))
return (
(parentPropertyName = elementReference.call(value)),
parentPropertyName === value
? "$i" +
outlineModel(request, Array.from(parentPropertyName)).toString(16)
: renderFragment(request, task, Array.from(parentPropertyName))
);
if ("function" === typeof ReadableStream && value instanceof ReadableStream)
return serializeReadableStream(request, task, value);
elementReference = value[ASYNC_ITERATOR];
if ("function" === typeof elementReference)
return (
null !== task.keyPath
? ((request = [
REACT_ELEMENT_TYPE,
REACT_FRAGMENT_TYPE,
task.keyPath,
{ children: value }
]),
(request = task.implicitSlot ? [request] : request))
: ((parentPropertyName = elementReference.call(value)),
(request = serializeAsyncIterable(
request,
task,
value,
parentPropertyName
))),
request
);
if (value instanceof Date) return "$D" + value.toJSON();
request = getPrototypeOf(value);
if (
request !== ObjectPrototype &&
(null === request || null !== getPrototypeOf(request))
)
throw Error(
"Only plain objects, and a few built-ins, can be passed to Client Components from Server Components. Classes or null prototypes are not supported." +
describeObjectForErrorMessage(parent, parentPropertyName)
);
return value;
}
if ("string" === typeof value) {
serializedSize += value.length;
if (
"Z" === value[value.length - 1] &&
parent[parentPropertyName] instanceof Date
)
return "$D" + value;
if (1024 <= value.length && null !== byteLengthOfChunk)
return (
request.pendingChunks++,
(task = request.nextChunkId++),
emitTextChunk(request, task, value, !1),
serializeByValueID(task)
);
request = "$" === value[0] ? "$" + value : value;
return request;
}
if ("boolean" === typeof value) return value;
if ("number" === typeof value)
return Number.isFinite(value)
? 0 === value && -Infinity === 1 / value
? "$-0"
: value
: Infinity === value
? "$Infinity"
: -Infinity === value
? "$-Infinity"
: "$NaN";
if ("undefined" === typeof value) return "$undefined";
if ("function" === typeof value) {
if (value.$$typeof === CLIENT_REFERENCE_TAG$1)
return serializeClientReference(
request,
parent,
parentPropertyName,
value
);
if (value.$$typeof === SERVER_REFERENCE_TAG)
return (
(task = request.writtenServerReferences),
(parentPropertyName = task.get(value)),
void 0 !== parentPropertyName
? (request = "$F" + parentPropertyName.toString(16))
: ((parentPropertyName = value.$$bound),
(parentPropertyName =
null === parentPropertyName
? null
: Promise.resolve(parentPropertyName)),
(request = outlineModel(request, {
id: value.$$id,
bound: parentPropertyName
})),
task.set(value, request),
(request = "$F" + request.toString(16))),
request
);
if (
void 0 !== request.temporaryReferences &&
((request = request.temporaryReferences.get(value)), void 0 !== request)
)
return "$T" + request;
if (value.$$typeof === TEMPORARY_REFERENCE_TAG)
throw Error(
"Could not reference an opaque temporary reference. This is likely due to misconfiguring the temporaryReferences options on the server."
);
if (/^on[A-Z]/.test(parentPropertyName))
throw Error(
"Event handlers cannot be passed to Client Component props." +
describeObjectForErrorMessage(parent, parentPropertyName) +
"\nIf you need interactivity, consider converting part of this to a Client Component."
);
throw Error(
'Functions cannot be passed directly to Client Components unless you explicitly expose it by marking it with "use server". Or maybe you meant to call this function rather than return it.' +
describeObjectForErrorMessage(parent, parentPropertyName)
);
}
if ("symbol" === typeof value) {
task = request.writtenSymbols;
elementReference = task.get(value);
if (void 0 !== elementReference)
return serializeByValueID(elementReference);
elementReference = value.description;
if (Symbol.for(elementReference) !== value)
throw Error(
"Only global symbols received from Symbol.for(...) can be passed to Client Components. The symbol Symbol.for(" +
(value.description + ") cannot be found among global symbols.") +
describeObjectForErrorMessage(parent, parentPropertyName)
);
request.pendingChunks++;
parentPropertyName = request.nextChunkId++;
parent = encodeReferenceChunk(
request,
parentPropertyName,
"$S" + elementReference
);
request.completedImportChunks.push(parent);
task.set(value, parentPropertyName);
return serializeByValueID(parentPropertyName);
}
if ("bigint" === typeof value) return "$n" + value.toString(10);
throw Error(
"Type " +
typeof value +
" is not supported in Client Component props." +
describeObjectForErrorMessage(parent, parentPropertyName)
);
}
function logRecoverableError(request, error) {
var prevRequest = currentRequest;
currentRequest = null;
try {
var onError = request.onError;
var errorDigest = onError(error);
} finally {
currentRequest = prevRequest;
}
if (null != errorDigest && "string" !== typeof errorDigest)