@tanstack/router-core 1.168.9 → 1.168.11
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.
- package/dist/cjs/hash-scroll.cjs +1 -1
- package/dist/cjs/hash-scroll.cjs.map +1 -1
- package/dist/cjs/index.d.cts +1 -1
- package/dist/cjs/load-matches.cjs +6 -6
- package/dist/cjs/load-matches.cjs.map +1 -1
- package/dist/cjs/router.cjs +57 -58
- package/dist/cjs/router.cjs.map +1 -1
- package/dist/cjs/router.d.cts +3 -1
- package/dist/cjs/scroll-restoration.cjs +1 -1
- package/dist/cjs/scroll-restoration.cjs.map +1 -1
- package/dist/cjs/ssr/createRequestHandler.cjs +2 -2
- package/dist/cjs/ssr/createRequestHandler.cjs.map +1 -1
- package/dist/cjs/ssr/serializer/RawStream.cjs +41 -32
- package/dist/cjs/ssr/serializer/RawStream.cjs.map +1 -1
- package/dist/cjs/ssr/serializer/RawStream.d.cts +12 -4
- package/dist/cjs/ssr/serializer/ShallowErrorPlugin.cjs.map +1 -1
- package/dist/cjs/ssr/serializer/ShallowErrorPlugin.d.cts +2 -2
- package/dist/cjs/ssr/serializer/seroval-plugins.cjs.map +1 -1
- package/dist/cjs/ssr/serializer/seroval-plugins.d.cts +2 -1
- package/dist/cjs/ssr/serializer/transformer.cjs +16 -14
- package/dist/cjs/ssr/serializer/transformer.cjs.map +1 -1
- package/dist/cjs/ssr/serializer/transformer.d.cts +24 -23
- package/dist/cjs/ssr/ssr-client.cjs +9 -9
- package/dist/cjs/ssr/ssr-client.cjs.map +1 -1
- package/dist/cjs/ssr/ssr-server.cjs +31 -9
- package/dist/cjs/ssr/ssr-server.cjs.map +1 -1
- package/dist/cjs/ssr/ssr-server.d.cts +3 -2
- package/dist/cjs/ssr/transformStreamWithRouter.cjs +4 -1
- package/dist/cjs/ssr/transformStreamWithRouter.cjs.map +1 -1
- package/dist/cjs/stores.cjs +57 -57
- package/dist/cjs/stores.cjs.map +1 -1
- package/dist/cjs/stores.d.cts +16 -16
- package/dist/esm/hash-scroll.js +1 -1
- package/dist/esm/hash-scroll.js.map +1 -1
- package/dist/esm/index.d.ts +1 -1
- package/dist/esm/load-matches.js +6 -6
- package/dist/esm/load-matches.js.map +1 -1
- package/dist/esm/router.d.ts +3 -1
- package/dist/esm/router.js +57 -58
- package/dist/esm/router.js.map +1 -1
- package/dist/esm/scroll-restoration.js +1 -1
- package/dist/esm/scroll-restoration.js.map +1 -1
- package/dist/esm/ssr/createRequestHandler.js +2 -2
- package/dist/esm/ssr/createRequestHandler.js.map +1 -1
- package/dist/esm/ssr/serializer/RawStream.d.ts +12 -4
- package/dist/esm/ssr/serializer/RawStream.js +41 -32
- package/dist/esm/ssr/serializer/RawStream.js.map +1 -1
- package/dist/esm/ssr/serializer/ShallowErrorPlugin.d.ts +2 -2
- package/dist/esm/ssr/serializer/ShallowErrorPlugin.js.map +1 -1
- package/dist/esm/ssr/serializer/seroval-plugins.d.ts +2 -1
- package/dist/esm/ssr/serializer/seroval-plugins.js.map +1 -1
- package/dist/esm/ssr/serializer/transformer.d.ts +24 -23
- package/dist/esm/ssr/serializer/transformer.js +16 -14
- package/dist/esm/ssr/serializer/transformer.js.map +1 -1
- package/dist/esm/ssr/ssr-client.js +9 -9
- package/dist/esm/ssr/ssr-client.js.map +1 -1
- package/dist/esm/ssr/ssr-server.d.ts +3 -2
- package/dist/esm/ssr/ssr-server.js +31 -9
- package/dist/esm/ssr/ssr-server.js.map +1 -1
- package/dist/esm/ssr/transformStreamWithRouter.js +4 -1
- package/dist/esm/ssr/transformStreamWithRouter.js.map +1 -1
- package/dist/esm/stores.d.ts +16 -16
- package/dist/esm/stores.js +58 -58
- package/dist/esm/stores.js.map +1 -1
- package/package.json +3 -3
- package/src/hash-scroll.ts +1 -1
- package/src/index.ts +1 -1
- package/src/load-matches.ts +8 -11
- package/src/router.ts +74 -85
- package/src/scroll-restoration.ts +1 -1
- package/src/ssr/createRequestHandler.ts +4 -5
- package/src/ssr/serializer/RawStream.ts +65 -56
- package/src/ssr/serializer/ShallowErrorPlugin.ts +2 -2
- package/src/ssr/serializer/seroval-plugins.ts +2 -1
- package/src/ssr/serializer/transformer.ts +71 -76
- package/src/ssr/ssr-client.ts +8 -12
- package/src/ssr/ssr-server.ts +39 -7
- package/src/ssr/transformStreamWithRouter.ts +3 -0
- package/src/stores.ts +86 -86
package/dist/cjs/hash-scroll.cjs
CHANGED
|
@@ -6,7 +6,7 @@
|
|
|
6
6
|
*/
|
|
7
7
|
function handleHashScroll(router) {
|
|
8
8
|
if (typeof document !== "undefined" && document.querySelector) {
|
|
9
|
-
const location = router.stores.location.
|
|
9
|
+
const location = router.stores.location.get();
|
|
10
10
|
const hashScrollIntoViewOptions = location.state.__hashScrollIntoViewOptions ?? true;
|
|
11
11
|
if (hashScrollIntoViewOptions && location.hash !== "") {
|
|
12
12
|
const el = document.getElementById(location.hash);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"hash-scroll.cjs","names":[],"sources":["../../src/hash-scroll.ts"],"sourcesContent":["import type { AnyRouter } from './router'\n\n/**\n * @private\n * Handles hash-based scrolling after navigation completes.\n * To be used in framework-specific <Transitioner> components during the onResolved event.\n */\nexport function handleHashScroll(router: AnyRouter) {\n if (typeof document !== 'undefined' && (document as any).querySelector) {\n const location = router.stores.location.
|
|
1
|
+
{"version":3,"file":"hash-scroll.cjs","names":[],"sources":["../../src/hash-scroll.ts"],"sourcesContent":["import type { AnyRouter } from './router'\n\n/**\n * @private\n * Handles hash-based scrolling after navigation completes.\n * To be used in framework-specific <Transitioner> components during the onResolved event.\n */\nexport function handleHashScroll(router: AnyRouter) {\n if (typeof document !== 'undefined' && (document as any).querySelector) {\n const location = router.stores.location.get()\n const hashScrollIntoViewOptions =\n location.state.__hashScrollIntoViewOptions ?? true\n\n if (hashScrollIntoViewOptions && location.hash !== '') {\n const el = document.getElementById(location.hash)\n if (el) {\n el.scrollIntoView(hashScrollIntoViewOptions)\n }\n }\n }\n}\n"],"mappings":";;;;;;AAOA,SAAgB,iBAAiB,QAAmB;AAClD,KAAI,OAAO,aAAa,eAAgB,SAAiB,eAAe;EACtE,MAAM,WAAW,OAAO,OAAO,SAAS,KAAK;EAC7C,MAAM,4BACJ,SAAS,MAAM,+BAA+B;AAEhD,MAAI,6BAA6B,SAAS,SAAS,IAAI;GACrD,MAAM,KAAK,SAAS,eAAe,SAAS,KAAK;AACjD,OAAI,GACF,IAAG,eAAe,0BAA0B"}
|
package/dist/cjs/index.d.cts
CHANGED
|
@@ -44,7 +44,7 @@ export { defaultGetScrollRestorationKey, getElementScrollRestorationEntry, stora
|
|
|
44
44
|
export { handleHashScroll } from './hash-scroll.cjs';
|
|
45
45
|
export type { ScrollRestorationOptions, ScrollRestorationEntry, } from './scroll-restoration.cjs';
|
|
46
46
|
export type { ValidateFromPath, ValidateToPath, ValidateSearch, ValidateParams, InferFrom, InferTo, InferMaskTo, InferMaskFrom, ValidateNavigateOptions, ValidateNavigateOptionsArray, ValidateRedirectOptions, ValidateRedirectOptionsArray, ValidateId, InferStrict, InferShouldThrow, InferSelected, ValidateUseSearchResult, ValidateUseParamsResult, } from './typePrimitives.cjs';
|
|
47
|
-
export type { AnySerializationAdapter, SerializationAdapter, ValidateSerializableInput,
|
|
47
|
+
export type { AnySerializationAdapter, SerializationAdapter, ValidateSerializableInput, SerializerExtensions, ValidateSerializable, RegisteredSerializableInput, SerializableExtensions, DefaultSerializable, Serializable, TSR_SERIALIZABLE, TsrSerializable, SerializationError, } from './ssr/serializer/transformer.cjs';
|
|
48
48
|
export { createSerializationAdapter, makeSerovalPlugin, makeSsrSerovalPlugin, } from './ssr/serializer/transformer.cjs';
|
|
49
49
|
export { defaultSerovalPlugins } from './ssr/serializer/seroval-plugins.cjs';
|
|
50
50
|
export { RawStream, createRawStreamRPCPlugin, createRawStreamDeserializePlugin, } from './ssr/serializer/RawStream.cjs';
|
|
@@ -12,12 +12,12 @@ var triggerOnReady = (inner) => {
|
|
|
12
12
|
}
|
|
13
13
|
};
|
|
14
14
|
var hasForcePendingActiveMatch = (router) => {
|
|
15
|
-
return router.stores.matchesId.
|
|
16
|
-
return router.stores.
|
|
15
|
+
return router.stores.matchesId.get().some((matchId) => {
|
|
16
|
+
return router.stores.matchStores.get(matchId)?.get()._forcePending;
|
|
17
17
|
});
|
|
18
18
|
};
|
|
19
19
|
var resolvePreload = (inner, matchId) => {
|
|
20
|
-
return !!(inner.preload && !inner.router.stores.
|
|
20
|
+
return !!(inner.preload && !inner.router.stores.matchStores.has(matchId));
|
|
21
21
|
};
|
|
22
22
|
/**
|
|
23
23
|
* Builds the accumulated context from router options and all matches up to (and optionally including) the given index.
|
|
@@ -463,8 +463,8 @@ var loadRouteMatch = async (inner, matchPromises, index) => {
|
|
|
463
463
|
if (_tanstack_router_core_isServer.isServer ?? inner.router.isServer) return inner.router.getMatch(matchId);
|
|
464
464
|
} else {
|
|
465
465
|
const prevMatch = inner.router.getMatch(matchId);
|
|
466
|
-
const activeIdAtIndex = inner.router.stores.matchesId.
|
|
467
|
-
const previousRouteMatchId = (activeIdAtIndex && inner.router.stores.
|
|
466
|
+
const activeIdAtIndex = inner.router.stores.matchesId.get()[index];
|
|
467
|
+
const previousRouteMatchId = (activeIdAtIndex && inner.router.stores.matchStores.get(activeIdAtIndex) || null)?.routeId === routeId ? activeIdAtIndex : inner.router.stores.matches.get().find((d) => d.routeId === routeId)?.id;
|
|
468
468
|
const preload = resolvePreload(inner, matchId);
|
|
469
469
|
if (prevMatch._nonReactive.loaderPromise) {
|
|
470
470
|
if (prevMatch.status === "success" && !inner.sync && !prevMatch.preload && shouldReloadInBackground) return prevMatch;
|
|
@@ -474,7 +474,7 @@ var loadRouteMatch = async (inner, matchPromises, index) => {
|
|
|
474
474
|
if (error) handleRedirectAndNotFound(inner, match, error);
|
|
475
475
|
if (match.status === "pending") await handleLoader(preload, prevMatch, previousRouteMatchId, match, route);
|
|
476
476
|
} else {
|
|
477
|
-
const nextPreload = preload && !inner.router.stores.
|
|
477
|
+
const nextPreload = preload && !inner.router.stores.matchStores.has(matchId);
|
|
478
478
|
const match = inner.router.getMatch(matchId);
|
|
479
479
|
match._nonReactive.loaderPromise = require_utils.createControlledPromise();
|
|
480
480
|
if (nextPreload !== match.preload) inner.updateMatch(matchId, (prev) => ({
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"load-matches.cjs","names":[],"sources":["../../src/load-matches.ts"],"sourcesContent":["import { isServer } from '@tanstack/router-core/isServer'\nimport { invariant } from './invariant'\nimport { createControlledPromise, isPromise } from './utils'\nimport { isNotFound } from './not-found'\nimport { rootRouteId } from './root'\nimport { isRedirect } from './redirect'\nimport type { NotFoundError } from './not-found'\nimport type { ParsedLocation } from './location'\nimport type {\n AnyRoute,\n BeforeLoadContextOptions,\n LoaderFnContext,\n SsrContextOptions,\n} from './route'\nimport type { AnyRouteMatch, MakeRouteMatch } from './Matches'\nimport type { AnyRouter, SSROption, UpdateMatchFn } from './router'\n\n/**\n * An object of this shape is created when calling `loadMatches`.\n * It contains everything we need for all other functions in this file\n * to work. (It's basically the function's argument, plus a few mutable states)\n */\ntype InnerLoadContext = {\n /** the calling router instance */\n router: AnyRouter\n location: ParsedLocation\n /** mutable state, scoped to a `loadMatches` call */\n firstBadMatchIndex?: number\n /** mutable state, scoped to a `loadMatches` call */\n rendered?: boolean\n serialError?: unknown\n updateMatch: UpdateMatchFn\n matches: Array<AnyRouteMatch>\n preload?: boolean\n forceStaleReload?: boolean\n onReady?: () => Promise<void>\n sync?: boolean\n}\n\nconst triggerOnReady = (inner: InnerLoadContext): void | Promise<void> => {\n if (!inner.rendered) {\n inner.rendered = true\n return inner.onReady?.()\n }\n}\n\nconst hasForcePendingActiveMatch = (router: AnyRouter): boolean => {\n return router.stores.matchesId.state.some((matchId) => {\n return router.stores.activeMatchStoresById.get(matchId)?.state._forcePending\n })\n}\n\nconst resolvePreload = (inner: InnerLoadContext, matchId: string): boolean => {\n return !!(\n inner.preload && !inner.router.stores.activeMatchStoresById.has(matchId)\n )\n}\n\n/**\n * Builds the accumulated context from router options and all matches up to (and optionally including) the given index.\n * Merges __routeContext and __beforeLoadContext from each match.\n */\nconst buildMatchContext = (\n inner: InnerLoadContext,\n index: number,\n includeCurrentMatch: boolean = true,\n): Record<string, unknown> => {\n const context: Record<string, unknown> = {\n ...(inner.router.options.context ?? {}),\n }\n const end = includeCurrentMatch ? index : index - 1\n for (let i = 0; i <= end; i++) {\n const innerMatch = inner.matches[i]\n if (!innerMatch) continue\n const m = inner.router.getMatch(innerMatch.id)\n if (!m) continue\n Object.assign(context, m.__routeContext, m.__beforeLoadContext)\n }\n return context\n}\n\nconst getNotFoundBoundaryIndex = (\n inner: InnerLoadContext,\n err: NotFoundError,\n): number | undefined => {\n if (!inner.matches.length) {\n return undefined\n }\n\n const requestedRouteId = err.routeId\n const matchedRootIndex = inner.matches.findIndex(\n (m) => m.routeId === inner.router.routeTree.id,\n )\n const rootIndex = matchedRootIndex >= 0 ? matchedRootIndex : 0\n\n let startIndex = requestedRouteId\n ? inner.matches.findIndex((match) => match.routeId === requestedRouteId)\n : (inner.firstBadMatchIndex ?? inner.matches.length - 1)\n\n if (startIndex < 0) {\n startIndex = rootIndex\n }\n\n for (let i = startIndex; i >= 0; i--) {\n const match = inner.matches[i]!\n const route = inner.router.looseRoutesById[match.routeId]!\n if (route.options.notFoundComponent) {\n return i\n }\n }\n\n // If no boundary component is found, preserve explicit routeId targeting behavior,\n // otherwise default to root for untargeted notFounds.\n return requestedRouteId ? startIndex : rootIndex\n}\n\nconst handleRedirectAndNotFound = (\n inner: InnerLoadContext,\n match: AnyRouteMatch | undefined,\n err: unknown,\n): void => {\n if (!isRedirect(err) && !isNotFound(err)) return\n\n if (isRedirect(err) && err.redirectHandled && !err.options.reloadDocument) {\n throw err\n }\n\n // in case of a redirecting match during preload, the match does not exist\n if (match) {\n match._nonReactive.beforeLoadPromise?.resolve()\n match._nonReactive.loaderPromise?.resolve()\n match._nonReactive.beforeLoadPromise = undefined\n match._nonReactive.loaderPromise = undefined\n\n match._nonReactive.error = err\n\n inner.updateMatch(match.id, (prev) => ({\n ...prev,\n status: isRedirect(err)\n ? 'redirected'\n : prev.status === 'pending'\n ? 'success'\n : prev.status,\n context: buildMatchContext(inner, match.index),\n isFetching: false,\n error: err,\n }))\n\n if (isNotFound(err) && !err.routeId) {\n // Stamp the throwing match's routeId so that the finalization step in\n // loadMatches knows where the notFound originated. The actual boundary\n // resolution (walking up to the nearest notFoundComponent) is deferred to\n // the finalization step, where firstBadMatchIndex is stable and\n // headMaxIndex can be capped correctly.\n err.routeId = match.routeId\n }\n\n match._nonReactive.loadPromise?.resolve()\n }\n\n if (isRedirect(err)) {\n inner.rendered = true\n err.options._fromLocation = inner.location\n err.redirectHandled = true\n err = inner.router.resolveRedirect(err)\n }\n\n throw err\n}\n\nconst shouldSkipLoader = (\n inner: InnerLoadContext,\n matchId: string,\n): boolean => {\n const match = inner.router.getMatch(matchId)\n if (!match) {\n return true\n }\n // upon hydration, we skip the loader if the match has been dehydrated on the server\n if (!(isServer ?? inner.router.isServer) && match._nonReactive.dehydrated) {\n return true\n }\n\n if ((isServer ?? inner.router.isServer) && match.ssr === false) {\n return true\n }\n\n return false\n}\n\nconst syncMatchContext = (\n inner: InnerLoadContext,\n matchId: string,\n index: number,\n): void => {\n const nextContext = buildMatchContext(inner, index)\n\n inner.updateMatch(matchId, (prev) => {\n return {\n ...prev,\n context: nextContext,\n }\n })\n}\n\nconst handleSerialError = (\n inner: InnerLoadContext,\n index: number,\n err: any,\n routerCode: string,\n): void => {\n const { id: matchId, routeId } = inner.matches[index]!\n const route = inner.router.looseRoutesById[routeId]!\n\n // Much like suspense, we use a promise here to know if\n // we've been outdated by a new loadMatches call and\n // should abort the current async operation\n if (err instanceof Promise) {\n throw err\n }\n\n err.routerCode = routerCode\n inner.firstBadMatchIndex ??= index\n handleRedirectAndNotFound(inner, inner.router.getMatch(matchId), err)\n\n try {\n route.options.onError?.(err)\n } catch (errorHandlerErr) {\n err = errorHandlerErr\n handleRedirectAndNotFound(inner, inner.router.getMatch(matchId), err)\n }\n\n inner.updateMatch(matchId, (prev) => {\n prev._nonReactive.beforeLoadPromise?.resolve()\n prev._nonReactive.beforeLoadPromise = undefined\n prev._nonReactive.loadPromise?.resolve()\n\n return {\n ...prev,\n error: err,\n status: 'error',\n isFetching: false,\n updatedAt: Date.now(),\n abortController: new AbortController(),\n }\n })\n\n if (!inner.preload && !isRedirect(err) && !isNotFound(err)) {\n inner.serialError ??= err\n }\n}\n\nconst isBeforeLoadSsr = (\n inner: InnerLoadContext,\n matchId: string,\n index: number,\n route: AnyRoute,\n): void | Promise<void> => {\n const existingMatch = inner.router.getMatch(matchId)!\n const parentMatchId = inner.matches[index - 1]?.id\n const parentMatch = parentMatchId\n ? inner.router.getMatch(parentMatchId)!\n : undefined\n\n // in SPA mode, only SSR the root route\n if (inner.router.isShell()) {\n existingMatch.ssr = route.id === rootRouteId\n return\n }\n\n if (parentMatch?.ssr === false) {\n existingMatch.ssr = false\n return\n }\n\n const parentOverride = (tempSsr: SSROption) => {\n if (tempSsr === true && parentMatch?.ssr === 'data-only') {\n return 'data-only'\n }\n return tempSsr\n }\n\n const defaultSsr = inner.router.options.defaultSsr ?? true\n\n if (route.options.ssr === undefined) {\n existingMatch.ssr = parentOverride(defaultSsr)\n return\n }\n\n if (typeof route.options.ssr !== 'function') {\n existingMatch.ssr = parentOverride(route.options.ssr)\n return\n }\n const { search, params } = existingMatch\n\n const ssrFnContext: SsrContextOptions<any, any, any> = {\n search: makeMaybe(search, existingMatch.searchError),\n params: makeMaybe(params, existingMatch.paramsError),\n location: inner.location,\n matches: inner.matches.map((match) => ({\n index: match.index,\n pathname: match.pathname,\n fullPath: match.fullPath,\n staticData: match.staticData,\n id: match.id,\n routeId: match.routeId,\n search: makeMaybe(match.search, match.searchError),\n params: makeMaybe(match.params, match.paramsError),\n ssr: match.ssr,\n })),\n }\n\n const tempSsr = route.options.ssr(ssrFnContext)\n if (isPromise(tempSsr)) {\n return tempSsr.then((ssr) => {\n existingMatch.ssr = parentOverride(ssr ?? defaultSsr)\n })\n }\n\n existingMatch.ssr = parentOverride(tempSsr ?? defaultSsr)\n return\n}\n\nconst setupPendingTimeout = (\n inner: InnerLoadContext,\n matchId: string,\n route: AnyRoute,\n match: AnyRouteMatch,\n): void => {\n if (match._nonReactive.pendingTimeout !== undefined) return\n\n const pendingMs =\n route.options.pendingMs ?? inner.router.options.defaultPendingMs\n const shouldPending = !!(\n inner.onReady &&\n !(isServer ?? inner.router.isServer) &&\n !resolvePreload(inner, matchId) &&\n (route.options.loader ||\n route.options.beforeLoad ||\n routeNeedsPreload(route)) &&\n typeof pendingMs === 'number' &&\n pendingMs !== Infinity &&\n (route.options.pendingComponent ??\n (inner.router.options as any)?.defaultPendingComponent)\n )\n\n if (shouldPending) {\n const pendingTimeout = setTimeout(() => {\n // Update the match and prematurely resolve the loadMatches promise so that\n // the pending component can start rendering\n triggerOnReady(inner)\n }, pendingMs)\n match._nonReactive.pendingTimeout = pendingTimeout\n }\n}\n\nconst preBeforeLoadSetup = (\n inner: InnerLoadContext,\n matchId: string,\n route: AnyRoute,\n): void | Promise<void> => {\n const existingMatch = inner.router.getMatch(matchId)!\n\n // If we are in the middle of a load, either of these will be present\n // (not to be confused with `loadPromise`, which is always defined)\n if (\n !existingMatch._nonReactive.beforeLoadPromise &&\n !existingMatch._nonReactive.loaderPromise\n )\n return\n\n setupPendingTimeout(inner, matchId, route, existingMatch)\n\n const then = () => {\n const match = inner.router.getMatch(matchId)!\n if (\n match.preload &&\n (match.status === 'redirected' || match.status === 'notFound')\n ) {\n handleRedirectAndNotFound(inner, match, match.error)\n }\n }\n\n // Wait for the previous beforeLoad to resolve before we continue\n return existingMatch._nonReactive.beforeLoadPromise\n ? existingMatch._nonReactive.beforeLoadPromise.then(then)\n : then()\n}\n\nconst executeBeforeLoad = (\n inner: InnerLoadContext,\n matchId: string,\n index: number,\n route: AnyRoute,\n): void | Promise<void> => {\n const match = inner.router.getMatch(matchId)!\n\n // explicitly capture the previous loadPromise\n let prevLoadPromise = match._nonReactive.loadPromise\n match._nonReactive.loadPromise = createControlledPromise<void>(() => {\n prevLoadPromise?.resolve()\n prevLoadPromise = undefined\n })\n\n const { paramsError, searchError } = match\n\n if (paramsError) {\n handleSerialError(inner, index, paramsError, 'PARSE_PARAMS')\n }\n\n if (searchError) {\n handleSerialError(inner, index, searchError, 'VALIDATE_SEARCH')\n }\n\n setupPendingTimeout(inner, matchId, route, match)\n\n const abortController = new AbortController()\n\n let isPending = false\n const pending = () => {\n if (isPending) return\n isPending = true\n inner.updateMatch(matchId, (prev) => ({\n ...prev,\n isFetching: 'beforeLoad',\n fetchCount: prev.fetchCount + 1,\n abortController,\n // Note: We intentionally don't update context here.\n // Context should only be updated after beforeLoad resolves to avoid\n // components seeing incomplete context during async beforeLoad execution.\n }))\n }\n\n const resolve = () => {\n match._nonReactive.beforeLoadPromise?.resolve()\n match._nonReactive.beforeLoadPromise = undefined\n inner.updateMatch(matchId, (prev) => ({\n ...prev,\n isFetching: false,\n }))\n }\n\n // if there is no `beforeLoad` option, just mark as pending and resolve\n // Context will be updated later in loadRouteMatch after loader completes\n if (!route.options.beforeLoad) {\n inner.router.batch(() => {\n pending()\n resolve()\n })\n return\n }\n\n match._nonReactive.beforeLoadPromise = createControlledPromise<void>()\n\n // Build context from all parent matches, excluding current match's __beforeLoadContext\n // (since we're about to execute beforeLoad for this match)\n const context = {\n ...buildMatchContext(inner, index, false),\n ...match.__routeContext,\n }\n const { search, params, cause } = match\n const preload = resolvePreload(inner, matchId)\n const beforeLoadFnContext: BeforeLoadContextOptions<\n any,\n any,\n any,\n any,\n any,\n any,\n any,\n any,\n any\n > = {\n search,\n abortController,\n params,\n preload,\n context,\n location: inner.location,\n navigate: (opts: any) =>\n inner.router.navigate({\n ...opts,\n _fromLocation: inner.location,\n }),\n buildLocation: inner.router.buildLocation,\n cause: preload ? 'preload' : cause,\n matches: inner.matches,\n routeId: route.id,\n ...inner.router.options.additionalContext,\n }\n\n const updateContext = (beforeLoadContext: any) => {\n if (beforeLoadContext === undefined) {\n inner.router.batch(() => {\n pending()\n resolve()\n })\n return\n }\n if (isRedirect(beforeLoadContext) || isNotFound(beforeLoadContext)) {\n pending()\n handleSerialError(inner, index, beforeLoadContext, 'BEFORE_LOAD')\n }\n\n inner.router.batch(() => {\n pending()\n inner.updateMatch(matchId, (prev) => ({\n ...prev,\n __beforeLoadContext: beforeLoadContext,\n }))\n resolve()\n })\n }\n\n let beforeLoadContext\n try {\n beforeLoadContext = route.options.beforeLoad(beforeLoadFnContext)\n if (isPromise(beforeLoadContext)) {\n pending()\n return beforeLoadContext\n .catch((err) => {\n handleSerialError(inner, index, err, 'BEFORE_LOAD')\n })\n .then(updateContext)\n }\n } catch (err) {\n pending()\n handleSerialError(inner, index, err, 'BEFORE_LOAD')\n }\n\n updateContext(beforeLoadContext)\n return\n}\n\nconst handleBeforeLoad = (\n inner: InnerLoadContext,\n index: number,\n): void | Promise<void> => {\n const { id: matchId, routeId } = inner.matches[index]!\n const route = inner.router.looseRoutesById[routeId]!\n\n const serverSsr = () => {\n // on the server, determine whether SSR the current match or not\n if (isServer ?? inner.router.isServer) {\n const maybePromise = isBeforeLoadSsr(inner, matchId, index, route)\n if (isPromise(maybePromise)) return maybePromise.then(queueExecution)\n }\n return queueExecution()\n }\n\n const execute = () => executeBeforeLoad(inner, matchId, index, route)\n\n const queueExecution = () => {\n if (shouldSkipLoader(inner, matchId)) return\n const result = preBeforeLoadSetup(inner, matchId, route)\n return isPromise(result) ? result.then(execute) : execute()\n }\n\n return serverSsr()\n}\n\nconst executeHead = (\n inner: InnerLoadContext,\n matchId: string,\n route: AnyRoute,\n): void | Promise<\n Pick<\n AnyRouteMatch,\n 'meta' | 'links' | 'headScripts' | 'headers' | 'scripts' | 'styles'\n >\n> => {\n const match = inner.router.getMatch(matchId)\n // in case of a redirecting match during preload, the match does not exist\n if (!match) {\n return\n }\n if (!route.options.head && !route.options.scripts && !route.options.headers) {\n return\n }\n const assetContext = {\n ssr: inner.router.options.ssr,\n matches: inner.matches,\n match,\n params: match.params,\n loaderData: match.loaderData,\n }\n\n return Promise.all([\n route.options.head?.(assetContext),\n route.options.scripts?.(assetContext),\n route.options.headers?.(assetContext),\n ]).then(([headFnContent, scripts, headers]) => {\n const meta = headFnContent?.meta\n const links = headFnContent?.links\n const headScripts = headFnContent?.scripts\n const styles = headFnContent?.styles\n\n return {\n meta,\n links,\n headScripts,\n headers,\n scripts,\n styles,\n }\n })\n}\n\nconst getLoaderContext = (\n inner: InnerLoadContext,\n matchPromises: Array<Promise<AnyRouteMatch>>,\n matchId: string,\n index: number,\n route: AnyRoute,\n): LoaderFnContext => {\n const parentMatchPromise = matchPromises[index - 1] as any\n const { params, loaderDeps, abortController, cause } =\n inner.router.getMatch(matchId)!\n\n const context = buildMatchContext(inner, index)\n\n const preload = resolvePreload(inner, matchId)\n\n return {\n params,\n deps: loaderDeps,\n preload: !!preload,\n parentMatchPromise,\n abortController,\n context,\n location: inner.location,\n navigate: (opts) =>\n inner.router.navigate({\n ...opts,\n _fromLocation: inner.location,\n }),\n cause: preload ? 'preload' : cause,\n route,\n ...inner.router.options.additionalContext,\n }\n}\n\nconst runLoader = async (\n inner: InnerLoadContext,\n matchPromises: Array<Promise<AnyRouteMatch>>,\n matchId: string,\n index: number,\n route: AnyRoute,\n): Promise<void> => {\n try {\n // If the Matches component rendered\n // the pending component and needs to show it for\n // a minimum duration, we''ll wait for it to resolve\n // before committing to the match and resolving\n // the loadPromise\n\n const match = inner.router.getMatch(matchId)!\n\n // Actually run the loader and handle the result\n try {\n if (!(isServer ?? inner.router.isServer) || match.ssr === true) {\n loadRouteChunk(route)\n }\n\n // Kick off the loader!\n const routeLoader = route.options.loader\n const loader =\n typeof routeLoader === 'function' ? routeLoader : routeLoader?.handler\n const loaderResult = loader?.(\n getLoaderContext(inner, matchPromises, matchId, index, route),\n )\n const loaderResultIsPromise = !!loader && isPromise(loaderResult)\n\n const willLoadSomething = !!(\n loaderResultIsPromise ||\n route._lazyPromise ||\n route._componentsPromise ||\n route.options.head ||\n route.options.scripts ||\n route.options.headers ||\n match._nonReactive.minPendingPromise\n )\n\n if (willLoadSomething) {\n inner.updateMatch(matchId, (prev) => ({\n ...prev,\n isFetching: 'loader',\n }))\n }\n\n if (loader) {\n const loaderData = loaderResultIsPromise\n ? await loaderResult\n : loaderResult\n\n handleRedirectAndNotFound(\n inner,\n inner.router.getMatch(matchId),\n loaderData,\n )\n if (loaderData !== undefined) {\n inner.updateMatch(matchId, (prev) => ({\n ...prev,\n loaderData,\n }))\n }\n }\n\n // Lazy option can modify the route options,\n // so we need to wait for it to resolve before\n // we can use the options\n if (route._lazyPromise) await route._lazyPromise\n const pendingPromise = match._nonReactive.minPendingPromise\n if (pendingPromise) await pendingPromise\n\n // Last but not least, wait for the the components\n // to be preloaded before we resolve the match\n if (route._componentsPromise) await route._componentsPromise\n inner.updateMatch(matchId, (prev) => ({\n ...prev,\n error: undefined,\n context: buildMatchContext(inner, index),\n status: 'success',\n isFetching: false,\n updatedAt: Date.now(),\n }))\n } catch (e) {\n let error = e\n\n if ((error as any)?.name === 'AbortError') {\n if (match.abortController.signal.aborted) {\n match._nonReactive.loaderPromise?.resolve()\n match._nonReactive.loaderPromise = undefined\n return\n }\n inner.updateMatch(matchId, (prev) => ({\n ...prev,\n status: prev.status === 'pending' ? 'success' : prev.status,\n isFetching: false,\n context: buildMatchContext(inner, index),\n }))\n return\n }\n\n const pendingPromise = match._nonReactive.minPendingPromise\n if (pendingPromise) await pendingPromise\n\n if (isNotFound(e)) {\n await (route.options.notFoundComponent as any)?.preload?.()\n }\n\n handleRedirectAndNotFound(inner, inner.router.getMatch(matchId), e)\n\n try {\n route.options.onError?.(e)\n } catch (onErrorError) {\n error = onErrorError\n handleRedirectAndNotFound(\n inner,\n inner.router.getMatch(matchId),\n onErrorError,\n )\n }\n if (!isRedirect(error) && !isNotFound(error)) {\n await loadRouteChunk(route, ['errorComponent'])\n }\n\n inner.updateMatch(matchId, (prev) => ({\n ...prev,\n error,\n context: buildMatchContext(inner, index),\n status: 'error',\n isFetching: false,\n }))\n }\n } catch (err) {\n const match = inner.router.getMatch(matchId)\n // in case of a redirecting match during preload, the match does not exist\n if (match) {\n match._nonReactive.loaderPromise = undefined\n }\n handleRedirectAndNotFound(inner, match, err)\n }\n}\n\nconst loadRouteMatch = async (\n inner: InnerLoadContext,\n matchPromises: Array<Promise<AnyRouteMatch>>,\n index: number,\n): Promise<AnyRouteMatch> => {\n async function handleLoader(\n preload: boolean,\n prevMatch: AnyRouteMatch,\n previousRouteMatchId: string | undefined,\n match: AnyRouteMatch,\n route: AnyRoute,\n ) {\n const age = Date.now() - prevMatch.updatedAt\n\n const staleAge = preload\n ? (route.options.preloadStaleTime ??\n inner.router.options.defaultPreloadStaleTime ??\n 30_000) // 30 seconds for preloads by default\n : (route.options.staleTime ?? inner.router.options.defaultStaleTime ?? 0)\n\n const shouldReloadOption = route.options.shouldReload\n\n // Default to reloading the route all the time\n // Allow shouldReload to get the last say,\n // if provided.\n const shouldReload =\n typeof shouldReloadOption === 'function'\n ? shouldReloadOption(\n getLoaderContext(inner, matchPromises, matchId, index, route),\n )\n : shouldReloadOption\n\n // If the route is successful and still fresh, just resolve\n const { status, invalid } = match\n const staleMatchShouldReload =\n age >= staleAge &&\n (!!inner.forceStaleReload ||\n match.cause === 'enter' ||\n (previousRouteMatchId !== undefined &&\n previousRouteMatchId !== match.id))\n loaderShouldRunAsync =\n status === 'success' &&\n (invalid || (shouldReload ?? staleMatchShouldReload))\n if (preload && route.options.preload === false) {\n // Do nothing\n } else if (\n loaderShouldRunAsync &&\n !inner.sync &&\n shouldReloadInBackground\n ) {\n loaderIsRunningAsync = true\n ;(async () => {\n try {\n await runLoader(inner, matchPromises, matchId, index, route)\n const match = inner.router.getMatch(matchId)!\n match._nonReactive.loaderPromise?.resolve()\n match._nonReactive.loadPromise?.resolve()\n match._nonReactive.loaderPromise = undefined\n match._nonReactive.loadPromise = undefined\n } catch (err) {\n if (isRedirect(err)) {\n await inner.router.navigate(err.options)\n }\n }\n })()\n } else if (status !== 'success' || loaderShouldRunAsync) {\n await runLoader(inner, matchPromises, matchId, index, route)\n } else {\n syncMatchContext(inner, matchId, index)\n }\n }\n\n const { id: matchId, routeId } = inner.matches[index]!\n let loaderShouldRunAsync = false\n let loaderIsRunningAsync = false\n const route = inner.router.looseRoutesById[routeId]!\n const routeLoader = route.options.loader\n const shouldReloadInBackground =\n ((typeof routeLoader === 'function'\n ? undefined\n : routeLoader?.staleReloadMode) ??\n inner.router.options.defaultStaleReloadMode) !== 'blocking'\n\n if (shouldSkipLoader(inner, matchId)) {\n const match = inner.router.getMatch(matchId)\n if (!match) {\n return inner.matches[index]!\n }\n\n syncMatchContext(inner, matchId, index)\n\n if (isServer ?? inner.router.isServer) {\n return inner.router.getMatch(matchId)!\n }\n } else {\n const prevMatch = inner.router.getMatch(matchId)! // This is where all of the stale-while-revalidate magic happens\n const activeIdAtIndex = inner.router.stores.matchesId.state[index]\n const activeAtIndex =\n (activeIdAtIndex &&\n inner.router.stores.activeMatchStoresById.get(activeIdAtIndex)) ||\n null\n const previousRouteMatchId =\n activeAtIndex?.routeId === routeId\n ? activeIdAtIndex\n : inner.router.stores.activeMatchesSnapshot.state.find(\n (d) => d.routeId === routeId,\n )?.id\n const preload = resolvePreload(inner, matchId)\n\n // there is a loaderPromise, so we are in the middle of a load\n if (prevMatch._nonReactive.loaderPromise) {\n // do not block if we already have stale data we can show\n // but only if the ongoing load is not a preload since error handling is different for preloads\n // and we don't want to swallow errors\n if (\n prevMatch.status === 'success' &&\n !inner.sync &&\n !prevMatch.preload &&\n shouldReloadInBackground\n ) {\n return prevMatch\n }\n await prevMatch._nonReactive.loaderPromise\n const match = inner.router.getMatch(matchId)!\n const error = match._nonReactive.error || match.error\n if (error) {\n handleRedirectAndNotFound(inner, match, error)\n }\n\n if (match.status === 'pending') {\n await handleLoader(\n preload,\n prevMatch,\n previousRouteMatchId,\n match,\n route,\n )\n }\n } else {\n const nextPreload =\n preload && !inner.router.stores.activeMatchStoresById.has(matchId)\n const match = inner.router.getMatch(matchId)!\n match._nonReactive.loaderPromise = createControlledPromise<void>()\n if (nextPreload !== match.preload) {\n inner.updateMatch(matchId, (prev) => ({\n ...prev,\n preload: nextPreload,\n }))\n }\n\n await handleLoader(preload, prevMatch, previousRouteMatchId, match, route)\n }\n }\n const match = inner.router.getMatch(matchId)!\n if (!loaderIsRunningAsync) {\n match._nonReactive.loaderPromise?.resolve()\n match._nonReactive.loadPromise?.resolve()\n match._nonReactive.loadPromise = undefined\n }\n\n clearTimeout(match._nonReactive.pendingTimeout)\n match._nonReactive.pendingTimeout = undefined\n if (!loaderIsRunningAsync) match._nonReactive.loaderPromise = undefined\n match._nonReactive.dehydrated = undefined\n\n const nextIsFetching = loaderIsRunningAsync ? match.isFetching : false\n if (nextIsFetching !== match.isFetching || match.invalid !== false) {\n inner.updateMatch(matchId, (prev) => ({\n ...prev,\n isFetching: nextIsFetching,\n invalid: false,\n }))\n return inner.router.getMatch(matchId)!\n } else {\n return match\n }\n}\n\nexport async function loadMatches(arg: {\n router: AnyRouter\n location: ParsedLocation\n matches: Array<AnyRouteMatch>\n preload?: boolean\n forceStaleReload?: boolean\n onReady?: () => Promise<void>\n updateMatch: UpdateMatchFn\n sync?: boolean\n}): Promise<Array<MakeRouteMatch>> {\n const inner: InnerLoadContext = arg\n const matchPromises: Array<Promise<AnyRouteMatch>> = []\n\n // make sure the pending component is immediately rendered when hydrating a match that is not SSRed\n // the pending component was already rendered on the server and we want to keep it shown on the client until minPendingMs is reached\n if (\n !(isServer ?? inner.router.isServer) &&\n hasForcePendingActiveMatch(inner.router)\n ) {\n triggerOnReady(inner)\n }\n\n let beforeLoadNotFound: NotFoundError | undefined\n\n // Execute all beforeLoads one by one\n for (let i = 0; i < inner.matches.length; i++) {\n try {\n const beforeLoad = handleBeforeLoad(inner, i)\n if (isPromise(beforeLoad)) await beforeLoad\n } catch (err) {\n if (isRedirect(err)) {\n throw err\n }\n if (isNotFound(err)) {\n beforeLoadNotFound = err\n } else {\n if (!inner.preload) throw err\n }\n break\n }\n\n if (inner.serialError || inner.firstBadMatchIndex != null) {\n break\n }\n }\n\n // Execute loaders once, with max index adapted for beforeLoad notFound handling.\n const baseMaxIndexExclusive = inner.firstBadMatchIndex ?? inner.matches.length\n\n const boundaryIndex =\n beforeLoadNotFound && !inner.preload\n ? getNotFoundBoundaryIndex(inner, beforeLoadNotFound)\n : undefined\n\n const maxIndexExclusive =\n beforeLoadNotFound && inner.preload\n ? 0\n : boundaryIndex !== undefined\n ? Math.min(boundaryIndex + 1, baseMaxIndexExclusive)\n : baseMaxIndexExclusive\n\n let firstNotFound: NotFoundError | undefined\n let firstUnhandledRejection: unknown\n\n for (let i = 0; i < maxIndexExclusive; i++) {\n matchPromises.push(loadRouteMatch(inner, matchPromises, i))\n }\n\n try {\n await Promise.all(matchPromises)\n } catch {\n const settled = await Promise.allSettled(matchPromises)\n\n for (const result of settled) {\n if (result.status !== 'rejected') continue\n\n const reason = result.reason\n if (isRedirect(reason)) {\n throw reason\n }\n if (isNotFound(reason)) {\n firstNotFound ??= reason\n } else {\n firstUnhandledRejection ??= reason\n }\n }\n\n if (firstUnhandledRejection !== undefined) {\n throw firstUnhandledRejection\n }\n }\n\n const notFoundToThrow =\n firstNotFound ??\n (beforeLoadNotFound && !inner.preload ? beforeLoadNotFound : undefined)\n\n let headMaxIndex =\n inner.firstBadMatchIndex !== undefined\n ? inner.firstBadMatchIndex\n : inner.matches.length - 1\n\n if (!notFoundToThrow && beforeLoadNotFound && inner.preload) {\n return inner.matches\n }\n\n if (notFoundToThrow) {\n // Determine once which matched route will actually render the\n // notFoundComponent, then pass this precomputed index through the remaining\n // finalization steps.\n // This can differ from the throwing route when routeId targets an ancestor\n // boundary (or when bubbling resolves to a parent/root boundary).\n const renderedBoundaryIndex = getNotFoundBoundaryIndex(\n inner,\n notFoundToThrow,\n )\n\n if (renderedBoundaryIndex === undefined) {\n if (process.env.NODE_ENV !== 'production') {\n throw new Error(\n 'Invariant failed: Could not find match for notFound boundary',\n )\n }\n\n invariant()\n }\n const boundaryMatch = inner.matches[renderedBoundaryIndex]!\n\n const boundaryRoute = inner.router.looseRoutesById[boundaryMatch.routeId]!\n const defaultNotFoundComponent = (inner.router.options as any)\n ?.defaultNotFoundComponent\n\n // Ensure a notFoundComponent exists on the boundary route\n if (!boundaryRoute.options.notFoundComponent && defaultNotFoundComponent) {\n boundaryRoute.options.notFoundComponent = defaultNotFoundComponent\n }\n\n notFoundToThrow.routeId = boundaryMatch.routeId\n\n const boundaryIsRoot = boundaryMatch.routeId === inner.router.routeTree.id\n\n inner.updateMatch(boundaryMatch.id, (prev) => ({\n ...prev,\n ...(boundaryIsRoot\n ? // For root boundary, use globalNotFound so the root component's\n // shell still renders and <Outlet> handles the not-found display,\n // instead of replacing the entire root shell via status='notFound'.\n { status: 'success' as const, globalNotFound: true, error: undefined }\n : // For non-root boundaries, set status:'notFound' so MatchInner\n // renders the notFoundComponent directly.\n { status: 'notFound' as const, error: notFoundToThrow }),\n isFetching: false,\n }))\n\n headMaxIndex = renderedBoundaryIndex\n\n // Ensure the rendering boundary route chunk (and its lazy components, including\n // lazy notFoundComponent) is loaded before we continue to head execution/render.\n await loadRouteChunk(boundaryRoute, ['notFoundComponent'])\n } else if (!inner.preload) {\n // Clear stale root global-not-found state on normal navigations that do not\n // throw notFound. This must live here (instead of only in runLoader success)\n // because the root loader may be skipped when data is still fresh.\n const rootMatch = inner.matches[0]!\n // `rootMatch` is the next match for this navigation. If it is not global\n // not-found, then any currently stored root global-not-found is stale.\n if (!rootMatch.globalNotFound) {\n // `currentRootMatch` is the current store state (from the previous\n // navigation/load). Update only when a stale flag is actually present.\n const currentRootMatch = inner.router.getMatch(rootMatch.id)\n if (currentRootMatch?.globalNotFound) {\n inner.updateMatch(rootMatch.id, (prev) => ({\n ...prev,\n globalNotFound: false,\n error: undefined,\n }))\n }\n }\n }\n\n // When a serial error occurred (e.g. beforeLoad threw a regular Error),\n // the erroring route's lazy chunk wasn't loaded because loaders were skipped.\n // We need to load it so the code-split errorComponent is available for rendering.\n if (inner.serialError && inner.firstBadMatchIndex !== undefined) {\n const errorRoute =\n inner.router.looseRoutesById[\n inner.matches[inner.firstBadMatchIndex]!.routeId\n ]!\n await loadRouteChunk(errorRoute, ['errorComponent'])\n }\n\n // serially execute heads once after loaders/notFound handling, ensuring\n // all head functions get a chance even if one throws.\n for (let i = 0; i <= headMaxIndex; i++) {\n const match = inner.matches[i]!\n const { id: matchId, routeId } = match\n const route = inner.router.looseRoutesById[routeId]!\n try {\n const headResult = executeHead(inner, matchId, route)\n if (headResult) {\n const head = await headResult\n inner.updateMatch(matchId, (prev) => ({\n ...prev,\n ...head,\n }))\n }\n } catch (err) {\n console.error(`Error executing head for route ${routeId}:`, err)\n }\n }\n\n const readyPromise = triggerOnReady(inner)\n if (isPromise(readyPromise)) {\n await readyPromise\n }\n\n if (notFoundToThrow) {\n throw notFoundToThrow\n }\n\n if (inner.serialError && !inner.preload && !inner.onReady) {\n throw inner.serialError\n }\n\n return inner.matches\n}\n\nexport type RouteComponentType =\n | 'component'\n | 'errorComponent'\n | 'pendingComponent'\n | 'notFoundComponent'\n\nfunction preloadRouteComponents(\n route: AnyRoute,\n componentTypesToLoad: Array<RouteComponentType>,\n): Promise<void> | undefined {\n const preloads = componentTypesToLoad\n .map((type) => (route.options[type] as any)?.preload?.())\n .filter(Boolean)\n\n if (preloads.length === 0) return undefined\n\n return Promise.all(preloads) as any as Promise<void>\n}\n\nexport function loadRouteChunk(\n route: AnyRoute,\n componentTypesToLoad: Array<RouteComponentType> = componentTypes,\n) {\n if (!route._lazyLoaded && route._lazyPromise === undefined) {\n if (route.lazyFn) {\n route._lazyPromise = route.lazyFn().then((lazyRoute) => {\n // explicitly don't copy over the lazy route's id\n const { id: _id, ...options } = lazyRoute.options\n Object.assign(route.options, options)\n route._lazyLoaded = true\n route._lazyPromise = undefined // gc promise, we won't need it anymore\n })\n } else {\n route._lazyLoaded = true\n }\n }\n\n const runAfterLazy = () =>\n route._componentsLoaded\n ? undefined\n : componentTypesToLoad === componentTypes\n ? (() => {\n if (route._componentsPromise === undefined) {\n const componentsPromise = preloadRouteComponents(\n route,\n componentTypes,\n )\n\n if (componentsPromise) {\n route._componentsPromise = componentsPromise.then(() => {\n route._componentsLoaded = true\n route._componentsPromise = undefined // gc promise, we won't need it anymore\n })\n } else {\n route._componentsLoaded = true\n }\n }\n\n return route._componentsPromise\n })()\n : preloadRouteComponents(route, componentTypesToLoad)\n\n return route._lazyPromise\n ? route._lazyPromise.then(runAfterLazy)\n : runAfterLazy()\n}\n\nfunction makeMaybe<TValue, TError>(\n value: TValue,\n error: TError,\n): { status: 'success'; value: TValue } | { status: 'error'; error: TError } {\n if (error) {\n return { status: 'error' as const, error }\n }\n return { status: 'success' as const, value }\n}\n\nexport function routeNeedsPreload(route: AnyRoute) {\n for (const componentType of componentTypes) {\n if ((route.options[componentType] as any)?.preload) {\n return true\n }\n }\n return false\n}\n\nexport const componentTypes: Array<RouteComponentType> = [\n 'component',\n 'errorComponent',\n 'pendingComponent',\n 'notFoundComponent',\n] as const\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"load-matches.cjs","names":[],"sources":["../../src/load-matches.ts"],"sourcesContent":["import { isServer } from '@tanstack/router-core/isServer'\nimport { invariant } from './invariant'\nimport { createControlledPromise, isPromise } from './utils'\nimport { isNotFound } from './not-found'\nimport { rootRouteId } from './root'\nimport { isRedirect } from './redirect'\nimport type { NotFoundError } from './not-found'\nimport type { ParsedLocation } from './location'\nimport type {\n AnyRoute,\n BeforeLoadContextOptions,\n LoaderFnContext,\n SsrContextOptions,\n} from './route'\nimport type { AnyRouteMatch, MakeRouteMatch } from './Matches'\nimport type { AnyRouter, SSROption, UpdateMatchFn } from './router'\n\n/**\n * An object of this shape is created when calling `loadMatches`.\n * It contains everything we need for all other functions in this file\n * to work. (It's basically the function's argument, plus a few mutable states)\n */\ntype InnerLoadContext = {\n /** the calling router instance */\n router: AnyRouter\n location: ParsedLocation\n /** mutable state, scoped to a `loadMatches` call */\n firstBadMatchIndex?: number\n /** mutable state, scoped to a `loadMatches` call */\n rendered?: boolean\n serialError?: unknown\n updateMatch: UpdateMatchFn\n matches: Array<AnyRouteMatch>\n preload?: boolean\n forceStaleReload?: boolean\n onReady?: () => Promise<void>\n sync?: boolean\n}\n\nconst triggerOnReady = (inner: InnerLoadContext): void | Promise<void> => {\n if (!inner.rendered) {\n inner.rendered = true\n return inner.onReady?.()\n }\n}\n\nconst hasForcePendingActiveMatch = (router: AnyRouter): boolean => {\n return router.stores.matchesId.get().some((matchId) => {\n return router.stores.matchStores.get(matchId)?.get()._forcePending\n })\n}\n\nconst resolvePreload = (inner: InnerLoadContext, matchId: string): boolean => {\n return !!(inner.preload && !inner.router.stores.matchStores.has(matchId))\n}\n\n/**\n * Builds the accumulated context from router options and all matches up to (and optionally including) the given index.\n * Merges __routeContext and __beforeLoadContext from each match.\n */\nconst buildMatchContext = (\n inner: InnerLoadContext,\n index: number,\n includeCurrentMatch: boolean = true,\n): Record<string, unknown> => {\n const context: Record<string, unknown> = {\n ...(inner.router.options.context ?? {}),\n }\n const end = includeCurrentMatch ? index : index - 1\n for (let i = 0; i <= end; i++) {\n const innerMatch = inner.matches[i]\n if (!innerMatch) continue\n const m = inner.router.getMatch(innerMatch.id)\n if (!m) continue\n Object.assign(context, m.__routeContext, m.__beforeLoadContext)\n }\n return context\n}\n\nconst getNotFoundBoundaryIndex = (\n inner: InnerLoadContext,\n err: NotFoundError,\n): number | undefined => {\n if (!inner.matches.length) {\n return undefined\n }\n\n const requestedRouteId = err.routeId\n const matchedRootIndex = inner.matches.findIndex(\n (m) => m.routeId === inner.router.routeTree.id,\n )\n const rootIndex = matchedRootIndex >= 0 ? matchedRootIndex : 0\n\n let startIndex = requestedRouteId\n ? inner.matches.findIndex((match) => match.routeId === requestedRouteId)\n : (inner.firstBadMatchIndex ?? inner.matches.length - 1)\n\n if (startIndex < 0) {\n startIndex = rootIndex\n }\n\n for (let i = startIndex; i >= 0; i--) {\n const match = inner.matches[i]!\n const route = inner.router.looseRoutesById[match.routeId]!\n if (route.options.notFoundComponent) {\n return i\n }\n }\n\n // If no boundary component is found, preserve explicit routeId targeting behavior,\n // otherwise default to root for untargeted notFounds.\n return requestedRouteId ? startIndex : rootIndex\n}\n\nconst handleRedirectAndNotFound = (\n inner: InnerLoadContext,\n match: AnyRouteMatch | undefined,\n err: unknown,\n): void => {\n if (!isRedirect(err) && !isNotFound(err)) return\n\n if (isRedirect(err) && err.redirectHandled && !err.options.reloadDocument) {\n throw err\n }\n\n // in case of a redirecting match during preload, the match does not exist\n if (match) {\n match._nonReactive.beforeLoadPromise?.resolve()\n match._nonReactive.loaderPromise?.resolve()\n match._nonReactive.beforeLoadPromise = undefined\n match._nonReactive.loaderPromise = undefined\n\n match._nonReactive.error = err\n\n inner.updateMatch(match.id, (prev) => ({\n ...prev,\n status: isRedirect(err)\n ? 'redirected'\n : prev.status === 'pending'\n ? 'success'\n : prev.status,\n context: buildMatchContext(inner, match.index),\n isFetching: false,\n error: err,\n }))\n\n if (isNotFound(err) && !err.routeId) {\n // Stamp the throwing match's routeId so that the finalization step in\n // loadMatches knows where the notFound originated. The actual boundary\n // resolution (walking up to the nearest notFoundComponent) is deferred to\n // the finalization step, where firstBadMatchIndex is stable and\n // headMaxIndex can be capped correctly.\n err.routeId = match.routeId\n }\n\n match._nonReactive.loadPromise?.resolve()\n }\n\n if (isRedirect(err)) {\n inner.rendered = true\n err.options._fromLocation = inner.location\n err.redirectHandled = true\n err = inner.router.resolveRedirect(err)\n }\n\n throw err\n}\n\nconst shouldSkipLoader = (\n inner: InnerLoadContext,\n matchId: string,\n): boolean => {\n const match = inner.router.getMatch(matchId)\n if (!match) {\n return true\n }\n // upon hydration, we skip the loader if the match has been dehydrated on the server\n if (!(isServer ?? inner.router.isServer) && match._nonReactive.dehydrated) {\n return true\n }\n\n if ((isServer ?? inner.router.isServer) && match.ssr === false) {\n return true\n }\n\n return false\n}\n\nconst syncMatchContext = (\n inner: InnerLoadContext,\n matchId: string,\n index: number,\n): void => {\n const nextContext = buildMatchContext(inner, index)\n\n inner.updateMatch(matchId, (prev) => {\n return {\n ...prev,\n context: nextContext,\n }\n })\n}\n\nconst handleSerialError = (\n inner: InnerLoadContext,\n index: number,\n err: any,\n routerCode: string,\n): void => {\n const { id: matchId, routeId } = inner.matches[index]!\n const route = inner.router.looseRoutesById[routeId]!\n\n // Much like suspense, we use a promise here to know if\n // we've been outdated by a new loadMatches call and\n // should abort the current async operation\n if (err instanceof Promise) {\n throw err\n }\n\n err.routerCode = routerCode\n inner.firstBadMatchIndex ??= index\n handleRedirectAndNotFound(inner, inner.router.getMatch(matchId), err)\n\n try {\n route.options.onError?.(err)\n } catch (errorHandlerErr) {\n err = errorHandlerErr\n handleRedirectAndNotFound(inner, inner.router.getMatch(matchId), err)\n }\n\n inner.updateMatch(matchId, (prev) => {\n prev._nonReactive.beforeLoadPromise?.resolve()\n prev._nonReactive.beforeLoadPromise = undefined\n prev._nonReactive.loadPromise?.resolve()\n\n return {\n ...prev,\n error: err,\n status: 'error',\n isFetching: false,\n updatedAt: Date.now(),\n abortController: new AbortController(),\n }\n })\n\n if (!inner.preload && !isRedirect(err) && !isNotFound(err)) {\n inner.serialError ??= err\n }\n}\n\nconst isBeforeLoadSsr = (\n inner: InnerLoadContext,\n matchId: string,\n index: number,\n route: AnyRoute,\n): void | Promise<void> => {\n const existingMatch = inner.router.getMatch(matchId)!\n const parentMatchId = inner.matches[index - 1]?.id\n const parentMatch = parentMatchId\n ? inner.router.getMatch(parentMatchId)!\n : undefined\n\n // in SPA mode, only SSR the root route\n if (inner.router.isShell()) {\n existingMatch.ssr = route.id === rootRouteId\n return\n }\n\n if (parentMatch?.ssr === false) {\n existingMatch.ssr = false\n return\n }\n\n const parentOverride = (tempSsr: SSROption) => {\n if (tempSsr === true && parentMatch?.ssr === 'data-only') {\n return 'data-only'\n }\n return tempSsr\n }\n\n const defaultSsr = inner.router.options.defaultSsr ?? true\n\n if (route.options.ssr === undefined) {\n existingMatch.ssr = parentOverride(defaultSsr)\n return\n }\n\n if (typeof route.options.ssr !== 'function') {\n existingMatch.ssr = parentOverride(route.options.ssr)\n return\n }\n const { search, params } = existingMatch\n\n const ssrFnContext: SsrContextOptions<any, any, any> = {\n search: makeMaybe(search, existingMatch.searchError),\n params: makeMaybe(params, existingMatch.paramsError),\n location: inner.location,\n matches: inner.matches.map((match) => ({\n index: match.index,\n pathname: match.pathname,\n fullPath: match.fullPath,\n staticData: match.staticData,\n id: match.id,\n routeId: match.routeId,\n search: makeMaybe(match.search, match.searchError),\n params: makeMaybe(match.params, match.paramsError),\n ssr: match.ssr,\n })),\n }\n\n const tempSsr = route.options.ssr(ssrFnContext)\n if (isPromise(tempSsr)) {\n return tempSsr.then((ssr) => {\n existingMatch.ssr = parentOverride(ssr ?? defaultSsr)\n })\n }\n\n existingMatch.ssr = parentOverride(tempSsr ?? defaultSsr)\n return\n}\n\nconst setupPendingTimeout = (\n inner: InnerLoadContext,\n matchId: string,\n route: AnyRoute,\n match: AnyRouteMatch,\n): void => {\n if (match._nonReactive.pendingTimeout !== undefined) return\n\n const pendingMs =\n route.options.pendingMs ?? inner.router.options.defaultPendingMs\n const shouldPending = !!(\n inner.onReady &&\n !(isServer ?? inner.router.isServer) &&\n !resolvePreload(inner, matchId) &&\n (route.options.loader ||\n route.options.beforeLoad ||\n routeNeedsPreload(route)) &&\n typeof pendingMs === 'number' &&\n pendingMs !== Infinity &&\n (route.options.pendingComponent ??\n (inner.router.options as any)?.defaultPendingComponent)\n )\n\n if (shouldPending) {\n const pendingTimeout = setTimeout(() => {\n // Update the match and prematurely resolve the loadMatches promise so that\n // the pending component can start rendering\n triggerOnReady(inner)\n }, pendingMs)\n match._nonReactive.pendingTimeout = pendingTimeout\n }\n}\n\nconst preBeforeLoadSetup = (\n inner: InnerLoadContext,\n matchId: string,\n route: AnyRoute,\n): void | Promise<void> => {\n const existingMatch = inner.router.getMatch(matchId)!\n\n // If we are in the middle of a load, either of these will be present\n // (not to be confused with `loadPromise`, which is always defined)\n if (\n !existingMatch._nonReactive.beforeLoadPromise &&\n !existingMatch._nonReactive.loaderPromise\n )\n return\n\n setupPendingTimeout(inner, matchId, route, existingMatch)\n\n const then = () => {\n const match = inner.router.getMatch(matchId)!\n if (\n match.preload &&\n (match.status === 'redirected' || match.status === 'notFound')\n ) {\n handleRedirectAndNotFound(inner, match, match.error)\n }\n }\n\n // Wait for the previous beforeLoad to resolve before we continue\n return existingMatch._nonReactive.beforeLoadPromise\n ? existingMatch._nonReactive.beforeLoadPromise.then(then)\n : then()\n}\n\nconst executeBeforeLoad = (\n inner: InnerLoadContext,\n matchId: string,\n index: number,\n route: AnyRoute,\n): void | Promise<void> => {\n const match = inner.router.getMatch(matchId)!\n\n // explicitly capture the previous loadPromise\n let prevLoadPromise = match._nonReactive.loadPromise\n match._nonReactive.loadPromise = createControlledPromise<void>(() => {\n prevLoadPromise?.resolve()\n prevLoadPromise = undefined\n })\n\n const { paramsError, searchError } = match\n\n if (paramsError) {\n handleSerialError(inner, index, paramsError, 'PARSE_PARAMS')\n }\n\n if (searchError) {\n handleSerialError(inner, index, searchError, 'VALIDATE_SEARCH')\n }\n\n setupPendingTimeout(inner, matchId, route, match)\n\n const abortController = new AbortController()\n\n let isPending = false\n const pending = () => {\n if (isPending) return\n isPending = true\n inner.updateMatch(matchId, (prev) => ({\n ...prev,\n isFetching: 'beforeLoad',\n fetchCount: prev.fetchCount + 1,\n abortController,\n // Note: We intentionally don't update context here.\n // Context should only be updated after beforeLoad resolves to avoid\n // components seeing incomplete context during async beforeLoad execution.\n }))\n }\n\n const resolve = () => {\n match._nonReactive.beforeLoadPromise?.resolve()\n match._nonReactive.beforeLoadPromise = undefined\n inner.updateMatch(matchId, (prev) => ({\n ...prev,\n isFetching: false,\n }))\n }\n\n // if there is no `beforeLoad` option, just mark as pending and resolve\n // Context will be updated later in loadRouteMatch after loader completes\n if (!route.options.beforeLoad) {\n inner.router.batch(() => {\n pending()\n resolve()\n })\n return\n }\n\n match._nonReactive.beforeLoadPromise = createControlledPromise<void>()\n\n // Build context from all parent matches, excluding current match's __beforeLoadContext\n // (since we're about to execute beforeLoad for this match)\n const context = {\n ...buildMatchContext(inner, index, false),\n ...match.__routeContext,\n }\n const { search, params, cause } = match\n const preload = resolvePreload(inner, matchId)\n const beforeLoadFnContext: BeforeLoadContextOptions<\n any,\n any,\n any,\n any,\n any,\n any,\n any,\n any,\n any\n > = {\n search,\n abortController,\n params,\n preload,\n context,\n location: inner.location,\n navigate: (opts: any) =>\n inner.router.navigate({\n ...opts,\n _fromLocation: inner.location,\n }),\n buildLocation: inner.router.buildLocation,\n cause: preload ? 'preload' : cause,\n matches: inner.matches,\n routeId: route.id,\n ...inner.router.options.additionalContext,\n }\n\n const updateContext = (beforeLoadContext: any) => {\n if (beforeLoadContext === undefined) {\n inner.router.batch(() => {\n pending()\n resolve()\n })\n return\n }\n if (isRedirect(beforeLoadContext) || isNotFound(beforeLoadContext)) {\n pending()\n handleSerialError(inner, index, beforeLoadContext, 'BEFORE_LOAD')\n }\n\n inner.router.batch(() => {\n pending()\n inner.updateMatch(matchId, (prev) => ({\n ...prev,\n __beforeLoadContext: beforeLoadContext,\n }))\n resolve()\n })\n }\n\n let beforeLoadContext\n try {\n beforeLoadContext = route.options.beforeLoad(beforeLoadFnContext)\n if (isPromise(beforeLoadContext)) {\n pending()\n return beforeLoadContext\n .catch((err) => {\n handleSerialError(inner, index, err, 'BEFORE_LOAD')\n })\n .then(updateContext)\n }\n } catch (err) {\n pending()\n handleSerialError(inner, index, err, 'BEFORE_LOAD')\n }\n\n updateContext(beforeLoadContext)\n return\n}\n\nconst handleBeforeLoad = (\n inner: InnerLoadContext,\n index: number,\n): void | Promise<void> => {\n const { id: matchId, routeId } = inner.matches[index]!\n const route = inner.router.looseRoutesById[routeId]!\n\n const serverSsr = () => {\n // on the server, determine whether SSR the current match or not\n if (isServer ?? inner.router.isServer) {\n const maybePromise = isBeforeLoadSsr(inner, matchId, index, route)\n if (isPromise(maybePromise)) return maybePromise.then(queueExecution)\n }\n return queueExecution()\n }\n\n const execute = () => executeBeforeLoad(inner, matchId, index, route)\n\n const queueExecution = () => {\n if (shouldSkipLoader(inner, matchId)) return\n const result = preBeforeLoadSetup(inner, matchId, route)\n return isPromise(result) ? result.then(execute) : execute()\n }\n\n return serverSsr()\n}\n\nconst executeHead = (\n inner: InnerLoadContext,\n matchId: string,\n route: AnyRoute,\n): void | Promise<\n Pick<\n AnyRouteMatch,\n 'meta' | 'links' | 'headScripts' | 'headers' | 'scripts' | 'styles'\n >\n> => {\n const match = inner.router.getMatch(matchId)\n // in case of a redirecting match during preload, the match does not exist\n if (!match) {\n return\n }\n if (!route.options.head && !route.options.scripts && !route.options.headers) {\n return\n }\n const assetContext = {\n ssr: inner.router.options.ssr,\n matches: inner.matches,\n match,\n params: match.params,\n loaderData: match.loaderData,\n }\n\n return Promise.all([\n route.options.head?.(assetContext),\n route.options.scripts?.(assetContext),\n route.options.headers?.(assetContext),\n ]).then(([headFnContent, scripts, headers]) => {\n const meta = headFnContent?.meta\n const links = headFnContent?.links\n const headScripts = headFnContent?.scripts\n const styles = headFnContent?.styles\n\n return {\n meta,\n links,\n headScripts,\n headers,\n scripts,\n styles,\n }\n })\n}\n\nconst getLoaderContext = (\n inner: InnerLoadContext,\n matchPromises: Array<Promise<AnyRouteMatch>>,\n matchId: string,\n index: number,\n route: AnyRoute,\n): LoaderFnContext => {\n const parentMatchPromise = matchPromises[index - 1] as any\n const { params, loaderDeps, abortController, cause } =\n inner.router.getMatch(matchId)!\n\n const context = buildMatchContext(inner, index)\n\n const preload = resolvePreload(inner, matchId)\n\n return {\n params,\n deps: loaderDeps,\n preload: !!preload,\n parentMatchPromise,\n abortController,\n context,\n location: inner.location,\n navigate: (opts) =>\n inner.router.navigate({\n ...opts,\n _fromLocation: inner.location,\n }),\n cause: preload ? 'preload' : cause,\n route,\n ...inner.router.options.additionalContext,\n }\n}\n\nconst runLoader = async (\n inner: InnerLoadContext,\n matchPromises: Array<Promise<AnyRouteMatch>>,\n matchId: string,\n index: number,\n route: AnyRoute,\n): Promise<void> => {\n try {\n // If the Matches component rendered\n // the pending component and needs to show it for\n // a minimum duration, we''ll wait for it to resolve\n // before committing to the match and resolving\n // the loadPromise\n\n const match = inner.router.getMatch(matchId)!\n\n // Actually run the loader and handle the result\n try {\n if (!(isServer ?? inner.router.isServer) || match.ssr === true) {\n loadRouteChunk(route)\n }\n\n // Kick off the loader!\n const routeLoader = route.options.loader\n const loader =\n typeof routeLoader === 'function' ? routeLoader : routeLoader?.handler\n const loaderResult = loader?.(\n getLoaderContext(inner, matchPromises, matchId, index, route),\n )\n const loaderResultIsPromise = !!loader && isPromise(loaderResult)\n\n const willLoadSomething = !!(\n loaderResultIsPromise ||\n route._lazyPromise ||\n route._componentsPromise ||\n route.options.head ||\n route.options.scripts ||\n route.options.headers ||\n match._nonReactive.minPendingPromise\n )\n\n if (willLoadSomething) {\n inner.updateMatch(matchId, (prev) => ({\n ...prev,\n isFetching: 'loader',\n }))\n }\n\n if (loader) {\n const loaderData = loaderResultIsPromise\n ? await loaderResult\n : loaderResult\n\n handleRedirectAndNotFound(\n inner,\n inner.router.getMatch(matchId),\n loaderData,\n )\n if (loaderData !== undefined) {\n inner.updateMatch(matchId, (prev) => ({\n ...prev,\n loaderData,\n }))\n }\n }\n\n // Lazy option can modify the route options,\n // so we need to wait for it to resolve before\n // we can use the options\n if (route._lazyPromise) await route._lazyPromise\n const pendingPromise = match._nonReactive.minPendingPromise\n if (pendingPromise) await pendingPromise\n\n // Last but not least, wait for the the components\n // to be preloaded before we resolve the match\n if (route._componentsPromise) await route._componentsPromise\n inner.updateMatch(matchId, (prev) => ({\n ...prev,\n error: undefined,\n context: buildMatchContext(inner, index),\n status: 'success',\n isFetching: false,\n updatedAt: Date.now(),\n }))\n } catch (e) {\n let error = e\n\n if ((error as any)?.name === 'AbortError') {\n if (match.abortController.signal.aborted) {\n match._nonReactive.loaderPromise?.resolve()\n match._nonReactive.loaderPromise = undefined\n return\n }\n inner.updateMatch(matchId, (prev) => ({\n ...prev,\n status: prev.status === 'pending' ? 'success' : prev.status,\n isFetching: false,\n context: buildMatchContext(inner, index),\n }))\n return\n }\n\n const pendingPromise = match._nonReactive.minPendingPromise\n if (pendingPromise) await pendingPromise\n\n if (isNotFound(e)) {\n await (route.options.notFoundComponent as any)?.preload?.()\n }\n\n handleRedirectAndNotFound(inner, inner.router.getMatch(matchId), e)\n\n try {\n route.options.onError?.(e)\n } catch (onErrorError) {\n error = onErrorError\n handleRedirectAndNotFound(\n inner,\n inner.router.getMatch(matchId),\n onErrorError,\n )\n }\n if (!isRedirect(error) && !isNotFound(error)) {\n await loadRouteChunk(route, ['errorComponent'])\n }\n\n inner.updateMatch(matchId, (prev) => ({\n ...prev,\n error,\n context: buildMatchContext(inner, index),\n status: 'error',\n isFetching: false,\n }))\n }\n } catch (err) {\n const match = inner.router.getMatch(matchId)\n // in case of a redirecting match during preload, the match does not exist\n if (match) {\n match._nonReactive.loaderPromise = undefined\n }\n handleRedirectAndNotFound(inner, match, err)\n }\n}\n\nconst loadRouteMatch = async (\n inner: InnerLoadContext,\n matchPromises: Array<Promise<AnyRouteMatch>>,\n index: number,\n): Promise<AnyRouteMatch> => {\n async function handleLoader(\n preload: boolean,\n prevMatch: AnyRouteMatch,\n previousRouteMatchId: string | undefined,\n match: AnyRouteMatch,\n route: AnyRoute,\n ) {\n const age = Date.now() - prevMatch.updatedAt\n\n const staleAge = preload\n ? (route.options.preloadStaleTime ??\n inner.router.options.defaultPreloadStaleTime ??\n 30_000) // 30 seconds for preloads by default\n : (route.options.staleTime ?? inner.router.options.defaultStaleTime ?? 0)\n\n const shouldReloadOption = route.options.shouldReload\n\n // Default to reloading the route all the time\n // Allow shouldReload to get the last say,\n // if provided.\n const shouldReload =\n typeof shouldReloadOption === 'function'\n ? shouldReloadOption(\n getLoaderContext(inner, matchPromises, matchId, index, route),\n )\n : shouldReloadOption\n\n // If the route is successful and still fresh, just resolve\n const { status, invalid } = match\n const staleMatchShouldReload =\n age >= staleAge &&\n (!!inner.forceStaleReload ||\n match.cause === 'enter' ||\n (previousRouteMatchId !== undefined &&\n previousRouteMatchId !== match.id))\n loaderShouldRunAsync =\n status === 'success' &&\n (invalid || (shouldReload ?? staleMatchShouldReload))\n if (preload && route.options.preload === false) {\n // Do nothing\n } else if (\n loaderShouldRunAsync &&\n !inner.sync &&\n shouldReloadInBackground\n ) {\n loaderIsRunningAsync = true\n ;(async () => {\n try {\n await runLoader(inner, matchPromises, matchId, index, route)\n const match = inner.router.getMatch(matchId)!\n match._nonReactive.loaderPromise?.resolve()\n match._nonReactive.loadPromise?.resolve()\n match._nonReactive.loaderPromise = undefined\n match._nonReactive.loadPromise = undefined\n } catch (err) {\n if (isRedirect(err)) {\n await inner.router.navigate(err.options)\n }\n }\n })()\n } else if (status !== 'success' || loaderShouldRunAsync) {\n await runLoader(inner, matchPromises, matchId, index, route)\n } else {\n syncMatchContext(inner, matchId, index)\n }\n }\n\n const { id: matchId, routeId } = inner.matches[index]!\n let loaderShouldRunAsync = false\n let loaderIsRunningAsync = false\n const route = inner.router.looseRoutesById[routeId]!\n const routeLoader = route.options.loader\n const shouldReloadInBackground =\n ((typeof routeLoader === 'function'\n ? undefined\n : routeLoader?.staleReloadMode) ??\n inner.router.options.defaultStaleReloadMode) !== 'blocking'\n\n if (shouldSkipLoader(inner, matchId)) {\n const match = inner.router.getMatch(matchId)\n if (!match) {\n return inner.matches[index]!\n }\n\n syncMatchContext(inner, matchId, index)\n\n if (isServer ?? inner.router.isServer) {\n return inner.router.getMatch(matchId)!\n }\n } else {\n const prevMatch = inner.router.getMatch(matchId)! // This is where all of the stale-while-revalidate magic happens\n const activeIdAtIndex = inner.router.stores.matchesId.get()[index]\n const activeAtIndex =\n (activeIdAtIndex &&\n inner.router.stores.matchStores.get(activeIdAtIndex)) ||\n null\n const previousRouteMatchId =\n activeAtIndex?.routeId === routeId\n ? activeIdAtIndex\n : inner.router.stores.matches.get().find((d) => d.routeId === routeId)\n ?.id\n const preload = resolvePreload(inner, matchId)\n\n // there is a loaderPromise, so we are in the middle of a load\n if (prevMatch._nonReactive.loaderPromise) {\n // do not block if we already have stale data we can show\n // but only if the ongoing load is not a preload since error handling is different for preloads\n // and we don't want to swallow errors\n if (\n prevMatch.status === 'success' &&\n !inner.sync &&\n !prevMatch.preload &&\n shouldReloadInBackground\n ) {\n return prevMatch\n }\n await prevMatch._nonReactive.loaderPromise\n const match = inner.router.getMatch(matchId)!\n const error = match._nonReactive.error || match.error\n if (error) {\n handleRedirectAndNotFound(inner, match, error)\n }\n\n if (match.status === 'pending') {\n await handleLoader(\n preload,\n prevMatch,\n previousRouteMatchId,\n match,\n route,\n )\n }\n } else {\n const nextPreload =\n preload && !inner.router.stores.matchStores.has(matchId)\n const match = inner.router.getMatch(matchId)!\n match._nonReactive.loaderPromise = createControlledPromise<void>()\n if (nextPreload !== match.preload) {\n inner.updateMatch(matchId, (prev) => ({\n ...prev,\n preload: nextPreload,\n }))\n }\n\n await handleLoader(preload, prevMatch, previousRouteMatchId, match, route)\n }\n }\n const match = inner.router.getMatch(matchId)!\n if (!loaderIsRunningAsync) {\n match._nonReactive.loaderPromise?.resolve()\n match._nonReactive.loadPromise?.resolve()\n match._nonReactive.loadPromise = undefined\n }\n\n clearTimeout(match._nonReactive.pendingTimeout)\n match._nonReactive.pendingTimeout = undefined\n if (!loaderIsRunningAsync) match._nonReactive.loaderPromise = undefined\n match._nonReactive.dehydrated = undefined\n\n const nextIsFetching = loaderIsRunningAsync ? match.isFetching : false\n if (nextIsFetching !== match.isFetching || match.invalid !== false) {\n inner.updateMatch(matchId, (prev) => ({\n ...prev,\n isFetching: nextIsFetching,\n invalid: false,\n }))\n return inner.router.getMatch(matchId)!\n } else {\n return match\n }\n}\n\nexport async function loadMatches(arg: {\n router: AnyRouter\n location: ParsedLocation\n matches: Array<AnyRouteMatch>\n preload?: boolean\n forceStaleReload?: boolean\n onReady?: () => Promise<void>\n updateMatch: UpdateMatchFn\n sync?: boolean\n}): Promise<Array<MakeRouteMatch>> {\n const inner: InnerLoadContext = arg\n const matchPromises: Array<Promise<AnyRouteMatch>> = []\n\n // make sure the pending component is immediately rendered when hydrating a match that is not SSRed\n // the pending component was already rendered on the server and we want to keep it shown on the client until minPendingMs is reached\n if (\n !(isServer ?? inner.router.isServer) &&\n hasForcePendingActiveMatch(inner.router)\n ) {\n triggerOnReady(inner)\n }\n\n let beforeLoadNotFound: NotFoundError | undefined\n\n // Execute all beforeLoads one by one\n for (let i = 0; i < inner.matches.length; i++) {\n try {\n const beforeLoad = handleBeforeLoad(inner, i)\n if (isPromise(beforeLoad)) await beforeLoad\n } catch (err) {\n if (isRedirect(err)) {\n throw err\n }\n if (isNotFound(err)) {\n beforeLoadNotFound = err\n } else {\n if (!inner.preload) throw err\n }\n break\n }\n\n if (inner.serialError || inner.firstBadMatchIndex != null) {\n break\n }\n }\n\n // Execute loaders once, with max index adapted for beforeLoad notFound handling.\n const baseMaxIndexExclusive = inner.firstBadMatchIndex ?? inner.matches.length\n\n const boundaryIndex =\n beforeLoadNotFound && !inner.preload\n ? getNotFoundBoundaryIndex(inner, beforeLoadNotFound)\n : undefined\n\n const maxIndexExclusive =\n beforeLoadNotFound && inner.preload\n ? 0\n : boundaryIndex !== undefined\n ? Math.min(boundaryIndex + 1, baseMaxIndexExclusive)\n : baseMaxIndexExclusive\n\n let firstNotFound: NotFoundError | undefined\n let firstUnhandledRejection: unknown\n\n for (let i = 0; i < maxIndexExclusive; i++) {\n matchPromises.push(loadRouteMatch(inner, matchPromises, i))\n }\n\n try {\n await Promise.all(matchPromises)\n } catch {\n const settled = await Promise.allSettled(matchPromises)\n\n for (const result of settled) {\n if (result.status !== 'rejected') continue\n\n const reason = result.reason\n if (isRedirect(reason)) {\n throw reason\n }\n if (isNotFound(reason)) {\n firstNotFound ??= reason\n } else {\n firstUnhandledRejection ??= reason\n }\n }\n\n if (firstUnhandledRejection !== undefined) {\n throw firstUnhandledRejection\n }\n }\n\n const notFoundToThrow =\n firstNotFound ??\n (beforeLoadNotFound && !inner.preload ? beforeLoadNotFound : undefined)\n\n let headMaxIndex =\n inner.firstBadMatchIndex !== undefined\n ? inner.firstBadMatchIndex\n : inner.matches.length - 1\n\n if (!notFoundToThrow && beforeLoadNotFound && inner.preload) {\n return inner.matches\n }\n\n if (notFoundToThrow) {\n // Determine once which matched route will actually render the\n // notFoundComponent, then pass this precomputed index through the remaining\n // finalization steps.\n // This can differ from the throwing route when routeId targets an ancestor\n // boundary (or when bubbling resolves to a parent/root boundary).\n const renderedBoundaryIndex = getNotFoundBoundaryIndex(\n inner,\n notFoundToThrow,\n )\n\n if (renderedBoundaryIndex === undefined) {\n if (process.env.NODE_ENV !== 'production') {\n throw new Error(\n 'Invariant failed: Could not find match for notFound boundary',\n )\n }\n\n invariant()\n }\n const boundaryMatch = inner.matches[renderedBoundaryIndex]!\n\n const boundaryRoute = inner.router.looseRoutesById[boundaryMatch.routeId]!\n const defaultNotFoundComponent = (inner.router.options as any)\n ?.defaultNotFoundComponent\n\n // Ensure a notFoundComponent exists on the boundary route\n if (!boundaryRoute.options.notFoundComponent && defaultNotFoundComponent) {\n boundaryRoute.options.notFoundComponent = defaultNotFoundComponent\n }\n\n notFoundToThrow.routeId = boundaryMatch.routeId\n\n const boundaryIsRoot = boundaryMatch.routeId === inner.router.routeTree.id\n\n inner.updateMatch(boundaryMatch.id, (prev) => ({\n ...prev,\n ...(boundaryIsRoot\n ? // For root boundary, use globalNotFound so the root component's\n // shell still renders and <Outlet> handles the not-found display,\n // instead of replacing the entire root shell via status='notFound'.\n { status: 'success' as const, globalNotFound: true, error: undefined }\n : // For non-root boundaries, set status:'notFound' so MatchInner\n // renders the notFoundComponent directly.\n { status: 'notFound' as const, error: notFoundToThrow }),\n isFetching: false,\n }))\n\n headMaxIndex = renderedBoundaryIndex\n\n // Ensure the rendering boundary route chunk (and its lazy components, including\n // lazy notFoundComponent) is loaded before we continue to head execution/render.\n await loadRouteChunk(boundaryRoute, ['notFoundComponent'])\n } else if (!inner.preload) {\n // Clear stale root global-not-found state on normal navigations that do not\n // throw notFound. This must live here (instead of only in runLoader success)\n // because the root loader may be skipped when data is still fresh.\n const rootMatch = inner.matches[0]!\n // `rootMatch` is the next match for this navigation. If it is not global\n // not-found, then any currently stored root global-not-found is stale.\n if (!rootMatch.globalNotFound) {\n // `currentRootMatch` is the current store state (from the previous\n // navigation/load). Update only when a stale flag is actually present.\n const currentRootMatch = inner.router.getMatch(rootMatch.id)\n if (currentRootMatch?.globalNotFound) {\n inner.updateMatch(rootMatch.id, (prev) => ({\n ...prev,\n globalNotFound: false,\n error: undefined,\n }))\n }\n }\n }\n\n // When a serial error occurred (e.g. beforeLoad threw a regular Error),\n // the erroring route's lazy chunk wasn't loaded because loaders were skipped.\n // We need to load it so the code-split errorComponent is available for rendering.\n if (inner.serialError && inner.firstBadMatchIndex !== undefined) {\n const errorRoute =\n inner.router.looseRoutesById[\n inner.matches[inner.firstBadMatchIndex]!.routeId\n ]!\n await loadRouteChunk(errorRoute, ['errorComponent'])\n }\n\n // serially execute heads once after loaders/notFound handling, ensuring\n // all head functions get a chance even if one throws.\n for (let i = 0; i <= headMaxIndex; i++) {\n const match = inner.matches[i]!\n const { id: matchId, routeId } = match\n const route = inner.router.looseRoutesById[routeId]!\n try {\n const headResult = executeHead(inner, matchId, route)\n if (headResult) {\n const head = await headResult\n inner.updateMatch(matchId, (prev) => ({\n ...prev,\n ...head,\n }))\n }\n } catch (err) {\n console.error(`Error executing head for route ${routeId}:`, err)\n }\n }\n\n const readyPromise = triggerOnReady(inner)\n if (isPromise(readyPromise)) {\n await readyPromise\n }\n\n if (notFoundToThrow) {\n throw notFoundToThrow\n }\n\n if (inner.serialError && !inner.preload && !inner.onReady) {\n throw inner.serialError\n }\n\n return inner.matches\n}\n\nexport type RouteComponentType =\n | 'component'\n | 'errorComponent'\n | 'pendingComponent'\n | 'notFoundComponent'\n\nfunction preloadRouteComponents(\n route: AnyRoute,\n componentTypesToLoad: Array<RouteComponentType>,\n): Promise<void> | undefined {\n const preloads = componentTypesToLoad\n .map((type) => (route.options[type] as any)?.preload?.())\n .filter(Boolean)\n\n if (preloads.length === 0) return undefined\n\n return Promise.all(preloads) as any as Promise<void>\n}\n\nexport function loadRouteChunk(\n route: AnyRoute,\n componentTypesToLoad: Array<RouteComponentType> = componentTypes,\n) {\n if (!route._lazyLoaded && route._lazyPromise === undefined) {\n if (route.lazyFn) {\n route._lazyPromise = route.lazyFn().then((lazyRoute) => {\n // explicitly don't copy over the lazy route's id\n const { id: _id, ...options } = lazyRoute.options\n Object.assign(route.options, options)\n route._lazyLoaded = true\n route._lazyPromise = undefined // gc promise, we won't need it anymore\n })\n } else {\n route._lazyLoaded = true\n }\n }\n\n const runAfterLazy = () =>\n route._componentsLoaded\n ? undefined\n : componentTypesToLoad === componentTypes\n ? (() => {\n if (route._componentsPromise === undefined) {\n const componentsPromise = preloadRouteComponents(\n route,\n componentTypes,\n )\n\n if (componentsPromise) {\n route._componentsPromise = componentsPromise.then(() => {\n route._componentsLoaded = true\n route._componentsPromise = undefined // gc promise, we won't need it anymore\n })\n } else {\n route._componentsLoaded = true\n }\n }\n\n return route._componentsPromise\n })()\n : preloadRouteComponents(route, componentTypesToLoad)\n\n return route._lazyPromise\n ? route._lazyPromise.then(runAfterLazy)\n : runAfterLazy()\n}\n\nfunction makeMaybe<TValue, TError>(\n value: TValue,\n error: TError,\n): { status: 'success'; value: TValue } | { status: 'error'; error: TError } {\n if (error) {\n return { status: 'error' as const, error }\n }\n return { status: 'success' as const, value }\n}\n\nexport function routeNeedsPreload(route: AnyRoute) {\n for (const componentType of componentTypes) {\n if ((route.options[componentType] as any)?.preload) {\n return true\n }\n }\n return false\n}\n\nexport const componentTypes: Array<RouteComponentType> = [\n 'component',\n 'errorComponent',\n 'pendingComponent',\n 'notFoundComponent',\n] as const\n"],"mappings":"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"}
|
package/dist/cjs/router.cjs
CHANGED
|
@@ -130,7 +130,7 @@ var RouterCore = class {
|
|
|
130
130
|
if (this.history) this.updateLatestLocation();
|
|
131
131
|
needsLocationUpdate = true;
|
|
132
132
|
}
|
|
133
|
-
if (needsLocationUpdate && this.stores) this.stores.location.
|
|
133
|
+
if (needsLocationUpdate && this.stores) this.stores.location.set(this.latestLocation);
|
|
134
134
|
if (typeof window !== "undefined" && "CSS" in window && typeof window.CSS?.supports === "function") this.isViewTransitionTypesSupported = window.CSS.supports("selector(:active-view-transition-type(a)");
|
|
135
135
|
};
|
|
136
136
|
this.updateLatestLocation = () => {
|
|
@@ -234,12 +234,12 @@ var RouterCore = class {
|
|
|
234
234
|
match._nonReactive.pendingTimeout = void 0;
|
|
235
235
|
};
|
|
236
236
|
this.cancelMatches = () => {
|
|
237
|
-
this.stores.
|
|
237
|
+
this.stores.pendingIds.get().forEach((matchId) => {
|
|
238
238
|
this.cancelMatch(matchId);
|
|
239
239
|
});
|
|
240
|
-
this.stores.matchesId.
|
|
241
|
-
if (this.stores.
|
|
242
|
-
const match = this.stores.
|
|
240
|
+
this.stores.matchesId.get().forEach((matchId) => {
|
|
241
|
+
if (this.stores.pendingMatchStores.has(matchId)) return;
|
|
242
|
+
const match = this.stores.matchStores.get(matchId)?.get();
|
|
243
243
|
if (!match) return;
|
|
244
244
|
if (match.status === "pending" || match.isFetching === "loader") this.cancelMatch(matchId);
|
|
245
245
|
});
|
|
@@ -507,29 +507,28 @@ var RouterCore = class {
|
|
|
507
507
|
}
|
|
508
508
|
}
|
|
509
509
|
const pendingMatches = this.matchRoutes(this.latestLocation);
|
|
510
|
-
const nextCachedMatches = this.stores.
|
|
510
|
+
const nextCachedMatches = this.stores.cachedMatches.get().filter((d) => !pendingMatches.some((e) => e.id === d.id));
|
|
511
511
|
this.batch(() => {
|
|
512
|
-
this.stores.status.
|
|
513
|
-
this.stores.statusCode.
|
|
514
|
-
this.stores.isLoading.
|
|
515
|
-
this.stores.location.
|
|
516
|
-
this.stores.
|
|
517
|
-
this.stores.
|
|
512
|
+
this.stores.status.set("pending");
|
|
513
|
+
this.stores.statusCode.set(200);
|
|
514
|
+
this.stores.isLoading.set(true);
|
|
515
|
+
this.stores.location.set(this.latestLocation);
|
|
516
|
+
this.stores.setPending(pendingMatches);
|
|
517
|
+
this.stores.setCached(nextCachedMatches);
|
|
518
518
|
});
|
|
519
519
|
};
|
|
520
520
|
this.load = async (opts) => {
|
|
521
521
|
let redirect;
|
|
522
522
|
let notFound;
|
|
523
523
|
let loadPromise;
|
|
524
|
-
const previousLocation = this.stores.resolvedLocation.
|
|
524
|
+
const previousLocation = this.stores.resolvedLocation.get() ?? this.stores.location.get();
|
|
525
525
|
loadPromise = new Promise((resolve) => {
|
|
526
526
|
this.startTransition(async () => {
|
|
527
527
|
try {
|
|
528
528
|
this.beforeLoad();
|
|
529
529
|
const next = this.latestLocation;
|
|
530
|
-
const
|
|
531
|
-
|
|
532
|
-
if (!this.stores.redirect.state) this.emit({
|
|
530
|
+
const locationChangeInfo = getLocationChangeInfo(next, this.stores.resolvedLocation.get());
|
|
531
|
+
if (!this.stores.redirect.get()) this.emit({
|
|
533
532
|
type: "onBeforeNavigate",
|
|
534
533
|
...locationChangeInfo
|
|
535
534
|
});
|
|
@@ -541,7 +540,7 @@ var RouterCore = class {
|
|
|
541
540
|
router: this,
|
|
542
541
|
sync: opts?.sync,
|
|
543
542
|
forceStaleReload: previousLocation.href === next.href,
|
|
544
|
-
matches: this.stores.
|
|
543
|
+
matches: this.stores.pendingMatches.get(),
|
|
545
544
|
location: next,
|
|
546
545
|
updateMatch: this.updateMatch,
|
|
547
546
|
onReady: async () => {
|
|
@@ -552,19 +551,19 @@ var RouterCore = class {
|
|
|
552
551
|
let hookEnteringMatches = null;
|
|
553
552
|
let hookStayingMatches = null;
|
|
554
553
|
this.batch(() => {
|
|
555
|
-
const pendingMatches = this.stores.
|
|
554
|
+
const pendingMatches = this.stores.pendingMatches.get();
|
|
556
555
|
const mountPending = pendingMatches.length;
|
|
557
|
-
const currentMatches = this.stores.
|
|
558
|
-
exitingMatches = mountPending ? currentMatches.filter((match) => !this.stores.
|
|
556
|
+
const currentMatches = this.stores.matches.get();
|
|
557
|
+
exitingMatches = mountPending ? currentMatches.filter((match) => !this.stores.pendingMatchStores.has(match.id)) : null;
|
|
559
558
|
const pendingRouteIds = /* @__PURE__ */ new Set();
|
|
560
|
-
for (const s of this.stores.
|
|
559
|
+
for (const s of this.stores.pendingMatchStores.values()) if (s.routeId) pendingRouteIds.add(s.routeId);
|
|
561
560
|
const activeRouteIds = /* @__PURE__ */ new Set();
|
|
562
|
-
for (const s of this.stores.
|
|
561
|
+
for (const s of this.stores.matchStores.values()) if (s.routeId) activeRouteIds.add(s.routeId);
|
|
563
562
|
hookExitingMatches = mountPending ? currentMatches.filter((match) => !pendingRouteIds.has(match.routeId)) : null;
|
|
564
563
|
hookEnteringMatches = mountPending ? pendingMatches.filter((match) => !activeRouteIds.has(match.routeId)) : null;
|
|
565
564
|
hookStayingMatches = mountPending ? pendingMatches.filter((match) => activeRouteIds.has(match.routeId)) : currentMatches;
|
|
566
|
-
this.stores.isLoading.
|
|
567
|
-
this.stores.loadedAt.
|
|
565
|
+
this.stores.isLoading.set(false);
|
|
566
|
+
this.stores.loadedAt.set(Date.now());
|
|
568
567
|
/**
|
|
569
568
|
* When committing new matches, cache any exiting matches that are still usable.
|
|
570
569
|
* Routes that resolved with `status: 'error'` or `status: 'notFound'` are
|
|
@@ -572,9 +571,9 @@ var RouterCore = class {
|
|
|
572
571
|
* or reloads re-run their loaders instead of reusing the failed/not-found data.
|
|
573
572
|
*/
|
|
574
573
|
if (mountPending) {
|
|
575
|
-
this.stores.
|
|
576
|
-
this.stores.
|
|
577
|
-
this.stores.
|
|
574
|
+
this.stores.setMatches(pendingMatches);
|
|
575
|
+
this.stores.setPending([]);
|
|
576
|
+
this.stores.setCached([...this.stores.cachedMatches.get(), ...exitingMatches.filter((d) => d.status !== "error" && d.status !== "notFound" && d.status !== "redirected")]);
|
|
578
577
|
this.clearExpiredCache();
|
|
579
578
|
}
|
|
580
579
|
});
|
|
@@ -599,10 +598,10 @@ var RouterCore = class {
|
|
|
599
598
|
ignoreBlocker: true
|
|
600
599
|
});
|
|
601
600
|
} else if (require_not_found.isNotFound(err)) notFound = err;
|
|
602
|
-
const nextStatusCode = redirect ? redirect.status : notFound ? 404 : this.stores.
|
|
601
|
+
const nextStatusCode = redirect ? redirect.status : notFound ? 404 : this.stores.matches.get().some((d) => d.status === "error") ? 500 : 200;
|
|
603
602
|
this.batch(() => {
|
|
604
|
-
this.stores.statusCode.
|
|
605
|
-
this.stores.redirect.
|
|
603
|
+
this.stores.statusCode.set(nextStatusCode);
|
|
604
|
+
this.stores.redirect.set(redirect);
|
|
606
605
|
});
|
|
607
606
|
}
|
|
608
607
|
if (this.latestLoadPromise === loadPromise) {
|
|
@@ -618,8 +617,8 @@ var RouterCore = class {
|
|
|
618
617
|
while (this.latestLoadPromise && loadPromise !== this.latestLoadPromise) await this.latestLoadPromise;
|
|
619
618
|
let newStatusCode = void 0;
|
|
620
619
|
if (this.hasNotFoundMatch()) newStatusCode = 404;
|
|
621
|
-
else if (this.stores.
|
|
622
|
-
if (newStatusCode !== void 0) this.stores.statusCode.
|
|
620
|
+
else if (this.stores.matches.get().some((d) => d.status === "error")) newStatusCode = 500;
|
|
621
|
+
if (newStatusCode !== void 0) this.stores.statusCode.set(newStatusCode);
|
|
623
622
|
};
|
|
624
623
|
this.startViewTransition = (fn) => {
|
|
625
624
|
const shouldViewTransition = this.shouldViewTransition ?? this.options.defaultViewTransition;
|
|
@@ -628,7 +627,7 @@ var RouterCore = class {
|
|
|
628
627
|
let startViewTransitionParams;
|
|
629
628
|
if (typeof shouldViewTransition === "object" && this.isViewTransitionTypesSupported) {
|
|
630
629
|
const next = this.latestLocation;
|
|
631
|
-
const prevLocation = this.stores.resolvedLocation.
|
|
630
|
+
const prevLocation = this.stores.resolvedLocation.get();
|
|
632
631
|
const resolvedViewTransitionTypes = typeof shouldViewTransition.types === "function" ? shouldViewTransition.types(getLocationChangeInfo(next, prevLocation)) : shouldViewTransition.types;
|
|
633
632
|
if (resolvedViewTransitionTypes === false) {
|
|
634
633
|
fn();
|
|
@@ -644,27 +643,27 @@ var RouterCore = class {
|
|
|
644
643
|
};
|
|
645
644
|
this.updateMatch = (id, updater) => {
|
|
646
645
|
this.startTransition(() => {
|
|
647
|
-
const pendingMatch = this.stores.
|
|
646
|
+
const pendingMatch = this.stores.pendingMatchStores.get(id);
|
|
648
647
|
if (pendingMatch) {
|
|
649
|
-
pendingMatch.
|
|
648
|
+
pendingMatch.set(updater);
|
|
650
649
|
return;
|
|
651
650
|
}
|
|
652
|
-
const activeMatch = this.stores.
|
|
651
|
+
const activeMatch = this.stores.matchStores.get(id);
|
|
653
652
|
if (activeMatch) {
|
|
654
|
-
activeMatch.
|
|
653
|
+
activeMatch.set(updater);
|
|
655
654
|
return;
|
|
656
655
|
}
|
|
657
|
-
const cachedMatch = this.stores.
|
|
656
|
+
const cachedMatch = this.stores.cachedMatchStores.get(id);
|
|
658
657
|
if (cachedMatch) {
|
|
659
|
-
const next = updater(cachedMatch.
|
|
658
|
+
const next = updater(cachedMatch.get());
|
|
660
659
|
if (next.status === "redirected") {
|
|
661
|
-
if (this.stores.
|
|
662
|
-
} else cachedMatch.
|
|
660
|
+
if (this.stores.cachedMatchStores.delete(id)) this.stores.cachedIds.set((prev) => prev.filter((matchId) => matchId !== id));
|
|
661
|
+
} else cachedMatch.set(next);
|
|
663
662
|
}
|
|
664
663
|
});
|
|
665
664
|
};
|
|
666
665
|
this.getMatch = (matchId) => {
|
|
667
|
-
return this.stores.
|
|
666
|
+
return this.stores.cachedMatchStores.get(matchId)?.get() ?? this.stores.pendingMatchStores.get(matchId)?.get() ?? this.stores.matchStores.get(matchId)?.get();
|
|
668
667
|
};
|
|
669
668
|
this.invalidate = (opts) => {
|
|
670
669
|
const invalidate = (d) => {
|
|
@@ -679,9 +678,9 @@ var RouterCore = class {
|
|
|
679
678
|
return d;
|
|
680
679
|
};
|
|
681
680
|
this.batch(() => {
|
|
682
|
-
this.stores.
|
|
683
|
-
this.stores.
|
|
684
|
-
this.stores.
|
|
681
|
+
this.stores.setMatches(this.stores.matches.get().map(invalidate));
|
|
682
|
+
this.stores.setCached(this.stores.cachedMatches.get().map(invalidate));
|
|
683
|
+
this.stores.setPending(this.stores.pendingMatches.get().map(invalidate));
|
|
685
684
|
});
|
|
686
685
|
this.shouldViewTransition = false;
|
|
687
686
|
return this.load({ sync: opts?.sync });
|
|
@@ -710,8 +709,8 @@ var RouterCore = class {
|
|
|
710
709
|
};
|
|
711
710
|
this.clearCache = (opts) => {
|
|
712
711
|
const filter = opts?.filter;
|
|
713
|
-
if (filter !== void 0) this.stores.
|
|
714
|
-
else this.stores.
|
|
712
|
+
if (filter !== void 0) this.stores.setCached(this.stores.cachedMatches.get().filter((m) => !filter(m)));
|
|
713
|
+
else this.stores.setCached([]);
|
|
715
714
|
};
|
|
716
715
|
this.clearExpiredCache = () => {
|
|
717
716
|
const now = Date.now();
|
|
@@ -732,12 +731,12 @@ var RouterCore = class {
|
|
|
732
731
|
preload: true,
|
|
733
732
|
dest: opts
|
|
734
733
|
});
|
|
735
|
-
const activeMatchIds = new Set([...this.stores.matchesId.
|
|
736
|
-
const loadedMatchIds = new Set([...activeMatchIds, ...this.stores.
|
|
734
|
+
const activeMatchIds = new Set([...this.stores.matchesId.get(), ...this.stores.pendingIds.get()]);
|
|
735
|
+
const loadedMatchIds = new Set([...activeMatchIds, ...this.stores.cachedIds.get()]);
|
|
737
736
|
const matchesToCache = matches.filter((match) => !loadedMatchIds.has(match.id));
|
|
738
737
|
if (matchesToCache.length) {
|
|
739
|
-
const cachedMatches = this.stores.
|
|
740
|
-
this.stores.
|
|
738
|
+
const cachedMatches = this.stores.cachedMatches.get();
|
|
739
|
+
this.stores.setCached([...cachedMatches, ...matchesToCache]);
|
|
741
740
|
}
|
|
742
741
|
try {
|
|
743
742
|
matches = await require_load_matches.loadMatches({
|
|
@@ -771,8 +770,8 @@ var RouterCore = class {
|
|
|
771
770
|
leaveParams: true
|
|
772
771
|
};
|
|
773
772
|
const next = this.buildLocation(matchLocation);
|
|
774
|
-
if (opts?.pending && this.stores.status.
|
|
775
|
-
const baseLocation = (opts?.pending === void 0 ? !this.stores.isLoading.
|
|
773
|
+
if (opts?.pending && this.stores.status.get() !== "pending") return false;
|
|
774
|
+
const baseLocation = (opts?.pending === void 0 ? !this.stores.isLoading.get() : opts.pending) ? this.latestLocation : this.stores.resolvedLocation.get() || this.stores.location.get();
|
|
776
775
|
const match = require_new_process_route_tree.findSingleMatch(next.pathname, opts?.caseSensitive ?? false, opts?.fuzzy ?? false, baseLocation.pathname, this.processedTree);
|
|
777
776
|
if (!match) return false;
|
|
778
777
|
if (location.params) {
|
|
@@ -782,7 +781,7 @@ var RouterCore = class {
|
|
|
782
781
|
return match.rawParams;
|
|
783
782
|
};
|
|
784
783
|
this.hasNotFoundMatch = () => {
|
|
785
|
-
return this.stores.
|
|
784
|
+
return this.stores.matches.get().some((d) => d.status === "notFound" || d.globalNotFound);
|
|
786
785
|
};
|
|
787
786
|
this.getStoreConfig = getStoreConfig;
|
|
788
787
|
this.update({
|
|
@@ -806,7 +805,7 @@ var RouterCore = class {
|
|
|
806
805
|
return !!this.options.isPrerendering;
|
|
807
806
|
}
|
|
808
807
|
get state() {
|
|
809
|
-
return this.stores.__store.
|
|
808
|
+
return this.stores.__store.get();
|
|
810
809
|
}
|
|
811
810
|
setRoutes({ routesById, routesByPath, processedTree }) {
|
|
812
811
|
this.routesById = routesById;
|
|
@@ -834,7 +833,7 @@ var RouterCore = class {
|
|
|
834
833
|
const globalNotFoundRouteId = isGlobalNotFound ? findGlobalNotFoundRouteId(this.options.notFoundMode, matchedRoutes) : void 0;
|
|
835
834
|
const matches = new Array(matchedRoutes.length);
|
|
836
835
|
const previousActiveMatchesByRouteId = /* @__PURE__ */ new Map();
|
|
837
|
-
for (const store of this.stores.
|
|
836
|
+
for (const store of this.stores.matchStores.values()) if (store.routeId) previousActiveMatchesByRouteId.set(store.routeId, store.get());
|
|
838
837
|
for (let index = 0; index < matchedRoutes.length; index++) {
|
|
839
838
|
const route = matchedRoutes[index];
|
|
840
839
|
const parentMatch = matches[index - 1];
|
|
@@ -990,8 +989,8 @@ var RouterCore = class {
|
|
|
990
989
|
for (const route of matchedRoutes) try {
|
|
991
990
|
Object.assign(accumulatedSearch, validateSearch(route.options.validateSearch, accumulatedSearch));
|
|
992
991
|
} catch {}
|
|
993
|
-
const lastStateMatchId = require_utils.last(this.stores.matchesId.
|
|
994
|
-
const lastStateMatch = lastStateMatchId && this.stores.
|
|
992
|
+
const lastStateMatchId = require_utils.last(this.stores.matchesId.get());
|
|
993
|
+
const lastStateMatch = lastStateMatchId && this.stores.matchStores.get(lastStateMatchId)?.get();
|
|
995
994
|
const canReuseParams = lastStateMatch && lastStateMatch.routeId === lastRoute.id && lastStateMatch.pathname === location.pathname;
|
|
996
995
|
let params;
|
|
997
996
|
if (canReuseParams) params = lastStateMatch.params;
|