UNPKG

@tanstack/router-plugin

Version:

Modern and scalable routing for React applications

45 lines (44 loc) 1.73 kB
import { getObjectPropertyKeyName, getUniqueProgramIdentifier } from "../../utils.js"; import * as t from "@babel/types"; //#region src/core/code-splitter/plugins/react-refresh-route-components.ts var REACT_REFRESH_ROUTE_COMPONENT_IDENTS = new Set([ "component", "shellComponent", "pendingComponent", "errorComponent", "notFoundComponent" ]); function hoistInlineRouteComponents(ctx) { const hoistedDeclarations = []; ctx.routeOptions.properties.forEach((prop) => { if (!t.isObjectProperty(prop)) return; const key = getObjectPropertyKeyName(prop); if (!key || !REACT_REFRESH_ROUTE_COMPONENT_IDENTS.has(key)) return; if (!t.isArrowFunctionExpression(prop.value) && !t.isFunctionExpression(prop.value)) return; const hoistedIdentifier = getUniqueProgramIdentifier(ctx.programPath, `TSR${key[0].toUpperCase()}${key.slice(1)}`); hoistedDeclarations.push(t.variableDeclaration("const", [t.variableDeclarator(hoistedIdentifier, t.cloneNode(prop.value, true))])); prop.value = t.cloneNode(hoistedIdentifier); }); if (hoistedDeclarations.length === 0) return false; ctx.insertionPath.insertBefore(hoistedDeclarations); return true; } function createReactRefreshRouteComponentsPlugin() { return { name: "react-refresh-route-components", getStableRouteOptionKeys() { return [...REACT_REFRESH_ROUTE_COMPONENT_IDENTS]; }, onUnsplittableRoute(ctx) { if (!ctx.opts.addHmr) return; if (hoistInlineRouteComponents(ctx)) return { modified: true }; }, onAddHmr(ctx) { if (!ctx.opts.addHmr) return; if (hoistInlineRouteComponents(ctx)) return { modified: true }; } }; } //#endregion export { createReactRefreshRouteComponentsPlugin }; //# sourceMappingURL=react-refresh-route-components.js.map