@tanstack/router-plugin 1.99.14 → 1.101.0

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.
Files changed (42) hide show
  1. package/dist/cjs/core/code-splitter/compilers.cjs +187 -34
  2. package/dist/cjs/core/code-splitter/compilers.cjs.map +1 -1
  3. package/dist/cjs/core/code-splitter/compilers.d.cts +14 -2
  4. package/dist/cjs/core/code-splitter/path-ids.cjs +37 -0
  5. package/dist/cjs/core/code-splitter/path-ids.cjs.map +1 -0
  6. package/dist/cjs/core/code-splitter/path-ids.d.cts +2 -0
  7. package/dist/cjs/core/config.cjs +33 -1
  8. package/dist/cjs/core/config.cjs.map +1 -1
  9. package/dist/cjs/core/config.d.cts +24 -0
  10. package/dist/cjs/core/constants.cjs +17 -2
  11. package/dist/cjs/core/constants.cjs.map +1 -1
  12. package/dist/cjs/core/constants.d.cts +5 -1
  13. package/dist/cjs/core/router-code-splitter-plugin.cjs +69 -16
  14. package/dist/cjs/core/router-code-splitter-plugin.cjs.map +1 -1
  15. package/dist/cjs/esbuild.d.cts +3 -0
  16. package/dist/cjs/rspack.d.cts +3 -0
  17. package/dist/cjs/vite.d.cts +3 -0
  18. package/dist/cjs/webpack.d.cts +3 -0
  19. package/dist/esm/core/code-splitter/compilers.d.ts +14 -2
  20. package/dist/esm/core/code-splitter/compilers.js +189 -36
  21. package/dist/esm/core/code-splitter/compilers.js.map +1 -1
  22. package/dist/esm/core/code-splitter/path-ids.d.ts +2 -0
  23. package/dist/esm/core/code-splitter/path-ids.js +37 -0
  24. package/dist/esm/core/code-splitter/path-ids.js.map +1 -0
  25. package/dist/esm/core/config.d.ts +24 -0
  26. package/dist/esm/core/config.js +34 -2
  27. package/dist/esm/core/config.js.map +1 -1
  28. package/dist/esm/core/constants.d.ts +5 -1
  29. package/dist/esm/core/constants.js +17 -2
  30. package/dist/esm/core/constants.js.map +1 -1
  31. package/dist/esm/core/router-code-splitter-plugin.js +72 -19
  32. package/dist/esm/core/router-code-splitter-plugin.js.map +1 -1
  33. package/dist/esm/esbuild.d.ts +3 -0
  34. package/dist/esm/rspack.d.ts +3 -0
  35. package/dist/esm/vite.d.ts +3 -0
  36. package/dist/esm/webpack.d.ts +3 -0
  37. package/package.json +3 -3
  38. package/src/core/code-splitter/compilers.ts +230 -46
  39. package/src/core/code-splitter/path-ids.ts +39 -0
  40. package/src/core/config.ts +63 -0
  41. package/src/core/constants.ts +18 -1
  42. package/src/core/router-code-splitter-plugin.ts +104 -20
@@ -1,4 +1,24 @@
1
1
  import { z } from 'zod';
2
+ import { RegisteredRouter, RouteIds } from '@tanstack/react-router';
3
+ import { CodeSplitGroupings } from './constants.js';
4
+ export declare const splitGroupingsSchema: z.ZodEffects<z.ZodArray<z.ZodArray<z.ZodUnion<[z.ZodLiteral<"loader">, z.ZodLiteral<"component">, z.ZodLiteral<"pendingComponent">, z.ZodLiteral<"errorComponent">, z.ZodLiteral<"notFoundComponent">]>, "many">, "many">, ("loader" | "component" | "pendingComponent" | "errorComponent" | "notFoundComponent")[][], ("loader" | "component" | "pendingComponent" | "errorComponent" | "notFoundComponent")[][]>;
5
+ export type CodeSplittingOptions = {
6
+ /**
7
+ * Use this function to programmatically control the code splitting behavior
8
+ * based on the `routeId` for each route.
9
+ *
10
+ * If you just need to change the default behavior, you can use the `defaultBehavior` option.
11
+ * @param params
12
+ */
13
+ splitBehavior?: (params: {
14
+ routeId: RouteIds<RegisteredRouter['routeTree']>;
15
+ }) => CodeSplitGroupings | undefined | void;
16
+ /**
17
+ * The default/global configuration to control your code splitting behavior per route.
18
+ * @default [['component'],['pendingComponent'],['errorComponent'],['notFoundComponent']]
19
+ */
20
+ defaultBehavior?: CodeSplitGroupings;
21
+ };
2
22
  export declare const configSchema: z.ZodObject<z.objectUtil.extendShape<{
3
23
  target: z.ZodDefault<z.ZodOptional<z.ZodEnum<["react"]>>>;
4
24
  virtualRouteConfig: z.ZodOptional<z.ZodUnion<[z.ZodType<import('@tanstack/virtual-file-routes').VirtualRootRoute, z.ZodTypeDef, import('@tanstack/virtual-file-routes').VirtualRootRoute>, z.ZodString]>>;
@@ -42,6 +62,7 @@ export declare const configSchema: z.ZodObject<z.objectUtil.extendShape<{
42
62
  }>>;
43
63
  }, {
44
64
  enableRouteGeneration: z.ZodOptional<z.ZodBoolean>;
65
+ codeSplittingOptions: z.ZodOptional<z.ZodType<CodeSplittingOptions, z.ZodTypeDef, CodeSplittingOptions>>;
45
66
  }>, "strip", z.ZodTypeAny, {
46
67
  target: "react";
47
68
  routeFileIgnorePrefix: string;
@@ -59,6 +80,7 @@ export declare const configSchema: z.ZodObject<z.objectUtil.extendShape<{
59
80
  indexToken: string;
60
81
  routeToken: string;
61
82
  enableRouteGeneration?: boolean | undefined;
83
+ codeSplittingOptions?: CodeSplittingOptions | undefined;
62
84
  virtualRouteConfig?: string | import('@tanstack/virtual-file-routes').VirtualRootRoute | undefined;
63
85
  routeFilePrefix?: string | undefined;
64
86
  routeFileIgnorePattern?: string | undefined;
@@ -74,6 +96,7 @@ export declare const configSchema: z.ZodObject<z.objectUtil.extendShape<{
74
96
  } | undefined;
75
97
  }, {
76
98
  enableRouteGeneration?: boolean | undefined;
99
+ codeSplittingOptions?: CodeSplittingOptions | undefined;
77
100
  target?: "react" | undefined;
78
101
  virtualRouteConfig?: string | import('@tanstack/virtual-file-routes').VirtualRootRoute | undefined;
79
102
  routeFilePrefix?: string | undefined;
@@ -120,6 +143,7 @@ export declare const getConfig: (inlineConfig: Partial<Config>, root: string) =>
120
143
  indexToken: string;
121
144
  routeToken: string;
122
145
  enableRouteGeneration?: boolean | undefined;
146
+ codeSplittingOptions?: CodeSplittingOptions | undefined;
123
147
  virtualRouteConfig?: string | import('@tanstack/virtual-file-routes').VirtualRootRoute | undefined;
124
148
  routeFilePrefix?: string | undefined;
125
149
  routeFileIgnorePattern?: string | undefined;
@@ -1,7 +1,38 @@
1
1
  import { z } from "zod";
2
2
  import { getConfig as getConfig$1, configSchema as configSchema$1 } from "@tanstack/router-generator";
3
+ const splitGroupingsSchema = z.array(
4
+ z.array(
5
+ z.union([
6
+ z.literal("loader"),
7
+ z.literal("component"),
8
+ z.literal("pendingComponent"),
9
+ z.literal("errorComponent"),
10
+ z.literal("notFoundComponent")
11
+ ])
12
+ ),
13
+ {
14
+ message: " Must be an Array of Arrays containing the split groupings. i.e. [['component'], ['pendingComponent'], ['errorComponent', 'notFoundComponent']]"
15
+ }
16
+ ).superRefine((val, ctx) => {
17
+ const flattened = val.flat();
18
+ const unique = [...new Set(flattened)];
19
+ if (unique.length !== flattened.length) {
20
+ ctx.addIssue({
21
+ code: "custom",
22
+ message: ` Split groupings must be unique and not repeated. i.e. i.e. [['component'], ['pendingComponent'], ['errorComponent', 'notFoundComponent']].
23
+ You input was: ${JSON.stringify(val)}.`
24
+ });
25
+ }
26
+ });
27
+ const codeSplittingOptionsSchema = z.object({
28
+ splitBehavior: z.function().optional(),
29
+ defaultBehavior: splitGroupingsSchema.optional()
30
+ });
3
31
  const configSchema = configSchema$1.extend({
4
- enableRouteGeneration: z.boolean().optional()
32
+ enableRouteGeneration: z.boolean().optional(),
33
+ codeSplittingOptions: z.custom((v) => {
34
+ return codeSplittingOptionsSchema.parse(v);
35
+ }).optional()
5
36
  });
6
37
  const getConfig = (inlineConfig, root) => {
7
38
  const config = getConfig$1(inlineConfig, root);
@@ -9,6 +40,7 @@ const getConfig = (inlineConfig, root) => {
9
40
  };
10
41
  export {
11
42
  configSchema,
12
- getConfig
43
+ getConfig,
44
+ splitGroupingsSchema
13
45
  };
14
46
  //# sourceMappingURL=config.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"config.js","sources":["../../../src/core/config.ts"],"sourcesContent":["import { z } from 'zod'\nimport {\n configSchema as generatorConfigSchema,\n getConfig as getGeneratorConfig,\n} from '@tanstack/router-generator'\n\nexport const configSchema = generatorConfigSchema.extend({\n enableRouteGeneration: z.boolean().optional(),\n})\n\nexport const getConfig = (inlineConfig: Partial<Config>, root: string) => {\n const config = getGeneratorConfig(inlineConfig, root)\n\n return configSchema.parse({ ...config, ...inlineConfig })\n}\n\nexport type Config = z.infer<typeof configSchema>\n"],"names":["generatorConfigSchema","getGeneratorConfig"],"mappings":";;AAMa,MAAA,eAAeA,eAAsB,OAAO;AAAA,EACvD,uBAAuB,EAAE,QAAQ,EAAE,SAAS;AAC9C,CAAC;AAEY,MAAA,YAAY,CAAC,cAA+B,SAAiB;AAClE,QAAA,SAASC,YAAmB,cAAc,IAAI;AAEpD,SAAO,aAAa,MAAM,EAAE,GAAG,QAAQ,GAAG,cAAc;AAC1D;"}
1
+ {"version":3,"file":"config.js","sources":["../../../src/core/config.ts"],"sourcesContent":["import { z } from 'zod'\nimport {\n configSchema as generatorConfigSchema,\n getConfig as getGeneratorConfig,\n} from '@tanstack/router-generator'\nimport type { RegisteredRouter, RouteIds } from '@tanstack/react-router'\nimport type { CodeSplitGroupings } from './constants'\n\nexport const splitGroupingsSchema = z\n .array(\n z.array(\n z.union([\n z.literal('loader'),\n z.literal('component'),\n z.literal('pendingComponent'),\n z.literal('errorComponent'),\n z.literal('notFoundComponent'),\n ]),\n ),\n {\n message:\n \" Must be an Array of Arrays containing the split groupings. i.e. [['component'], ['pendingComponent'], ['errorComponent', 'notFoundComponent']]\",\n },\n )\n .superRefine((val, ctx) => {\n const flattened = val.flat()\n const unique = [...new Set(flattened)]\n\n // Elements must be unique,\n // ie. this shouldn't be allows [['component'], ['component', 'loader']]\n if (unique.length !== flattened.length) {\n ctx.addIssue({\n code: 'custom',\n message:\n \" Split groupings must be unique and not repeated. i.e. i.e. [['component'], ['pendingComponent'], ['errorComponent', 'notFoundComponent']].\" +\n `\\n You input was: ${JSON.stringify(val)}.`,\n })\n }\n })\n\nexport type CodeSplittingOptions = {\n /**\n * Use this function to programmatically control the code splitting behavior\n * based on the `routeId` for each route.\n *\n * If you just need to change the default behavior, you can use the `defaultBehavior` option.\n * @param params\n */\n splitBehavior?: (params: {\n routeId: RouteIds<RegisteredRouter['routeTree']>\n }) => CodeSplitGroupings | undefined | void\n\n /**\n * The default/global configuration to control your code splitting behavior per route.\n * @default [['component'],['pendingComponent'],['errorComponent'],['notFoundComponent']]\n */\n defaultBehavior?: CodeSplitGroupings\n}\n\nconst codeSplittingOptionsSchema = z.object({\n splitBehavior: z.function().optional(),\n defaultBehavior: splitGroupingsSchema.optional(),\n})\n\nexport const configSchema = generatorConfigSchema.extend({\n enableRouteGeneration: z.boolean().optional(),\n codeSplittingOptions: z\n .custom<CodeSplittingOptions>((v) => {\n return codeSplittingOptionsSchema.parse(v)\n })\n .optional(),\n})\n\nexport const getConfig = (inlineConfig: Partial<Config>, root: string) => {\n const config = getGeneratorConfig(inlineConfig, root)\n\n return configSchema.parse({ ...config, ...inlineConfig })\n}\n\nexport type Config = z.infer<typeof configSchema>\n"],"names":["generatorConfigSchema","getGeneratorConfig"],"mappings":";;AAQO,MAAM,uBAAuB,EACjC;AAAA,EACC,EAAE;AAAA,IACA,EAAE,MAAM;AAAA,MACN,EAAE,QAAQ,QAAQ;AAAA,MAClB,EAAE,QAAQ,WAAW;AAAA,MACrB,EAAE,QAAQ,kBAAkB;AAAA,MAC5B,EAAE,QAAQ,gBAAgB;AAAA,MAC1B,EAAE,QAAQ,mBAAmB;AAAA,IAC9B,CAAA;AAAA,EACH;AAAA,EACA;AAAA,IACE,SACE;AAAA,EAAA;AAEN,EACC,YAAY,CAAC,KAAK,QAAQ;AACnB,QAAA,YAAY,IAAI,KAAK;AAC3B,QAAM,SAAS,CAAC,GAAG,IAAI,IAAI,SAAS,CAAC;AAIjC,MAAA,OAAO,WAAW,UAAU,QAAQ;AACtC,QAAI,SAAS;AAAA,MACX,MAAM;AAAA,MACN,SACE;AAAA,mBACsB,KAAK,UAAU,GAAG,CAAC;AAAA,IAAA,CAC5C;AAAA,EAAA;AAEL,CAAC;AAqBH,MAAM,6BAA6B,EAAE,OAAO;AAAA,EAC1C,eAAe,EAAE,SAAS,EAAE,SAAS;AAAA,EACrC,iBAAiB,qBAAqB,SAAS;AACjD,CAAC;AAEY,MAAA,eAAeA,eAAsB,OAAO;AAAA,EACvD,uBAAuB,EAAE,QAAQ,EAAE,SAAS;AAAA,EAC5C,sBAAsB,EACnB,OAA6B,CAAC,MAAM;AAC5B,WAAA,2BAA2B,MAAM,CAAC;AAAA,EAC1C,CAAA,EACA,SAAS;AACd,CAAC;AAEY,MAAA,YAAY,CAAC,cAA+B,SAAiB;AAClE,QAAA,SAASC,YAAmB,cAAc,IAAI;AAEpD,SAAO,aAAa,MAAM,EAAE,GAAG,QAAQ,GAAG,cAAc;AAC1D;"}
@@ -1 +1,5 @@
1
- export declare const splitPrefix = "tsr-split";
1
+ export declare const tsrSplit = "tsr-split";
2
+ export declare const splitRouteIdentNodes: readonly ["loader", "component", "pendingComponent", "errorComponent", "notFoundComponent"];
3
+ export type SplitRouteIdentNodes = (typeof splitRouteIdentNodes)[number];
4
+ export type CodeSplitGroupings = Array<Array<SplitRouteIdentNodes>>;
5
+ export declare const defaultCodeSplitGroupings: CodeSplitGroupings;
@@ -1,5 +1,20 @@
1
- const splitPrefix = "tsr-split";
1
+ const tsrSplit = "tsr-split";
2
+ const splitRouteIdentNodes = [
3
+ "loader",
4
+ "component",
5
+ "pendingComponent",
6
+ "errorComponent",
7
+ "notFoundComponent"
8
+ ];
9
+ const defaultCodeSplitGroupings = [
10
+ ["component"],
11
+ ["pendingComponent"],
12
+ ["errorComponent"],
13
+ ["notFoundComponent"]
14
+ ];
2
15
  export {
3
- splitPrefix
16
+ defaultCodeSplitGroupings,
17
+ splitRouteIdentNodes,
18
+ tsrSplit
4
19
  };
5
20
  //# sourceMappingURL=constants.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"constants.js","sources":["../../../src/core/constants.ts"],"sourcesContent":["export const splitPrefix = 'tsr-split'\n"],"names":[],"mappings":"AAAO,MAAM,cAAc;"}
1
+ {"version":3,"file":"constants.js","sources":["../../../src/core/constants.ts"],"sourcesContent":["export const tsrSplit = 'tsr-split'\n\nexport const splitRouteIdentNodes = [\n 'loader',\n 'component',\n 'pendingComponent',\n 'errorComponent',\n 'notFoundComponent',\n] as const\nexport type SplitRouteIdentNodes = (typeof splitRouteIdentNodes)[number]\nexport type CodeSplitGroupings = Array<Array<SplitRouteIdentNodes>>\n\nexport const defaultCodeSplitGroupings: CodeSplitGroupings = [\n ['component'],\n ['pendingComponent'],\n ['errorComponent'],\n ['notFoundComponent'],\n]\n"],"names":[],"mappings":"AAAO,MAAM,WAAW;AAEjB,MAAM,uBAAuB;AAAA,EAClC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF;AAIO,MAAM,4BAAgD;AAAA,EAC3D,CAAC,WAAW;AAAA,EACZ,CAAC,kBAAkB;AAAA,EACnB,CAAC,gBAAgB;AAAA,EACjB,CAAC,mBAAmB;AACtB;"}
@@ -1,9 +1,10 @@
1
1
  import { isAbsolute, join, normalize } from "node:path";
2
2
  import { pathToFileURL, fileURLToPath } from "node:url";
3
3
  import { logDiff } from "@tanstack/router-utils";
4
- import { getConfig } from "./config.js";
5
- import { compileCodeSplitVirtualRoute, compileCodeSplitReferenceRoute } from "./code-splitter/compilers.js";
6
- import { splitPrefix } from "./constants.js";
4
+ import { getConfig, splitGroupingsSchema } from "./config.js";
5
+ import { compileCodeSplitVirtualRoute, detectCodeSplitGroupingsFromRoute, compileCodeSplitReferenceRoute } from "./code-splitter/compilers.js";
6
+ import { tsrSplit, splitRouteIdentNodes, defaultCodeSplitGroupings } from "./constants.js";
7
+ import { decodeIdentifier } from "./code-splitter/path-ids.js";
7
8
  const debug = process.env.TSR_VITE_DEBUG && ["true", "router-plugin"].includes(process.env.TSR_VITE_DEBUG);
8
9
  function capitalizeFirst(str) {
9
10
  return str.charAt(0).toUpperCase() + str.slice(1);
@@ -37,26 +38,52 @@ const unpluginRouterCodeSplitterFactory = (options = {}, { framework }) => {
37
38
  let ROOT = process.cwd();
38
39
  let userConfig = options;
39
40
  const isProduction = process.env.NODE_ENV === "production";
40
- const handleSplittingFile = (code, id) => {
41
- if (debug) console.info("Splitting Route: ", id);
42
- const compiledVirtualRoute = compileCodeSplitVirtualRoute({
41
+ const getGlobalCodeSplitGroupings = () => {
42
+ var _a;
43
+ return ((_a = userConfig.codeSplittingOptions) == null ? void 0 : _a.defaultBehavior) || defaultCodeSplitGroupings;
44
+ };
45
+ const getShouldSplitFn = () => {
46
+ var _a;
47
+ return (_a = userConfig.codeSplittingOptions) == null ? void 0 : _a.splitBehavior;
48
+ };
49
+ const handleCompilingReferenceFile = (code, id) => {
50
+ if (debug) console.info("Compiling Route: ", id);
51
+ const fromCode = detectCodeSplitGroupingsFromRoute({
43
52
  code,
44
53
  root: ROOT,
45
54
  filename: id
46
55
  });
47
- if (debug) {
48
- logDiff(code, compiledVirtualRoute.code);
49
- console.log("Output:\n", compiledVirtualRoute.code);
56
+ if (fromCode.groupings) {
57
+ const res = splitGroupingsSchema.safeParse(fromCode.groupings);
58
+ if (!res.success) {
59
+ const message = res.error.errors.map((e) => e.message).join(". ");
60
+ throw new Error(
61
+ `The groupings for the route "${id}" are invalid.
62
+ ${message}`
63
+ );
64
+ }
50
65
  }
51
- return compiledVirtualRoute;
52
- };
53
- const handleCompilingFile = (code, id) => {
54
- if (debug) console.info("Compiling Route: ", id);
66
+ const userShouldSplitFn = getShouldSplitFn();
67
+ const pluginSplitBehavior = userShouldSplitFn == null ? void 0 : userShouldSplitFn({
68
+ routeId: fromCode.routeId
69
+ });
70
+ if (pluginSplitBehavior) {
71
+ const res = splitGroupingsSchema.safeParse(pluginSplitBehavior);
72
+ if (!res.success) {
73
+ const message = res.error.errors.map((e) => e.message).join(". ");
74
+ throw new Error(
75
+ `The groupings returned when using \`splitBehavior\` for the route "${id}" are invalid.
76
+ ${message}`
77
+ );
78
+ }
79
+ }
80
+ const splitGroupings = fromCode.groupings || pluginSplitBehavior || getGlobalCodeSplitGroupings();
55
81
  const compiledReferenceRoute = compileCodeSplitReferenceRoute({
56
82
  code,
57
83
  root: ROOT,
58
84
  filename: id,
59
- isProduction
85
+ runtimeEnv: isProduction ? "prod" : "dev",
86
+ codeSplitGroupings: splitGroupings
60
87
  });
61
88
  if (debug) {
62
89
  logDiff(code, compiledReferenceRoute.code);
@@ -64,6 +91,32 @@ const unpluginRouterCodeSplitterFactory = (options = {}, { framework }) => {
64
91
  }
65
92
  return compiledReferenceRoute;
66
93
  };
94
+ const handleCompilingVirtualFile = (code, id) => {
95
+ if (debug) console.info("Splitting Route: ", id);
96
+ const [_, ...pathnameParts] = id.split("?");
97
+ const searchParams = new URLSearchParams(pathnameParts.join("?"));
98
+ const splitValue = searchParams.get(tsrSplit);
99
+ if (!splitValue) {
100
+ throw new Error(
101
+ `The split value for the virtual route "${id}" was not found.`
102
+ );
103
+ }
104
+ const rawGrouping = decodeIdentifier(splitValue);
105
+ const grouping = [...new Set(rawGrouping)].filter(
106
+ (p) => splitRouteIdentNodes.includes(p)
107
+ );
108
+ const result = compileCodeSplitVirtualRoute({
109
+ code,
110
+ root: ROOT,
111
+ filename: id,
112
+ splitTargets: grouping
113
+ });
114
+ if (debug) {
115
+ logDiff(code, result.code);
116
+ console.log("Output:\n", result.code + "\n\n");
117
+ }
118
+ return result;
119
+ };
67
120
  return {
68
121
  name: "router-code-splitter-plugin",
69
122
  enforce: "pre",
@@ -74,8 +127,8 @@ const unpluginRouterCodeSplitterFactory = (options = {}, { framework }) => {
74
127
  const url = pathToFileURL(id);
75
128
  url.searchParams.delete("v");
76
129
  id = fileURLToPath(url).replace(/\\/g, "/");
77
- if (id.includes(splitPrefix)) {
78
- return handleSplittingFile(code, id);
130
+ if (id.includes(tsrSplit)) {
131
+ return handleCompilingVirtualFile(code, id);
79
132
  } else if (fileIsInRoutesDirectory(id, userConfig.routesDirectory) && (code.includes("createRoute(") || code.includes("createFileRoute("))) {
80
133
  for (const externalPlugin of bannedBeforeExternalPlugins) {
81
134
  if (!externalPlugin.frameworks.includes(framework)) {
@@ -85,7 +138,7 @@ const unpluginRouterCodeSplitterFactory = (options = {}, { framework }) => {
85
138
  throw new FoundPluginInBeforeCode(externalPlugin, framework);
86
139
  }
87
140
  }
88
- return handleCompilingFile(code, id);
141
+ return handleCompilingReferenceFile(code, id);
89
142
  }
90
143
  return null;
91
144
  },
@@ -93,7 +146,7 @@ const unpluginRouterCodeSplitterFactory = (options = {}, { framework }) => {
93
146
  if (!userConfig.autoCodeSplitting) {
94
147
  return void 0;
95
148
  }
96
- if (fileIsInRoutesDirectory(id, userConfig.routesDirectory) || id.includes(splitPrefix)) {
149
+ if (fileIsInRoutesDirectory(id, userConfig.routesDirectory) || id.includes(tsrSplit)) {
97
150
  return true;
98
151
  }
99
152
  return false;
@@ -104,7 +157,7 @@ const unpluginRouterCodeSplitterFactory = (options = {}, { framework }) => {
104
157
  userConfig = getConfig(options, ROOT);
105
158
  }
106
159
  },
107
- rspack(compiler) {
160
+ rspack(_compiler) {
108
161
  ROOT = process.cwd();
109
162
  userConfig = getConfig(options, ROOT);
110
163
  },
@@ -1 +1 @@
1
- {"version":3,"file":"router-code-splitter-plugin.js","sources":["../../../src/core/router-code-splitter-plugin.ts"],"sourcesContent":["import { isAbsolute, join, normalize } from 'node:path'\n\nimport { fileURLToPath, pathToFileURL } from 'node:url'\nimport { logDiff } from '@tanstack/router-utils'\nimport { getConfig } from './config'\nimport {\n compileCodeSplitReferenceRoute,\n compileCodeSplitVirtualRoute,\n} from './code-splitter/compilers'\nimport { splitPrefix } from './constants'\n\nimport type { Config } from './config'\nimport type { UnpluginContextMeta, UnpluginFactory } from 'unplugin'\n\nconst debug =\n process.env.TSR_VITE_DEBUG &&\n ['true', 'router-plugin'].includes(process.env.TSR_VITE_DEBUG)\n\nfunction capitalizeFirst(str: string): string {\n return str.charAt(0).toUpperCase() + str.slice(1)\n}\n\nfunction fileIsInRoutesDirectory(\n filePath: string,\n routesDirectory: string,\n): boolean {\n const routesDirectoryPath = isAbsolute(routesDirectory)\n ? routesDirectory\n : join(process.cwd(), routesDirectory)\n\n const path = normalize(filePath)\n\n return path.startsWith(routesDirectoryPath)\n}\n\ntype BannedBeforeExternalPlugin = {\n identifier: string\n pkg: string\n usage: string\n frameworks: Array<UnpluginContextMeta['framework']>\n}\n\nconst bannedBeforeExternalPlugins: Array<BannedBeforeExternalPlugin> = [\n {\n identifier: '@react-refresh',\n pkg: '@vitejs/plugin-react',\n usage: 'viteReact()',\n frameworks: ['vite'],\n },\n]\n\nclass FoundPluginInBeforeCode extends Error {\n constructor(externalPlugin: BannedBeforeExternalPlugin, framework: string) {\n super(`We detected that the '${externalPlugin.pkg}' was passed before '@tanstack/router-plugin'. Please make sure that '@tanstack/router-plugin' is passed before '${externalPlugin.pkg}' and try again: \ne.g.\nplugins: [\n TanStackRouter${capitalizeFirst(framework)}(), // Place this before ${externalPlugin.usage}\n ${externalPlugin.usage},\n]\n`)\n }\n}\n\nconst PLUGIN_NAME = 'unplugin:router-code-splitter'\n\nexport const unpluginRouterCodeSplitterFactory: UnpluginFactory<\n Partial<Config> | undefined\n> = (options = {}, { framework }) => {\n let ROOT: string = process.cwd()\n let userConfig = options as Config\n\n const isProduction = process.env.NODE_ENV === 'production'\n\n const handleSplittingFile = (code: string, id: string) => {\n if (debug) console.info('Splitting Route: ', id)\n\n const compiledVirtualRoute = compileCodeSplitVirtualRoute({\n code,\n root: ROOT,\n filename: id,\n })\n\n if (debug) {\n logDiff(code, compiledVirtualRoute.code)\n console.log('Output:\\n', compiledVirtualRoute.code)\n }\n\n return compiledVirtualRoute\n }\n\n const handleCompilingFile = (code: string, id: string) => {\n if (debug) console.info('Compiling Route: ', id)\n\n const compiledReferenceRoute = compileCodeSplitReferenceRoute({\n code,\n root: ROOT,\n filename: id,\n isProduction,\n })\n\n if (debug) {\n logDiff(code, compiledReferenceRoute.code)\n console.log('Output:\\n', compiledReferenceRoute.code + '\\n\\n')\n }\n\n return compiledReferenceRoute\n }\n\n return {\n name: 'router-code-splitter-plugin',\n enforce: 'pre',\n\n transform(code, id) {\n if (!userConfig.autoCodeSplitting) {\n return null\n }\n\n const url = pathToFileURL(id)\n url.searchParams.delete('v')\n id = fileURLToPath(url).replace(/\\\\/g, '/')\n\n if (id.includes(splitPrefix)) {\n return handleSplittingFile(code, id)\n } else if (\n fileIsInRoutesDirectory(id, userConfig.routesDirectory) &&\n (code.includes('createRoute(') || code.includes('createFileRoute('))\n ) {\n for (const externalPlugin of bannedBeforeExternalPlugins) {\n if (!externalPlugin.frameworks.includes(framework)) {\n continue\n }\n\n if (code.includes(externalPlugin.identifier)) {\n throw new FoundPluginInBeforeCode(externalPlugin, framework)\n }\n }\n\n return handleCompilingFile(code, id)\n }\n\n return null\n },\n\n transformInclude(id) {\n if (!userConfig.autoCodeSplitting) {\n return undefined\n }\n\n if (\n fileIsInRoutesDirectory(id, userConfig.routesDirectory) ||\n id.includes(splitPrefix)\n ) {\n return true\n }\n return false\n },\n\n vite: {\n configResolved(config) {\n ROOT = config.root\n\n userConfig = getConfig(options, ROOT)\n },\n },\n\n rspack(compiler) {\n ROOT = process.cwd()\n userConfig = getConfig(options, ROOT)\n },\n\n webpack(compiler) {\n ROOT = process.cwd()\n userConfig = getConfig(options, ROOT)\n\n if (\n userConfig.autoCodeSplitting &&\n compiler.options.mode === 'production'\n ) {\n compiler.hooks.done.tap(PLUGIN_NAME, () => {\n console.info('✅ ' + PLUGIN_NAME + ': code-splitting done!')\n setTimeout(() => {\n process.exit(0)\n })\n })\n }\n },\n }\n}\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"router-code-splitter-plugin.js","sources":["../../../src/core/router-code-splitter-plugin.ts"],"sourcesContent":["/**\n * It is important to familiarize yourself with how the code-splitting works in this plugin.\n * https://github.com/TanStack/router/pull/3355\n */\n\nimport { isAbsolute, join, normalize } from 'node:path'\nimport { fileURLToPath, pathToFileURL } from 'node:url'\nimport { logDiff } from '@tanstack/router-utils'\nimport { getConfig, splitGroupingsSchema } from './config'\nimport {\n compileCodeSplitReferenceRoute,\n compileCodeSplitVirtualRoute,\n detectCodeSplitGroupingsFromRoute,\n} from './code-splitter/compilers'\nimport {\n defaultCodeSplitGroupings,\n splitRouteIdentNodes,\n tsrSplit,\n} from './constants'\nimport { decodeIdentifier } from './code-splitter/path-ids'\nimport type { CodeSplitGroupings, SplitRouteIdentNodes } from './constants'\n\nimport type { Config } from './config'\nimport type {\n UnpluginContextMeta,\n UnpluginFactory,\n TransformResult as UnpluginTransformResult,\n} from 'unplugin'\n\nconst debug =\n process.env.TSR_VITE_DEBUG &&\n ['true', 'router-plugin'].includes(process.env.TSR_VITE_DEBUG)\n\nfunction capitalizeFirst(str: string): string {\n return str.charAt(0).toUpperCase() + str.slice(1)\n}\n\nfunction fileIsInRoutesDirectory(\n filePath: string,\n routesDirectory: string,\n): boolean {\n const routesDirectoryPath = isAbsolute(routesDirectory)\n ? routesDirectory\n : join(process.cwd(), routesDirectory)\n\n const path = normalize(filePath)\n\n return path.startsWith(routesDirectoryPath)\n}\n\ntype BannedBeforeExternalPlugin = {\n identifier: string\n pkg: string\n usage: string\n frameworks: Array<UnpluginContextMeta['framework']>\n}\n\nconst bannedBeforeExternalPlugins: Array<BannedBeforeExternalPlugin> = [\n {\n identifier: '@react-refresh',\n pkg: '@vitejs/plugin-react',\n usage: 'viteReact()',\n frameworks: ['vite'],\n },\n]\n\nclass FoundPluginInBeforeCode extends Error {\n constructor(externalPlugin: BannedBeforeExternalPlugin, framework: string) {\n super(`We detected that the '${externalPlugin.pkg}' was passed before '@tanstack/router-plugin'. Please make sure that '@tanstack/router-plugin' is passed before '${externalPlugin.pkg}' and try again: \ne.g.\nplugins: [\n TanStackRouter${capitalizeFirst(framework)}(), // Place this before ${externalPlugin.usage}\n ${externalPlugin.usage},\n]\n`)\n }\n}\n\nconst PLUGIN_NAME = 'unplugin:router-code-splitter'\n\nexport const unpluginRouterCodeSplitterFactory: UnpluginFactory<\n Partial<Config> | undefined\n> = (options = {}, { framework }) => {\n let ROOT: string = process.cwd()\n let userConfig = options as Config\n\n const isProduction = process.env.NODE_ENV === 'production'\n\n const getGlobalCodeSplitGroupings = () => {\n return (\n userConfig.codeSplittingOptions?.defaultBehavior ||\n defaultCodeSplitGroupings\n )\n }\n const getShouldSplitFn = () => {\n return userConfig.codeSplittingOptions?.splitBehavior\n }\n\n const handleCompilingReferenceFile = (\n code: string,\n id: string,\n ): UnpluginTransformResult => {\n if (debug) console.info('Compiling Route: ', id)\n\n const fromCode = detectCodeSplitGroupingsFromRoute({\n code,\n root: ROOT,\n filename: id,\n })\n\n if (fromCode.groupings) {\n const res = splitGroupingsSchema.safeParse(fromCode.groupings)\n if (!res.success) {\n const message = res.error.errors.map((e) => e.message).join('. ')\n throw new Error(\n `The groupings for the route \"${id}\" are invalid.\\n${message}`,\n )\n }\n }\n\n const userShouldSplitFn = getShouldSplitFn()\n\n const pluginSplitBehavior = userShouldSplitFn?.({\n routeId: fromCode.routeId,\n }) as CodeSplitGroupings | undefined\n\n if (pluginSplitBehavior) {\n const res = splitGroupingsSchema.safeParse(pluginSplitBehavior)\n if (!res.success) {\n const message = res.error.errors.map((e) => e.message).join('. ')\n throw new Error(\n `The groupings returned when using \\`splitBehavior\\` for the route \"${id}\" are invalid.\\n${message}`,\n )\n }\n }\n\n const splitGroupings: CodeSplitGroupings =\n fromCode.groupings || pluginSplitBehavior || getGlobalCodeSplitGroupings()\n\n const compiledReferenceRoute = compileCodeSplitReferenceRoute({\n code,\n root: ROOT,\n filename: id,\n runtimeEnv: isProduction ? 'prod' : 'dev',\n codeSplitGroupings: splitGroupings,\n })\n\n if (debug) {\n logDiff(code, compiledReferenceRoute.code)\n console.log('Output:\\n', compiledReferenceRoute.code + '\\n\\n')\n }\n\n return compiledReferenceRoute\n }\n\n const handleCompilingVirtualFile = (\n code: string,\n id: string,\n ): UnpluginTransformResult => {\n if (debug) console.info('Splitting Route: ', id)\n\n const [_, ...pathnameParts] = id.split('?')\n\n const searchParams = new URLSearchParams(pathnameParts.join('?'))\n const splitValue = searchParams.get(tsrSplit)\n\n if (!splitValue) {\n throw new Error(\n `The split value for the virtual route \"${id}\" was not found.`,\n )\n }\n\n const rawGrouping = decodeIdentifier(splitValue)\n const grouping = [...new Set(rawGrouping)].filter((p) =>\n splitRouteIdentNodes.includes(p as any),\n ) as Array<SplitRouteIdentNodes>\n\n const result = compileCodeSplitVirtualRoute({\n code,\n root: ROOT,\n filename: id,\n splitTargets: grouping,\n })\n\n if (debug) {\n logDiff(code, result.code)\n console.log('Output:\\n', result.code + '\\n\\n')\n }\n\n return result\n }\n\n return {\n name: 'router-code-splitter-plugin',\n enforce: 'pre',\n\n transform(code, id) {\n if (!userConfig.autoCodeSplitting) {\n return null\n }\n\n const url = pathToFileURL(id)\n url.searchParams.delete('v')\n id = fileURLToPath(url).replace(/\\\\/g, '/')\n\n if (id.includes(tsrSplit)) {\n return handleCompilingVirtualFile(code, id)\n } else if (\n fileIsInRoutesDirectory(id, userConfig.routesDirectory) &&\n (code.includes('createRoute(') || code.includes('createFileRoute('))\n ) {\n for (const externalPlugin of bannedBeforeExternalPlugins) {\n if (!externalPlugin.frameworks.includes(framework)) {\n continue\n }\n\n if (code.includes(externalPlugin.identifier)) {\n throw new FoundPluginInBeforeCode(externalPlugin, framework)\n }\n }\n\n return handleCompilingReferenceFile(code, id)\n }\n\n return null\n },\n\n transformInclude(id) {\n if (!userConfig.autoCodeSplitting) {\n return undefined\n }\n\n if (\n fileIsInRoutesDirectory(id, userConfig.routesDirectory) ||\n id.includes(tsrSplit)\n ) {\n return true\n }\n return false\n },\n\n vite: {\n configResolved(config) {\n ROOT = config.root\n\n userConfig = getConfig(options, ROOT)\n },\n },\n\n rspack(_compiler) {\n ROOT = process.cwd()\n userConfig = getConfig(options, ROOT)\n },\n\n webpack(compiler) {\n ROOT = process.cwd()\n userConfig = getConfig(options, ROOT)\n\n if (\n userConfig.autoCodeSplitting &&\n compiler.options.mode === 'production'\n ) {\n compiler.hooks.done.tap(PLUGIN_NAME, () => {\n console.info('✅ ' + PLUGIN_NAME + ': code-splitting done!')\n setTimeout(() => {\n process.exit(0)\n })\n })\n }\n },\n }\n}\n"],"names":[],"mappings":"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"}
@@ -25,6 +25,7 @@ declare const TanStackRouterGeneratorEsbuild: (options?: Partial<{
25
25
  indexToken: string;
26
26
  routeToken: string;
27
27
  enableRouteGeneration?: boolean | undefined;
28
+ codeSplittingOptions?: import('./core/config.js').CodeSplittingOptions | undefined;
28
29
  virtualRouteConfig?: string | import('@tanstack/virtual-file-routes').VirtualRootRoute | undefined;
29
30
  routeFilePrefix?: string | undefined;
30
31
  routeFileIgnorePattern?: string | undefined;
@@ -65,6 +66,7 @@ declare const TanStackRouterCodeSplitterEsbuild: (options?: Partial<{
65
66
  indexToken: string;
66
67
  routeToken: string;
67
68
  enableRouteGeneration?: boolean | undefined;
69
+ codeSplittingOptions?: import('./core/config.js').CodeSplittingOptions | undefined;
68
70
  virtualRouteConfig?: string | import('@tanstack/virtual-file-routes').VirtualRootRoute | undefined;
69
71
  routeFilePrefix?: string | undefined;
70
72
  routeFileIgnorePattern?: string | undefined;
@@ -105,6 +107,7 @@ declare const TanStackRouterEsbuild: (options?: Partial<{
105
107
  indexToken: string;
106
108
  routeToken: string;
107
109
  enableRouteGeneration?: boolean | undefined;
110
+ codeSplittingOptions?: import('./core/config.js').CodeSplittingOptions | undefined;
108
111
  virtualRouteConfig?: string | import('@tanstack/virtual-file-routes').VirtualRootRoute | undefined;
109
112
  routeFilePrefix?: string | undefined;
110
113
  routeFileIgnorePattern?: string | undefined;
@@ -29,6 +29,7 @@ declare const TanStackRouterGeneratorRspack: (options?: Partial<{
29
29
  indexToken: string;
30
30
  routeToken: string;
31
31
  enableRouteGeneration?: boolean | undefined;
32
+ codeSplittingOptions?: import('./core/config.js').CodeSplittingOptions | undefined;
32
33
  virtualRouteConfig?: string | import('@tanstack/virtual-file-routes').VirtualRootRoute | undefined;
33
34
  routeFilePrefix?: string | undefined;
34
35
  routeFileIgnorePattern?: string | undefined;
@@ -73,6 +74,7 @@ declare const TanStackRouterCodeSplitterRspack: (options?: Partial<{
73
74
  indexToken: string;
74
75
  routeToken: string;
75
76
  enableRouteGeneration?: boolean | undefined;
77
+ codeSplittingOptions?: import('./core/config.js').CodeSplittingOptions | undefined;
76
78
  virtualRouteConfig?: string | import('@tanstack/virtual-file-routes').VirtualRootRoute | undefined;
77
79
  routeFilePrefix?: string | undefined;
78
80
  routeFileIgnorePattern?: string | undefined;
@@ -117,6 +119,7 @@ declare const TanStackRouterRspack: (options?: Partial<{
117
119
  indexToken: string;
118
120
  routeToken: string;
119
121
  enableRouteGeneration?: boolean | undefined;
122
+ codeSplittingOptions?: import('./core/config.js').CodeSplittingOptions | undefined;
120
123
  virtualRouteConfig?: string | import('@tanstack/virtual-file-routes').VirtualRootRoute | undefined;
121
124
  routeFilePrefix?: string | undefined;
122
125
  routeFileIgnorePattern?: string | undefined;
@@ -25,6 +25,7 @@ declare const TanStackRouterGeneratorVite: (options?: Partial<{
25
25
  indexToken: string;
26
26
  routeToken: string;
27
27
  enableRouteGeneration?: boolean | undefined;
28
+ codeSplittingOptions?: import('./core/config.js').CodeSplittingOptions | undefined;
28
29
  virtualRouteConfig?: string | import('@tanstack/virtual-file-routes').VirtualRootRoute | undefined;
29
30
  routeFilePrefix?: string | undefined;
30
31
  routeFileIgnorePattern?: string | undefined;
@@ -65,6 +66,7 @@ declare const TanStackRouterCodeSplitterVite: (options?: Partial<{
65
66
  indexToken: string;
66
67
  routeToken: string;
67
68
  enableRouteGeneration?: boolean | undefined;
69
+ codeSplittingOptions?: import('./core/config.js').CodeSplittingOptions | undefined;
68
70
  virtualRouteConfig?: string | import('@tanstack/virtual-file-routes').VirtualRootRoute | undefined;
69
71
  routeFilePrefix?: string | undefined;
70
72
  routeFileIgnorePattern?: string | undefined;
@@ -105,6 +107,7 @@ declare const TanStackRouterVite: (options?: Partial<{
105
107
  indexToken: string;
106
108
  routeToken: string;
107
109
  enableRouteGeneration?: boolean | undefined;
110
+ codeSplittingOptions?: import('./core/config.js').CodeSplittingOptions | undefined;
108
111
  virtualRouteConfig?: string | import('@tanstack/virtual-file-routes').VirtualRootRoute | undefined;
109
112
  routeFilePrefix?: string | undefined;
110
113
  routeFileIgnorePattern?: string | undefined;
@@ -25,6 +25,7 @@ declare const TanStackRouterGeneratorWebpack: (options?: Partial<{
25
25
  indexToken: string;
26
26
  routeToken: string;
27
27
  enableRouteGeneration?: boolean | undefined;
28
+ codeSplittingOptions?: import('./core/config.js').CodeSplittingOptions | undefined;
28
29
  virtualRouteConfig?: string | import('@tanstack/virtual-file-routes').VirtualRootRoute | undefined;
29
30
  routeFilePrefix?: string | undefined;
30
31
  routeFileIgnorePattern?: string | undefined;
@@ -65,6 +66,7 @@ declare const TanStackRouterCodeSplitterWebpack: (options?: Partial<{
65
66
  indexToken: string;
66
67
  routeToken: string;
67
68
  enableRouteGeneration?: boolean | undefined;
69
+ codeSplittingOptions?: import('./core/config.js').CodeSplittingOptions | undefined;
68
70
  virtualRouteConfig?: string | import('@tanstack/virtual-file-routes').VirtualRootRoute | undefined;
69
71
  routeFilePrefix?: string | undefined;
70
72
  routeFileIgnorePattern?: string | undefined;
@@ -105,6 +107,7 @@ declare const TanStackRouterWebpack: (options?: Partial<{
105
107
  indexToken: string;
106
108
  routeToken: string;
107
109
  enableRouteGeneration?: boolean | undefined;
110
+ codeSplittingOptions?: import('./core/config.js').CodeSplittingOptions | undefined;
108
111
  virtualRouteConfig?: string | import('@tanstack/virtual-file-routes').VirtualRootRoute | undefined;
109
112
  routeFilePrefix?: string | undefined;
110
113
  routeFileIgnorePattern?: string | undefined;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@tanstack/router-plugin",
3
- "version": "1.99.14",
3
+ "version": "1.101.0",
4
4
  "description": "Modern and scalable routing for React applications",
5
5
  "author": "Tanner Linsley",
6
6
  "license": "MIT",
@@ -100,7 +100,7 @@
100
100
  "chokidar": "^3.6.0",
101
101
  "unplugin": "^2.1.2",
102
102
  "zod": "^3.24.1",
103
- "@tanstack/router-generator": "^1.99.14",
103
+ "@tanstack/router-generator": "^1.101.0",
104
104
  "@tanstack/router-utils": "^1.99.5",
105
105
  "@tanstack/virtual-file-routes": "^1.99.0"
106
106
  },
@@ -108,7 +108,7 @@
108
108
  "@rsbuild/core": ">=1.0.2",
109
109
  "vite": ">=5.0.0 || >=6.0.0",
110
110
  "webpack": ">=5.92.0",
111
- "@tanstack/react-router": "^1.99.13"
111
+ "@tanstack/react-router": "^1.101.0"
112
112
  },
113
113
  "peerDependenciesMeta": {
114
114
  "@rsbuild/core": {