-
Notifications
You must be signed in to change notification settings - Fork 3
Update react-router monorepo to v7 (major) #36
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
base: dev
Are you sure you want to change the base?
Conversation
⚠ Artifact update problemRenovate failed to update an artifact related to this branch. You probably do not want to merge this PR as-is. ♻ Renovate will retry this branch, including artifacts, only when one of the following happens:
The artifact failure details are included below: File name: package-lock.json
|
15f2280
to
1a456b1
Compare
|
This PR contains the following updates:
^5.2.0
->^7.0.0
^5.2.0
->^7.0.0
Release Notes
remix-run/react-router (react-router)
v7.9.4
Compare Source
Patch Changes
handle external redirects in from server actions (#14400)
New (unstable)
useRoute
hook for accessing data from specific routes (#14407)For example, let's say you have an
admin
route somewhere in your app and you want any child routes ofadmin
to all have access to theloaderData
andactionData
fromadmin.
You might even want to create a reusable widget that all of the routes nested under
admin
could use:In framework mode,
useRoute
knows all your app's routes and gives you TS errors when invalid route IDs are passed in:useRoute
returnsundefined
if the route is not part of the current page:Note: the
root
route is the exception since it is guaranteed to be part of the current page.As a result,
useRoute
never returnsundefined
forroot
.loaderData
andactionData
are marked as optional since they could be accessed before theaction
is triggered or after theloader
threw an error:If instead of a specific route, you wanted access to the current route's
loaderData
andactionData
, you can calluseRoute
without arguments:This usage is equivalent to calling
useLoaderData
anduseActionData
, but consolidates all route data access into one hook:useRoute
.Note: when calling
useRoute()
(without a route ID), TS has no way to know which route is the current route.As a result,
loaderData
andactionData
are typed asunknown
.If you want more type-safety, you can either narrow the type yourself with something like
zod
or you can refactor your app to pass down typed props to yourAdminWidget
:v7.9.3
Compare Source
Patch Changes
Do not try to use
turbo-stream
to decode CDN errors that never reached the server (#14385)Fix Data Mode regression causing a 404 during initial load in when
middleware
exists without anyloader
functions (#14393)v7.9.2
Compare Source
Patch Changes
middleware
on initial load even if no loaders exist (#14348)createRoutesStub
to run route middleware<RoutesStub future={{ v8_middleware: true }} />
flag to enable the propercontext
typeUpdate Lazy Route Discovery manifest requests to use a singular comma-separated
paths
query param instead of repeatedp
query params (#14321)[UNSTABLE] Add
fetcher.unstable_reset()
API (#14206)Made useOutlet element reference have stable identity in-between route chages (#13382)
feat: enable full transition support for the rsc router (#14362)
In RSC Data Mode, handle SSR'd client errors and re-try in the browser (#14342)
Support
middleware
prop on<Route>
for usage with a data router viacreateRoutesFromElements
(#14357)Handle encoded question mark and hash characters in ancestor splat routes (#14249)
Fail gracefully on manifest version mismatch logic if
sessionStorage
access is blocked (#14335)v7.9.1
Compare Source
Patch Changes
Future
interface naming frommiddleware
->v8_middleware
(#14327)v7.9.0
Compare Source
Minor Changes
Stabilize middleware and context APIs. (#14215)
We have removed the
unstable_
prefix from the following APIs and they are now considered stable and ready for production use:RouterContextProvider
createContext
createBrowserRouter
getContext
option<HydratedRouter>
getContext
propPlease see the Middleware Docs, the Middleware RFC, and the Client-side Context RFC for more information.
Patch Changes
meta()
JSON-LD content (#14316)href
function available in a react-server context (#14262)getPayload()
is called to allow for "in-context" decoding and hoisting of contextual assets (#14248)href()
now correctly processes routes that have an extension after the parameter or are a single optional parameter. (#13797)v7.8.2
Compare Source
Patch Changes
[UNSTABLE] Remove Data Mode
future.unstable_middleware
flag fromcreateBrowserRouter
(#14213)getLoadContext
type behavior change[UNSTABLE] Add
<RouterProvider unstable_onError>
/<HydratedRouter unstable_onError>
prop for client side error reporting (#14162)server action revalidation opt out via $SKIP_REVALIDATION field (#14154)
Properly escape interpolated param values in
generatePath()
(#13530)Maintain
ReadonlyMap
andReadonlySet
types in server response data. (#13092)[UNSTABLE] Delay serialization of
.data
redirects to 202 responses until after middleware chain (#14205)Fix
TypeError
if you throw frompatchRoutesOnNavigation
when no partial matches exist (#14198)Fix
basename
usage without a leading slash in data routers (#11671)[UNSTABLE] Update client middleware so it returns the data strategy results allowing for more advanced post-processing middleware (#14151)
v7.8.1
Compare Source
Patch Changes
matchPath
(#11813)basename
is set withssr:false
(#13791)isRouteErrorResponse
utility inreact-server
environments (#14166)meta
andlinks
Route Exports in RSC Data Mode (#14136)data()
values toResponse
instances viaResponse.json()
in resource routes and middleware (#14159, #14181)v7.8.0
Compare Source
Minor Changes
nonce
prop toLinks
&PrefetchPageLinks
(#14048)loaderData
arguments/properties alongside existingdata
arguments/properties to provide consistency and clarity betweenloaderData
andactionData
across the board (#14047)Route.MetaArgs
,Route.MetaMatch
,MetaArgs
,MetaMatch
,Route.ComponentProps.matches
,UIMatch
@deprecated
warnings have been added to the existingdata
properties to point users to newloaderData
properties, in preparation for removing thedata
properties in a future major releasePatch Changes
Prevent "Did not find corresponding fetcher result" console error when navigating during a
fetcher.submit
revalidation (#14114)Bubble client-side middleware errors prior to
next
to the appropriate ancestor error boundary (#14138)Switch Lazy Route Discovery manifest URL generation to usea standalone
URLSearchParams
instance instead ofURL.searchParams
to avoid a major performance bottleneck in Chrome (#14084)Adjust internal RSC usage of
React.use
to avoid Webpack compilation errors when using React 18 (#14113)Remove dependency on
@types/node
in TypeScript declaration files (#14059)Fix types for
UIMatch
to reflect that theloaderData
/data
properties may beundefined
(#12206)ErrorBoundary
is being rendered, not all active matches will have loader data available, since it may have been theirloader
that threw to trigger the boundaryUIMatch.data
type was not correctly handing this and would always reflect the presence of data, leading to the unexpected runtime errors when anErrorBoundary
was renderedmatch.data
accesses - you should properly guard forundefined
values in those scenarios.[UNSTABLE] Ensure resource route errors go through
handleError
w/middleware enabled (#14078)[UNSTABLE] Propagate returned Response from server middleware if next wasn't called (#14093)
[UNSTABLE] Allow server middlewares to return
data()
values which will be converted into aResponse
(#14093)[UNSTABLE] Update middleware error handling so that the
next
function never throws and instead handles any middleware errors at the properErrorBoundary
and returns theResponse
up through the ancestornext
function (#14118)[UNSTABLE] When middleware is enabled, make the
context
parameter read-only (viaReadonly<unstable_RouterContextProvider>
) so that TypeScript will not allow you to write arbitrary fields to it in loaders, actions, or middleware. (#14097)[UNSTABLE] Rename and alter the signature/functionality of the
unstable_respond
API instaticHandler.query
/staticHandler.queryRoute
(#14103)unstable_generateMiddlewareResponse
for clarityunstable_respond
and handing you the result, we now pass aquery
/queryRoute
function as a parameter and you execute the loaders/actions inside your callback, giving you full access to pre-processing and error handlingquery
version of the API now has a signature of(query: (r: Request) => Promise<StaticHandlerContext | Response>) => Promise<Response>
queryRoute
version of the API now has a signature of(queryRoute: (r: Request) => Promise<Response>) => Promise<Response>
query
and direct error handling of errors thrown from querystaticHandler
unstable_respond
API[UNSTABLE] Convert internal middleware implementations to use the new
unstable_generateMiddlewareResponse
API (#14103)[UNSTABLE] Change
getLoadContext
signature (type GetLoadContextFunction
) whenfuture.unstable_middleware
is enabled so that it returns anunstable_RouterContextProvider
instance instead of aMap
used to contruct the instance internally (#14097)type unstable_InitialContext
exportgetLoadContext
function[UNSTABLE] Run client middleware on client navigations even if no loaders exist (#14106)
[UNSTABLE] Change the
unstable_getContext
signature onRouterProvider
/HydratedRouter
/unstable_RSCHydratedRouter
so that it returns anunstable_RouterContextProvider
instance instead of aMap
used to contruct the instance internally (#14097)unstable_getContext
prop[UNSTABLE] proxy server action side-effect redirects from actions for document and callServer requests (#14131)
[UNSTABLE] Fix RSC Data Mode issue where routes that return
false
fromshouldRevalidate
would be replaced by an<Outlet />
(#14071)v7.7.1
Compare Source
Patch Changes
shouldRevalidate
returned false (#14026)Matched leaf route at location "/..." does not have an element or Component
warnings when error boundaries are rendered. (#14021)v7.7.0
Compare Source
Minor Changes
Add unstable RSC support (#13700)
For more information, see the RSC documentation.
Patch Changes
Handle
InvalidCharacterError
when validating cookie signature (#13847)Pass a copy of
searchParams
to thesetSearchParams
callback function to avoid muations of the internalsearchParams
instance. This was an issue when navigations were blocked because the internal instance be out of sync withuseLocation().search
. (#12784)Support invalid
Date
inturbo-stream
v2 fork (#13684)In Framework Mode, clear critical CSS in development after initial render (#13872)
Strip search parameters from
patchRoutesOnNavigation
path
param for fetcher calls (#13911)Skip scroll restoration on useRevalidator() calls because they're not new locations (#13671)
Support unencoded UTF-8 routes in prerender config with
ssr
set tofalse
(#13699)Do not throw if the url hash is not a valid URI component (#13247)
Fix a regression in
createRoutesStub
introduced with the middleware feature. (#13946)As part of that work we altered the signature to align with the new middleware APIs without making it backwards compatible with the prior
AppLoadContext
API. This permittedcreateRoutesStub
to work if you were opting into middleware and the updatedcontext
typings, but brokecreateRoutesStub
for users not yet opting into middleware.We've reverted this change and re-implemented it in such a way that both sets of users can leverage it.
createRoutesStub
with the updated API.Remove
Content-Length
header from Single Fetch responses (#13902)v7.6.3
Compare Source
Patch Changes
Do not serialize types for
useRouteLoaderData<typeof clientLoader>
(#13752)For types to distinguish a
clientLoader
from aserverLoader
, you MUST annotateclientLoader
args:v7.6.2
Compare Source
Patch Changes
with-props
chunk in Framework Mode by moving route module component prop logic from the Vite plugin toreact-router
(#13650)headers()
function processing for use with RSC (#13639)v7.6.1
Compare Source
Patch Changes
Update
Route.MetaArgs
to reflect thatdata
can be potentiallyundefined
(#13563)This is primarily for cases where a route
loader
threw an error to it's ownErrorBoundary
. but it also arises in the case of a 404 which renders the rootErrorBoundary
/meta
but the root loader did not run because not routes matched.Partially revert optimization added in
7.1.4
to reduce calls tomatchRoutes
because it surfaced other issues (#13562)Fix typegen when same route is used at multiple paths (#13574)
For example,
routes/route.tsx
is used at 4 different paths here:Previously, typegen would arbitrarily pick one of these paths to be the "winner" and generate types for the route module based on that path.
Now, typegen creates unions as necessary for alternate paths for the same route file.
Better types for
params
(#13543)For example:
Previously,
params
for theroutes/layout.tsx
route were calculated as{ p: string, l: string }
.This incorrectly ignores params that could come from child routes.
If visiting
/parent/1/layout/2/child1/3/4
, the actual params passed toroutes/layout.tsx
will have a type of{ p: string, l: string, c1a: string, c1b: string }
.Now,
params
are aware of child routes and autocompletion will include child params as optionals:You can also narrow the types for
params
as it is implemented as a normalized union of params for each page that includesroutes/layout.tsx
:UNSTABLE: renamed internal
react-router/route-module
export toreact-router/internal
UNSTABLE: removed
Info
export from generated+types/*
filesAvoid initial fetcher execution 404 error when Lazy Route Discovery is interrupted by a navigation (#13564)
href replaces splats
*
(#13593)v7.6.0
Compare Source
Minor Changes
Added a new
react-router.config.ts
routeDiscovery
option to configure Lazy Route Discovery behavior. (#13451)/__manifest
path:routeDiscovery: { mode: "lazy", manifestPath: "/__manifest" }
routeDiscovery: { mode: "lazy", manifestPath: "/custom-manifest" }
routeDiscovery: { mode: "initial" }
Add support for route component props in
createRoutesStub
. This allows you to unit test your route components using the props instead of the hooks: (#13528)Patch Changes
Fix
react-router
module augmentation forNodeNext
(#13498)Don't bundle
react-router
inreact-router/dom
CJS export (#13497)Fix bug where a submitting
fetcher
would get stuck in aloading
state if a revalidatingloader
redirected (#12873)Fix hydration error if a server
loader
returnedundefined
(#13496)Fix initial load 404 scenarios in data mode (#13500)
Stabilize
useRevalidator
'srevalidate
function (#13542)Preserve status code if a
clientAction
throws adata()
result in framework mode (#13522)Be defensive against leading double slashes in paths to avoid
Invalid URL
errors from the URL constructor (#13510)new URL("//", window.location.origin)
Remove
Navigator
declaration fornavigator.connection.saveData
to avoid messing with any other types beyondsaveData
in userland (#13512)Fix
handleError
params
values on.data
requests for routes with a dynamic param as the last URL segment (#13481)Don't trigger an
ErrorBoundary
UI before the reload when we detect a manifest verison mismatch in Lazy Route Discovery (#13480)Inline
turbo-stream@2.4.1
dependency and fix decoding ordering of Map/Set instances (#13518)Only render dev warnings in DEV mode (#13461)
UNSTABLE: Fix a few bugs with error bubbling in middleware use-cases (#13538)
Short circuit post-processing on aborted
dataStrategy
requests (#13521)Cannot read properties of undefined (reading 'result')
v7.5.3
Compare Source
Patch Changes
loaderData
being cleared at the handlingErrorBoundary
route (#13476)clientLoader.hydrate
initial load executions (#13477)v7.5.2
Compare Source
Patch Changes
Update Single Fetch to also handle the 204 redirects used in
?_data
requests in Remix v2 (#13364).data
requests from outside the scope of React Router (i.e., anexpress
/hono
middleware)Adjust approach for Prerendering/SPA Mode via headers (#13453)
v7.5.1
Compare Source
Patch Changes
Fix single fetch bug where no revalidation request would be made when navigating upwards to a reused parent route (#13253)
When using the object-based
route.lazy
API, theHydrateFallback
andhydrateFallbackElement
properties are now skipped when lazy loading routes after hydration. (#13376)If you move the code for these properties into a separate file, you can use this optimization to avoid downloading unused hydration code. For example:
Properly revalidate prerendered paths when param values change (#13380)
UNSTABLE: Add a new
unstable_runClientMiddleware
argument todataStrategy
to enable middleware execution in customdataStrategy
implementations (#13395)UNSTABLE: Add better error messaging when
getLoadContext
is not updated to return aMap
" (#13242)Do not automatically add
null
tostaticHandler.query()
context.loaderData
if routes do not have loaders (#13223)undefined
from loaders, our prior check ofloaderData[routeId] !== undefined
was no longer sufficient and was changed to arouteId in loaderData
check - thesenull
values can cause issues for this new checkcreateStaticHandler()
/<StaticRouterProvider>
, and usingcontext.loaderData
to control<RouterProvider>
hydration behavior on the clientFix prerendering when a loader returns a redirect (#13365)
UNSTABLE: Update context type for
LoaderFunctionArgs
/ActionFunctionArgs
when middleware is enabled (#13381)Add support for the new
unstable_shouldCallHandler
/unstable_shouldRevalidateArgs
APIs indataStrategy
(#13253)v7.5.0
Compare Source
Minor Changes
Add granular object-based API for
route.lazy
to support lazy loading of individual route properties, for example: (#13294)Breaking change for
route.unstable_lazyMiddleware
consumersThe
route.unstable_lazyMiddleware
property is no longer supported. If you want to lazily load middleware, you must use the new object-basedroute.lazy
API withroute.lazy.unstable_middleware
, for example:Patch Changes
unstable_subResourceIntegrity
future flag that enables generation of an importmap with integrity for the scripts that will be loaded by the browser. (#13163)v7.4.1
Compare Source
Patch Changes
Fix types on
unstable_MiddlewareFunction
to avoid type errors when a middleware doesn't return a value (#13311)Dedupe calls to
route.lazy
functions (#13260)Add support for
route.unstable_lazyMiddleware
function to allow lazy loading of middleware logic. (#13210)Breaking change for
unstable_middleware
consumersThe
route.unstable_middleware
property is no longer supported in the return value fromroute.lazy
. If you want to lazily load middleware, you must useroute.unstable_lazyMiddleware
.v7.4.0
Compare Source
Patch Changes
shouldRevalidate
behavior forclientLoader
-only routes inssr:true
apps (#13221)RequestHandler
loadContext
parameter type when middleware is enabled (#13204)Route.unstable_MiddlewareFunction
to have a return value ofResponse | undefined
instead ofResponse | void
becaue you should not return anything if you aren't returning theResponse
(#13199)next()
and are no longer leaking theMiddlewareError
implementation detail (#13180)v7.3.0
Compare Source
Minor Changes
fetcherKey
as a parameter topatchRoutesOnNavigation
(#13061)fetcher
calls to undiscovered routes, this mismatch will trigger a document reload of the current pathPatch Changes
Skip resource route flow in dev server in SPA mode (#13113)
Support middleware on routes (unstable) (#12941)
Middleware is implemented behind a
future.unstable_middleware
flag. To enable, you must enable the flag and the types in yourreact-router-config.ts
file:clientMiddleware
that we will be addressing this before a stable release.context
parameter passed to yourloader
/action
functions - see below for more information.Once enabled, routes can define an array of middleware functions that will run sequentially before route handlers run. These functions accept the same parameters as
loader
/action
plus an additionalnext
parameter to run the remaining data pipeline. This allows middlewares to perform logic before and after handlers execute.Here's a simple example of a client-side logging middleware that can be placed on the root route:
Note that in the above example, the
next
/middleware
functions don't return anything. This is by design as on the client there is no "response" to send over the network like there would be for middlewares running on the server. The data is all handled behind the scenes by the statefulrouter
.For a server-side middleware, the
next
function will return the HTTPResponse
that React Router will be sending across the wire, thus giving you a chance to make changes as needed. You may throw a new response to short circuit and respond immediately, or you may return a new or altered response to override the default returned bynext()
.You can throw a
redirect
from a middleware to short circuit any remaining processing:Note that in cases like this where you don't need to do any post-processing you don't need to call the
next
function or return aResponse
.Here's another example of using a server middleware to detect 404s and check the CMS for a redirect:
context
parameterWhen middleware is enabled, your application will use a different type of
context
parameter in your loaders and actions to provide better type safety. Instead ofAppLoadContext
,context
will now be an instance ofContextProvider
that you can use with type-safe contexts (similar toReact.createContext
):If you are using a custom server with a
getLoadContext
function, the return value for initial context values passed from the server adapter layer is no longer an object and should now return anunstable_InitialContext
(Map<RouterContext, unknown>
):Fix types for loaderData and actionData that contained
Record
s (#13139)UNSTABLE(BREAKING):
unstable_SerializesTo
added a way to register custom serialization types in Single Fetch for other library and framework authors like Apollo.It was implemented with branded type whose branded property that was made optional so that casting arbitrary values was easy:
However, this broke type inference in
loaderData
andactionData
for anyRecord
types as those would now (incorrectly) matchunstable_SerializesTo
.This affected all users, not just those that depended on
unstable_SerializesTo
.To fix this, the branded property of
unstable_SerializesTo
is marked as required instead of optional.For library and framework authors using
unstable_SerializesTo
, you may need to addas unknown
casts before casting tounstable_SerializesTo
.Fix single fetch
_root.data
requests when abasename
is used (#12898)Add
context
support to client side data routers (unstable) (#12941)Your application
loader
andaction
functions on the client will now receive acontext
parameter. This is an instance ofunstable_RouterContextProvider
that you use with type-safe contexts (similar toReact.createContext
) and is most useful with the correspondingmiddleware
/clientMiddleware
API's:Similar to server-side requests, a fresh
context
will be created per navigation (orfetcher
call). If you have initial data you'd like to populate in the context for every request, you can provide anunstable_getContext
function at the root of your app:createBrowserRouter(routes, { unstable_getContext })
<HydratedRouter unstable_getContext>
This function should return an value of type
unstable_InitialContext
which is aMap<unstable_RouterContext, unknown>
of context's and initial values:v7.2.0
Compare Source
Minor Changes
New type-safe
href
utility that guarantees links point to actual paths in your app (#13012)Patch Changes
Fix typegen for repeated params (#13012)
In React Router, path parameters are keyed by their name.
So for a path pattern like
/a/:id/b/:id?/c/:id
, the last:id
will set the value forid
inuseParams
and theparams
prop.For example,
/a/1/b/2/c/3
will result in the value{ id: 3 }
at runtime.Previously, generated types for params incorrectly modeled repeated params with an array.
So
/a/1/b/2/c/3
generated a type like{ id: [1,2,3] }
.To be consistent with runtime behavior, the generated types now correctly model the "last one wins" semantics of path parameters.
So
/a/1/b/2/c/3
now generates a type like{ id: 3 }
.Don't apply Single Fetch revalidation de-optimization when in SPA mode since there is no server HTTP request (#12948)
Properly handle revalidations to across a prerender/SPA boundary (#13021)
.data
requests if the path wasn't pre-rendered because the request will 404loader
data inssr:false
mode is static because it's generated at build timeclientLoader
to do anything dynamicloader
and not aclientLoader
, we disable revalidation by default because there is no new data to retrieveConfiguration
📅 Schedule: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined).
🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.
♻ Rebasing: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox.
🔕 Ignore: Close this PR and you won't be reminded about these updates again.
This PR was generated by Mend Renovate. View the repository job log.