import { createHrefFromUrl } from "./create-href-from-url"; import { fillLazyItemsTillLeafWithHead } from "./fill-lazy-items-till-leaf-with-head"; import { extractPathFromFlightRouterState } from "./compute-changed-path"; import { createPrefetchCacheEntryForInitialLoad } from "./prefetch-cache-utils"; import { PrefetchKind } from "./router-reducer-types"; import { addRefreshMarkerToActiveParallelSegments } from "./refetch-inactive-parallel-segments"; export function createInitialRouterState(param) { let { buildId, initialTree, initialSeedData, urlParts, initialParallelRoutes, location, initialHead, couldBeIntercepted } = param; // When initialized on the server, the canonical URL is provided as an array of parts. // This is to ensure that when the RSC payload streamed to the client, crawlers don't interpret it // as a URL that should be crawled. const initialCanonicalUrl = urlParts.join("/"); const isServer = !location; const rsc = initialSeedData[2]; const cache = { lazyData: null, rsc: rsc, prefetchRsc: null, head: null, prefetchHead: null, // The cache gets seeded during the first render. `initialParallelRoutes` ensures the cache from the first render is there during the second render. parallelRoutes: isServer ? new Map() : initialParallelRoutes, lazyDataResolved: false, loading: initialSeedData[3] }; const canonicalUrl = // location.href is read as the initial value for canonicalUrl in the browser // This is safe to do as canonicalUrl can't be rendered, it's only used to control the history updates in the useEffect further down in this file. location ? createHrefFromUrl(location) : initialCanonicalUrl; addRefreshMarkerToActiveParallelSegments(initialTree, canonicalUrl); const prefetchCache = new Map(); // When the cache hasn't been seeded yet we fill the cache with the head. if (initialParallelRoutes === null || initialParallelRoutes.size === 0) { fillLazyItemsTillLeafWithHead(cache, undefined, initialTree, initialSeedData, initialHead); } var // the || operator is intentional, the pathname can be an empty string _ref; const initialState = { buildId, tree: initialTree, cache, prefetchCache, pushRef: { pendingPush: false, mpaNavigation: false, // First render needs to preserve the previous window.history.state // to avoid it being overwritten on navigation back/forward with MPA Navigation. preserveCustomHistoryState: true }, focusAndScrollRef: { apply: false, onlyHashChange: false, hashFragment: null, segmentPaths: [] }, canonicalUrl, nextUrl: (_ref = extractPathFromFlightRouterState(initialTree) || (location == null ? void 0 : location.pathname)) != null ? _ref : null }; if (location) { // Seed the prefetch cache with this page's data. // This is to prevent needlessly re-prefetching a page that is already reusable, // and will avoid triggering a loading state/data fetch stall when navigating back to the page. const url = new URL("" + location.pathname + location.search, location.origin); const initialFlightData = [ [ "", initialTree, null, null ] ]; createPrefetchCacheEntryForInitialLoad({ url, kind: PrefetchKind.AUTO, data: [ initialFlightData, undefined, false, couldBeIntercepted ], tree: initialState.tree, prefetchCache: initialState.prefetchCache, nextUrl: initialState.nextUrl }); } return initialState; } //# sourceMappingURL=create-initial-router-state.js.map