Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

'redirectSymbol' introduced in #12527 causes type error #12615

Closed
dantrain opened this issue Dec 21, 2024 · 16 comments
Closed

'redirectSymbol' introduced in #12527 causes type error #12615

dantrain opened this issue Dec 21, 2024 · 16 comments

Comments

@dantrain
Copy link

I'm using React Router as a...

framework

Reproduction

Run tsc

System Info

System:
    OS: macOS 15.1.1
    CPU: (10) arm64 Apple M1 Pro
    Memory: 139.30 MB / 32.00 GB
    Shell: 5.9 - /bin/zsh
  Binaries:
    Node: 22.11.0 - /usr/local/bin/node
    npm: 10.9.0 - /usr/local/bin/npm
    pnpm: 9.15.0 - ~/Library/pnpm/pnpm
    Watchman: 2024.10.07.00 - /opt/homebrew/bin/watchman
  Browsers:
    Chrome: 131.0.6778.205
    Safari: 18.1.1

Used Package Manager

pnpm

Expected Behavior

No type errors

Actual Behavior

Received error:

error TS4058: Return type of exported function has or is using name 'redirectSymbol' from external module "/node_modules/.pnpm/[email protected][email protected][email protected][email protected]/node_modules/react-router/dist/development/route-data-aSUFWnQ6" but cannot be named.

export async function loader({ request, context }: Route.LoaderArgs) {
@dantrain dantrain added the bug label Dec 21, 2024
@penspinner
Copy link

I am also encountering this TypeScript issue. This error occurs when any functions return a redirect call.

Here is my related Discord message + thread: https://discord.com/channels/770287896669978684/1319889604211511384.

Here are my TypeScript configs:

tsconfig.json

{
    "files": [],
    "references": [{ "path": "./tsconfig.node.json" }, { "path": "./tsconfig.vite.json" }],
    "compilerOptions": {
        "forceConsistentCasingInFileNames": true,
        "isolatedModules": true,
        "skipLibCheck": true,
        "strict": true,
        "noEmit": true,
        "paths": {
            "~/*": ["./app/*"]
        }
    }
}

tsconfig.node.json

{
    "extends": "./tsconfig.json",
    "include": [
        "react-router.config.ts",
        "tailwind.config.ts",
        "vite.config.ts",
        "vitest.workspace.ts",
        "prisma/**/*.ts"
    ],
    "compilerOptions": {
        "composite": true,
        "strict": true,
        "types": ["node"],
        "lib": ["ES2022"],
        "target": "ES2022",
        "module": "NodeNext",
        "moduleResolution": "NodeNext"
    }
}

tsconfig.vite.json

{
    "extends": "./tsconfig.json",
    "include": [
        ".react-router/types/**/*",
        "app/**/*",
        "app/**/.server/**/*",
        "app/**/.client/**/*",
        "server/**/*",
        "env.d.ts",
        "tests/**/*.ts",
        "types.ts"
    ],
    "compilerOptions": {
        "composite": true,
        "lib": ["DOM", "DOM.Iterable", "ES2022"],
        "types": ["vite/client"],
        "target": "ES2022",
        "module": "ES2022",
        "moduleResolution": "bundler",
        "jsx": "react-jsx",
        "baseUrl": ".",
        "rootDirs": [".", "./.react-router/types"],
        "typeRoots": ["public/node_modules/@types", "./node_modules"],
        "esModuleInterop": true,
        "resolveJsonModule": true
    }
}

@penspinner
Copy link

@pcattori Likely has something to do with this PR here: #12527.

@pcattori
Copy link
Contributor

I can't reproduce this locally. Could you share a repro on stackblitz or github?

@penspinner
Copy link

penspinner commented Dec 22, 2024

@pcattori I figured out that the issue occurs when the tsconfig.json.compilerOptions has composite: true.

@dantrain
Copy link
Author

@pcattori here's a branch of the repo where I'm encountering this issue.

As @penspinner observed, it is happening when a redirect is returned from a loader/action. I don't seem to have composite: true in my tsconfig.

Presumably I could get around this by throwing the redirect instead of returning it, but the docs seem to encourage returning.

@10xsai
Copy link

10xsai commented Dec 24, 2024

@pcattori Hi, facing same issue with RR7 as framework. When i am removing return from redirect, the error is going away. This is the exact message

Return type of exported function has or is using name 'redirectSymbol' from external module "/home/sai/MyProject/node_modules/.pnpm/[email protected][email protected][email protected][email protected]/node_modules/react-router/dist/development/route-data-aSUFWnQ6" but cannot be named.ts(4058)

@AdiRishi
Copy link

Experienced the same thing.

@pcattori if you want a very minimal reproduction repository, made one here - https://github.com/AdiRishi/rr7-redirect-ts-bug

The error can be seen by running npm run typecheck or going to the app/routes/redirect-to-home.tsx file.

@m-muiznieks
Copy link

I have exactly the same issue. :/

@pcattori
Copy link
Contributor

pcattori commented Dec 30, 2024

@AdiRishi looking at your reproduction (https://github.com/AdiRishi/rr7-redirect-ts-bug), I commented out declaration, declarationMap, and sourceMap from your tsconfig.json since a React Router app is not a library and does not need generated type declarations. In fact, any settings of tsconfig.json that solely affect compilation output are irrelevant as React Router only uses tsc for typechecking and instead uses Vite for compilation.

@dantrain looks like your @remix-relay/typescript-config package also sets these options. You should be able to override them to false in your remix.json if you want to keep base.json as is.

Closing since those were the two reproductions provided so far, but if anyone disagrees with my reasoning or has a reproduction without compiler-only settings like declaration, declarationMap, or sourceMap, then I'm happy to reopen this and continue discussion.

@iamtomcat
Copy link

I'm currently running into this without any of those settings. I don't have a reproducible version at the moment. I'll try and make a version in the next few days.

@dantrain
Copy link
Author

Thank you for looking into this @pcattori, I overrode these as you suggested and the problem is solved for me.

I wondered why I had added these library only options to my base tsconfig.json in the first place. It seems these are present in the boilerplate when setting up a monorepo using the Turborepo command create-turbo@latest, see here. Hopefully this helps anyone with a similar issue.

@penspinner
Copy link

@pcattori

I tried setting sourceMap, declaration, and declarationMap to false in my tsconfig.vite.json. It's telling me that:

Composite projects may not disable declaration emit.

https://www.typescriptlang.org/tsconfig/#composite

image

I'm using project references and it requires composite setting to be enabled. TypeScript project references is used in the Node Custom Server React Router template.

@jfsiii
Copy link

jfsiii commented Jan 2, 2025

I have the same issue/constraint @penspinner mentioned.

For now, I'm working around it using the same code react-router does but without the problematic bit.

Response.redirect(url, status) works in most/simple cases but there are some times we're also passing other headers.

I also considered using data(null, { headers: { location: url, status }) but since react-router is using new Response I stuck with that.

@jack-r-warren
Copy link

jack-r-warren commented Jan 3, 2025

Also arrived here from the templates. A minimal reproduction:

npx create-react-router@latest ./reproduction \ 
  --template remix-run/react-router-templates/node-custom-server --yes

Edit ./reproduction/app/routes/home.tsx:

+ import { redirect } from "react-router";
  export async function loader({ context }: Route.LoaderArgs) {
+   return redirect("example.org");

TypeScript error on loader:

Return type of exported function has or is using name 'redirectSymbol' from external module "<redacted>/reproduction/node_modules/react-router/dist/development/route-data-aSUFWnQ6" but cannot be named. ts(4058)

Copy link
Contributor

🤖 Hello there,

We just published version 7.1.2-pre.0 which involves this issue. If you'd like to take it for a test run please try it out and let us know what you think!

Thanks!

@OscarAyoy
Copy link

Returning a redirect() seems to be working as expected again!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

10 participants