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

feat(react-router): add NotFoundErrorData interface for improved type safety #3112

Open
wants to merge 11 commits into
base: main
Choose a base branch
from

Conversation

Sheraff
Copy link

@Sheraff Sheraff commented Jan 5, 2025

Related discussion thread: #3113. This PR implements one of the possible solutions mentioned in the discussion.


Here's a demo of this PR, throwing type-safe notFound errors: https://stackblitz.com/edit/tanstack-router-fyrpy35d?file=src%2Froutes%2Findex.tsx


Currently the notFound() function accepts a params object with the shape of NotFoundError that is then passed as props to the notFoundComponent.

Arbitrary data can be send through this mechanism with the data?: any key of NotFoundError, but this any prevents us from creating type-safe "not found" errors.

This PR proposes that users should be able to define their own data shape through the global augmentation of a new interface NotFoundErrorData. For example:

declare module '@tanstack/react-router' {
  interface NotFoundErrorData {
    data: {
      a: string
      b: string
    }
  }
}
declare module '@tanstack/react-router' {
  interface NotFoundErrorData {
    data: 'foo' | 'bar'
  }
}
declare module '@tanstack/react-router' {
  interface NotFoundErrorData {
    data:
      | { type: 'foo', a: number }
      | { type: 'bar', b: string }
  }
}

This PR uses this new interface in a way that will preserve data?: any as the default if it is not globally augmented:

data?: NotFoundErrorData extends { data: infer TData } ? TData : any

Closes #3113

@Sheraff Sheraff changed the title feat'react-router): add NotFoundErrorData interface for improved type safety feat(react-router): add NotFoundErrorData interface for improved type safety Jan 5, 2025
@Sheraff Sheraff marked this pull request as ready for review January 5, 2025 09:42
Copy link

nx-cloud bot commented Jan 5, 2025

View your CI Pipeline Execution ↗ for commit 659a5df.

Command Status Duration Result
nx affected --targets=test:eslint,test:unit,tes... ✅ Succeeded 4m 41s View ↗
nx run-many --target=build --exclude=examples/*... ✅ Succeeded 1m 17s View ↗

☁️ Nx Cloud last updated this comment at 2025-01-15 19:00:06 UTC

Copy link

pkg-pr-new bot commented Jan 5, 2025

Open in Stackblitz

More templates

@tanstack/arktype-adapter

npm i https://pkg.pr.new/@tanstack/arktype-adapter@3112

@tanstack/create-router

npm i https://pkg.pr.new/@tanstack/create-router@3112

@tanstack/directive-functions-plugin

npm i https://pkg.pr.new/@tanstack/directive-functions-plugin@3112

@tanstack/create-start

npm i https://pkg.pr.new/@tanstack/create-start@3112

@tanstack/history

npm i https://pkg.pr.new/@tanstack/history@3112

@tanstack/react-cross-context

npm i https://pkg.pr.new/@tanstack/react-cross-context@3112

@tanstack/eslint-plugin-router

npm i https://pkg.pr.new/@tanstack/eslint-plugin-router@3112

@tanstack/react-router

npm i https://pkg.pr.new/@tanstack/react-router@3112

@tanstack/react-router-with-query

npm i https://pkg.pr.new/@tanstack/react-router-with-query@3112

@tanstack/router-cli

npm i https://pkg.pr.new/@tanstack/router-cli@3112

@tanstack/router-devtools

npm i https://pkg.pr.new/@tanstack/router-devtools@3112

@tanstack/router-generator

npm i https://pkg.pr.new/@tanstack/router-generator@3112

@tanstack/router-plugin

npm i https://pkg.pr.new/@tanstack/router-plugin@3112

@tanstack/router-vite-plugin

npm i https://pkg.pr.new/@tanstack/router-vite-plugin@3112

@tanstack/server-functions-plugin

npm i https://pkg.pr.new/@tanstack/server-functions-plugin@3112

@tanstack/start

npm i https://pkg.pr.new/@tanstack/start@3112

@tanstack/start-plugin

npm i https://pkg.pr.new/@tanstack/start-plugin@3112

@tanstack/valibot-adapter

npm i https://pkg.pr.new/@tanstack/valibot-adapter@3112

@tanstack/virtual-file-routes

npm i https://pkg.pr.new/@tanstack/virtual-file-routes@3112

@tanstack/zod-adapter

npm i https://pkg.pr.new/@tanstack/zod-adapter@3112

commit: 659a5df

@EskiMojo14
Copy link
Contributor

might be worth extending the existing Register interface already used for registering the router type, rather than adding a new interface for the same purpose

Copy link
Member

@SeanCassiere SeanCassiere left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please add this into the reference docs for notFound.

@SeanCassiere SeanCassiere requested a review from chorobin January 10, 2025 01:28
@Sheraff
Copy link
Author

Sheraff commented Jan 11, 2025

might be worth extending the existing Register interface already used for registering the router type, rather than adding a new interface for the same purpose

I would love a 2nd opinion on this. I'm definitely not against this and it does kinda make sense. But it's also not uncommon for libraries to expose multiple interfaces that can be extended, and by using a "dedicated" one, we're kinda scoping the concerns.

Again, it also does make complete sense to me to reuse the Register. So anybody wants to weigh in?

@schiller-manuel
Copy link
Contributor

cc @chorobin please have a look
especially whether we want this configurable per route

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

Successfully merging this pull request may close these issues.

4 participants