Skip to content

Commit

Permalink
doc: update the accumulated router context guide to for checking brea…
Browse files Browse the repository at this point in the history
…dcrumbs (#2160)

* doc(accumulated-route-context): useRouterState to listen reactive state change

* Apply suggestions from code review

Don't use `routeContext`, use `context` instead.

* ci: apply automated fixes

* docs: cleanup the breadcrumbs filer

---------

Co-authored-by: Sean Cassiere <33615041+SeanCassiere@users.noreply.github.com>
Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com>
  • Loading branch information
3 people authored Aug 21, 2024
1 parent d318a1a commit 22f0985
Showing 1 changed file with 12 additions and 11 deletions.
23 changes: 12 additions & 11 deletions docs/framework/react/guide/router-context.md
Original file line number Diff line number Diff line change
Expand Up @@ -303,15 +303,16 @@ Context, especially the isolated route `context` objects, make it trivial to acc
// src/routes/__root.tsx
export const Route = createRootRoute({
component: () => {
const router = useRouter()

const breadcrumbs = router.state.matches.map((match) => {
const { context } = match
return {
title: context.getTitle(),
path: match.path,
}
})
const matches = useRouterState({ select: (s) => s.matches })

const breadcrumbs = matches
.filter((match) => match.context.getTitle)
.map(({ pathname, context }) => {
return {
title: context.getTitle(),
path: pathname,
}
})

// ...
},
Expand All @@ -324,9 +325,9 @@ Using that same route context, we could also generate a title tag for our page's
// src/routes/__root.tsx
export const Route = createRootRoute({
component: () => {
const router = useRouter()
const matches = useRouterState({ select: (s) => s.matches })

const matchWithTitle = [...router.state.matches]
const matchWithTitle = [...matches]
.reverse()
.find((d) => d.context.getTitle)

Expand Down

0 comments on commit 22f0985

Please sign in to comment.