"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); Object.defineProperty(exports, "fillCacheWithNewSubTreeData", { enumerable: true, get: function() { return fillCacheWithNewSubTreeData; } }); const _approutercontextsharedruntime = require("../../../shared/lib/app-router-context.shared-runtime"); const _invalidatecachebyrouterstate = require("./invalidate-cache-by-router-state"); const _filllazyitemstillleafwithhead = require("./fill-lazy-items-till-leaf-with-head"); const _createroutercachekey = require("./create-router-cache-key"); function fillCacheWithNewSubTreeData(newCache, existingCache, flightDataPath, wasPrefetched) { const isLastEntry = flightDataPath.length <= 5; const [parallelRouteKey, segment] = flightDataPath; const cacheKey = (0, _createroutercachekey.createRouterCacheKey)(segment); const existingChildSegmentMap = existingCache.parallelRoutes.get(parallelRouteKey); if (!existingChildSegmentMap) { // Bailout because the existing cache does not have the path to the leaf node // Will trigger lazy fetch in layout-router because of missing segment return; } let childSegmentMap = newCache.parallelRoutes.get(parallelRouteKey); if (!childSegmentMap || childSegmentMap === existingChildSegmentMap) { childSegmentMap = new Map(existingChildSegmentMap); newCache.parallelRoutes.set(parallelRouteKey, childSegmentMap); } const existingChildCacheNode = existingChildSegmentMap.get(cacheKey); let childCacheNode = childSegmentMap.get(cacheKey); if (isLastEntry) { if (!childCacheNode || !childCacheNode.data || childCacheNode === existingChildCacheNode) { childCacheNode = { status: _approutercontextsharedruntime.CacheStates.READY, data: null, subTreeData: flightDataPath[3], // Ensure segments other than the one we got data for are preserved. parallelRoutes: existingChildCacheNode ? new Map(existingChildCacheNode.parallelRoutes) : new Map() }; if (existingChildCacheNode) { (0, _invalidatecachebyrouterstate.invalidateCacheByRouterState)(childCacheNode, existingChildCacheNode, flightDataPath[2]); } (0, _filllazyitemstillleafwithhead.fillLazyItemsTillLeafWithHead)(childCacheNode, existingChildCacheNode, flightDataPath[2], flightDataPath[4], wasPrefetched); childSegmentMap.set(cacheKey, childCacheNode); } return; } if (!childCacheNode || !existingChildCacheNode) { // Bailout because the existing cache does not have the path to the leaf node // Will trigger lazy fetch in layout-router because of missing segment return; } if (childCacheNode === existingChildCacheNode) { childCacheNode = { status: childCacheNode.status, data: childCacheNode.data, subTreeData: childCacheNode.subTreeData, parallelRoutes: new Map(childCacheNode.parallelRoutes) }; childSegmentMap.set(cacheKey, childCacheNode); } fillCacheWithNewSubTreeData(childCacheNode, existingChildCacheNode, flightDataPath.slice(2), wasPrefetched); } if ((typeof exports.default === 'function' || (typeof exports.default === 'object' && exports.default !== null)) && typeof exports.default.__esModule === 'undefined') { Object.defineProperty(exports.default, '__esModule', { value: true }); Object.assign(exports.default, exports); module.exports = exports.default; } //# sourceMappingURL=fill-cache-with-new-subtree-data.js.map