UNPKG

@tanstack/router-plugin

Version:

Modern and scalable routing for React applications

63 lines (62 loc) 2.01 kB
"use strict"; Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" }); const routerUtils = require("@tanstack/router-utils"); const routeHmrStatement = require("./route-hmr-statement.cjs"); const utils = require("./utils.cjs"); const config = require("./config.cjs"); const includeCode = [ "createFileRoute(", "createRootRoute(", "createRootRouteWithContext(" ]; const unpluginRouterHmrFactory = (options = {}) => { let ROOT = process.cwd(); let userConfig = options; return { name: "tanstack-router:hmr", enforce: "pre", transform: { filter: { // this is necessary for webpack / rspack to avoid matching .html files id: /\.(m|c)?(j|t)sx?$/, code: { include: includeCode } }, handler(code, id) { var _a; if (!((_a = globalThis.TSR_ROUTES_BY_ID_MAP) == null ? void 0 : _a.has(id))) { return null; } if (utils.debug) console.info("Adding HMR handling to route ", id); const ast = routerUtils.parseAst({ code }); ast.program.body.push(routeHmrStatement.routeHmrStatement); const result = routerUtils.generateFromAst(ast, { sourceMaps: true, filename: id, sourceFileName: id }); if (utils.debug) { routerUtils.logDiff(code, result.code); console.log("Output:\n", result.code + "\n\n"); } return result; } }, vite: { configResolved(config$1) { ROOT = config$1.root; userConfig = config.getConfig(options, ROOT); }, applyToEnvironment(environment) { var _a, _b; if ((_b = (_a = userConfig.plugin) == null ? void 0 : _a.vite) == null ? void 0 : _b.environmentName) { return userConfig.plugin.vite.environmentName === environment.name; } return true; } } }; }; exports.unpluginRouterHmrFactory = unpluginRouterHmrFactory; //# sourceMappingURL=router-hmr-plugin.cjs.map