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

fix(router-core): return meta if match.status notFound #3912

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

Conversation

roduyemi
Copy link

@roduyemi roduyemi commented Apr 1, 2025

Fixes #3657

Updates the match meta, links, script etc. if in case of match.status being notFound or an error.

@@ -1443,7 +1443,7 @@ export class RouterCore<
// If it's already a success, update headers and head content
// These may get updated again if the match is refreshed
// due to being stale
if (match.status === 'success') {
if (match.status === 'success' || match.status === 'notFound') {
Copy link
Contributor

Choose a reason for hiding this comment

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

while this will invoke the meta fns, the types of those functions are now incorrect I think, as loaderdata is not necessarily defined

Copy link
Author

Choose a reason for hiding this comment

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

Thanks @schiller-manuel, may you please help with the correct fix for this? We're keen to update to the latest version but this is a blocker for us 🙏🏿

Copy link
Contributor

Choose a reason for hiding this comment

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

I am not sure. just making the loader data optional would be the easiest ...
@SeanCassiere why don't we pass in the full AssetFnContextOptions into headers?

Copy link
Contributor

Choose a reason for hiding this comment

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

what about any other errors that might be handled by the errorComponent? why specifically just notFound?

Copy link
Author

Choose a reason for hiding this comment

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

If it always updated the meta tags (success or error) that'd be great! So it should update for success, error and notFound but not redirected or pending?

Copy link
Contributor

Choose a reason for hiding this comment

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

probably? unless there is a reason not to update them?

Copy link
Author

Choose a reason for hiding this comment

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

Nope, will make those changes and thanks for the speedy response!

@roduyemi roduyemi changed the title fix(router-core): return meta if match.success notFound fix(router-core): return meta if match.status notFound Apr 1, 2025
Copy link

nx-cloud bot commented Apr 1, 2025

View your CI Pipeline Execution ↗ for commit e2b1249.

Command Status Duration Result
nx affected --targets=test:eslint,test:unit,tes... ✅ Succeeded 5m 33s View ↗
nx run-many --target=build --exclude=examples/*... ✅ Succeeded 2m 3s View ↗

☁️ Nx Cloud last updated this comment at 2025-04-02 20:52:21 UTC

Copy link

pkg-pr-new bot commented Apr 1, 2025

More templates

@tanstack/arktype-adapter

npm i https://pkg.pr.new/TanStack/router/@tanstack/arktype-adapter@3912

@tanstack/create-router

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

@tanstack/create-start

npm i https://pkg.pr.new/TanStack/router/@tanstack/create-start@3912

@tanstack/directive-functions-plugin

npm i https://pkg.pr.new/TanStack/router/@tanstack/directive-functions-plugin@3912

@tanstack/eslint-plugin-router

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

@tanstack/history

npm i https://pkg.pr.new/TanStack/router/@tanstack/history@3912

@tanstack/react-router

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

@tanstack/react-router-devtools

npm i https://pkg.pr.new/TanStack/router/@tanstack/react-router-devtools@3912

@tanstack/react-start

npm i https://pkg.pr.new/TanStack/router/@tanstack/react-start@3912

@tanstack/react-router-with-query

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

@tanstack/react-start-client

npm i https://pkg.pr.new/TanStack/router/@tanstack/react-start-client@3912

@tanstack/react-start-config

npm i https://pkg.pr.new/TanStack/router/@tanstack/react-start-config@3912

@tanstack/react-start-plugin

npm i https://pkg.pr.new/TanStack/router/@tanstack/react-start-plugin@3912

@tanstack/react-start-router-manifest

npm i https://pkg.pr.new/TanStack/router/@tanstack/react-start-router-manifest@3912

@tanstack/react-start-server

npm i https://pkg.pr.new/TanStack/router/@tanstack/react-start-server@3912

@tanstack/router-cli

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

@tanstack/router-core

npm i https://pkg.pr.new/TanStack/router/@tanstack/router-core@3912

@tanstack/router-devtools

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

@tanstack/router-devtools-core

npm i https://pkg.pr.new/TanStack/router/@tanstack/router-devtools-core@3912

@tanstack/router-plugin

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

@tanstack/router-generator

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

@tanstack/router-utils

npm i https://pkg.pr.new/TanStack/router/@tanstack/router-utils@3912

@tanstack/router-vite-plugin

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

@tanstack/server-functions-plugin

npm i https://pkg.pr.new/TanStack/router/@tanstack/server-functions-plugin@3912

@tanstack/solid-router

npm i https://pkg.pr.new/TanStack/router/@tanstack/solid-router@3912

@tanstack/solid-router-devtools

npm i https://pkg.pr.new/TanStack/router/@tanstack/solid-router-devtools@3912

@tanstack/solid-start

npm i https://pkg.pr.new/TanStack/router/@tanstack/solid-start@3912

@tanstack/solid-start-config

npm i https://pkg.pr.new/TanStack/router/@tanstack/solid-start-config@3912

@tanstack/solid-start-client

npm i https://pkg.pr.new/TanStack/router/@tanstack/solid-start-client@3912

@tanstack/solid-start-plugin

npm i https://pkg.pr.new/TanStack/router/@tanstack/solid-start-plugin@3912

@tanstack/solid-start-router-manifest

npm i https://pkg.pr.new/TanStack/router/@tanstack/solid-start-router-manifest@3912

@tanstack/solid-start-server

npm i https://pkg.pr.new/TanStack/router/@tanstack/solid-start-server@3912

@tanstack/start

npm i https://pkg.pr.new/TanStack/router/@tanstack/start@3912

@tanstack/start-api-routes

npm i https://pkg.pr.new/TanStack/router/@tanstack/start-api-routes@3912

@tanstack/start-client-core

npm i https://pkg.pr.new/TanStack/router/@tanstack/start-client-core@3912

@tanstack/start-config

npm i https://pkg.pr.new/TanStack/router/@tanstack/start-config@3912

@tanstack/start-server-core

npm i https://pkg.pr.new/TanStack/router/@tanstack/start-server-core@3912

@tanstack/start-server-functions-client

npm i https://pkg.pr.new/TanStack/router/@tanstack/start-server-functions-client@3912

@tanstack/start-server-functions-fetcher

npm i https://pkg.pr.new/TanStack/router/@tanstack/start-server-functions-fetcher@3912

@tanstack/start-server-functions-handler

npm i https://pkg.pr.new/TanStack/router/@tanstack/start-server-functions-handler@3912

@tanstack/start-server-functions-ssr

npm i https://pkg.pr.new/TanStack/router/@tanstack/start-server-functions-ssr@3912

@tanstack/start-server-functions-server

npm i https://pkg.pr.new/TanStack/router/@tanstack/start-server-functions-server@3912

@tanstack/valibot-adapter

npm i https://pkg.pr.new/TanStack/router/@tanstack/valibot-adapter@3912

@tanstack/virtual-file-routes

npm i https://pkg.pr.new/TanStack/router/@tanstack/virtual-file-routes@3912

@tanstack/zod-adapter

npm i https://pkg.pr.new/TanStack/router/@tanstack/zod-adapter@3912

commit: e2b1249

@roduyemi roduyemi requested a review from schiller-manuel April 2, 2025 15:00
match.headers = route.options.headers?.({
loaderData: match.loaderData,
...(loaderData && { loaderData }),
Copy link
Member

Choose a reason for hiding this comment

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

Why is this bit changing? Same question for the bit down below?

Copy link
Contributor

Choose a reason for hiding this comment

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

yeah seems not necessary.

Copy link
Author

Choose a reason for hiding this comment

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

This is based on your request to make loaderData optional 🙂 is this not what you meant?

Copy link
Contributor

Choose a reason for hiding this comment

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

no sorry i was referring to the user facing types

@schiller-manuel
Copy link
Contributor

please pass AssetFnContextOptions into headers as well
then make loaderData in AssetFnContextOptionsoptional

@roduyemi
Copy link
Author

roduyemi commented Apr 2, 2025

please pass AssetFnContextOptions into headers as well then make loaderData in AssetFnContextOptionsoptional

Thank you for clarifying the change you’re expecting.

const headers = route.options.headers?.({
loaderData,
})
const headers = route.options.headers?.(assetContext)
Copy link
Contributor

@schiller-manuel schiller-manuel Apr 2, 2025

Choose a reason for hiding this comment

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

are the meta functions down here really executed when an error is thrown in the loader? don't we have to run them in the catch block as well?

if my hunch is right, why are your tests not failing?

Copy link
Author

Choose a reason for hiding this comment

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

The match.meta is updated here as expected but is there another change you're expecting? I can extend the test to add scripts and links etc too if you want?

Copy link
Contributor

Choose a reason for hiding this comment

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

I was just wondering what happens if the loader throws. it would not reach those lines, so headers/links/ etc would not get executed, right?

Copy link
Author

Choose a reason for hiding this comment

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

These lines are executed now because the condition has been updated to include a match.status of error or notFound 🙂

Copy link
Contributor

@schiller-manuel schiller-manuel Apr 2, 2025

Choose a reason for hiding this comment

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

are you on discord? let's discuss there (just DM me)

https://discord.com/invite/WrRKjPJ

Copy link
Author

Choose a reason for hiding this comment

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

Please let me know if there's anything you'd like me to do to get this moved forward 🙏🏿

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

Successfully merging this pull request may close these issues.

Route head function not called if rendering notFoundComponent
3 participants