Skip to content

Commit

Permalink
Support moduleResolution Node16 and NodeNext for non-JS files.
Browse files Browse the repository at this point in the history
#12440 introduced a fix for tsconfig, however, it broke non-JS routes (like .mdx)
  • Loading branch information
Nowell Strite committed Dec 3, 2024
1 parent f0145cc commit f21c90c
Show file tree
Hide file tree
Showing 3 changed files with 15 additions and 7 deletions.
5 changes: 5 additions & 0 deletions .changeset/moody-eagles-deny.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
"@react-router/dev": patch
---

Support `moduleResolution` `Node16` and `NodeNext` for non-JS files.
1 change: 1 addition & 0 deletions contributors.yml
Original file line number Diff line number Diff line change
Expand Up @@ -211,6 +211,7 @@
- Nismit
- nnhjs
- noisypigeon
- nowells
- Nurai1
- Obi-Dann
- OlegDev1
Expand Down
16 changes: 9 additions & 7 deletions packages/react-router-dev/typegen/generate.ts
Original file line number Diff line number Diff line change
@@ -1,11 +1,16 @@
import ts from "dedent";
import * as Path from "pathe";
import * as Pathe from "pathe/utils";

import { type RouteManifest, type RouteManifestEntry } from "../config/routes";
import { type Context } from "./context";
import { getTypesPath } from "./paths";

function getTypescriptSafePath(path: string) {
// In typescript, we want to support "moduleResolution": "nodenext" as well as not having "allowImportingTsExtensions": true,
// so we normalize all JS like files to `.js`, but allow other extensions such as `.mdx` and others that might be used as routes.
return path.replace(/\.(js|ts)x?$/, ".js");
}

export function generate(ctx: Context, route: RouteManifestEntry): string {
const lineage = getRouteLineage(ctx.config.routes, route);
const urlpath = lineage.map((route) => route.path).join("/");
Expand All @@ -20,9 +25,9 @@ export function generate(ctx: Context, route: RouteManifestEntry): string {
);

const indent = i === 0 ? "" : " ".repeat(2);
let source = noExtension(rel);
let source = getTypescriptSafePath(rel);
if (!source.startsWith("../")) source = "./" + source;
return `${indent}import type { Info as Parent${i} } from "${source}.js"`;
return `${indent}import type { Info as Parent${i} } from "${source}"`;
})
.join("\n");

Expand All @@ -34,7 +39,7 @@ export function generate(ctx: Context, route: RouteManifestEntry): string {
${parentTypeImports}
type Module = typeof import("../${Pathe.filename(route.file)}.js")
type Module = typeof import("../${getTypescriptSafePath(Path.basename(route.file))}")
export type Info = {
parents: [${parents.map((_, i) => `Parent${i}`).join(", ")}],
Expand Down Expand Up @@ -72,9 +77,6 @@ export function generate(ctx: Context, route: RouteManifestEntry): string {
`;
}

const noExtension = (path: string) =>
Path.join(Path.dirname(path), Pathe.filename(path));

function getRouteLineage(routes: RouteManifest, route: RouteManifestEntry) {
const result: RouteManifestEntry[] = [];
while (route) {
Expand Down

0 comments on commit f21c90c

Please sign in to comment.