libelektra
libelektra copied to clipboard
build(deps): bump react-router-dom from 4.3.1 to 6.4.1 in /src/tools/webui
Bumps react-router-dom from 4.3.1 to 6.4.1.
Release notes
Sourced from react-router-dom's releases.
[email protected]
Patch Changes
fix: remove internal router singleton (#9227)
This change removes the internal module-level
routerSingletonwe create and maintain inside our data routers since it was causing a number of headaches for non-simple use cases:
- Unit tests are a pain because you need to find a way to reset the singleton in-between tests
- Use use a
_resetModuleScopesingleton for our tests- ...but this isn't exposed to users who may want to do their own tests around our router
- The JSX children
<Route>objects cause non-intuitive behavior based on idiomatic react expectations
- Conditional runtime
<Route>'s won't get picked up- Adding new
<Route>'s during local dev won't get picked up during HMR- Using external state in your elements doesn't work as one might expect (see #9225)
Instead, we are going to lift the singleton out into user-land, so that they create the router singleton and manage it outside the react tree - which is what react 18 is encouraging with
useSyncExternalStoreanyways! This also means that since users create the router - there's no longer any difference in the rendering aspect for memory/browser/hash routers (which only impacts router/history creation) - so we can get rid of those and trim to a simpleRouterProvider// Before function App() { <DataBrowserRouter> <Route path="/" element={<Layout />}> <Route index element={<Home />}> </Route> <DataBrowserRouter> }// After let router = createBrowserRouter([{ path: "/", element: <Layout />, children: [{ index: true, element: <Home />, }] }]);
function App() { return <RouterProvider router={router} /> }
If folks still prefer the JSX notation, they can leverage
createRoutesFromElements(aliased fromcreateRoutesFromChildrensince they are not "children" in this usage):let routes = createRoutesFromElements( <Route path="/" element={<Layout />}> <Route index element={<Home />}> </Route> );
... (truncated)
Changelog
Sourced from react-router-dom's changelog.
6.4.1
Patch Changes
- Updated dependencies:
[email protected]@remix-run/[email protected]6.4.0
Whoa this is a big one!
6.4.0brings all the data loading and mutation APIs over from Remix. Here's a quick high level overview, but it's recommended you go check out the docs, especially the feature overview and the tutorial.New APIs
- Create your router with
createMemoryRouter/createBrowserRouter/createHashRouter- Render your router with
<RouterProvider>- Load data with a Route
loaderand mutate with a Routeaction- Handle errors with Route
errorElement- Submit data with the new
<Form>component- Perform in-page data loads and mutations with
useFetcher()- Defer non-critical data with
deferandAwait- Manage scroll position with
<ScrollRestoration>New Features
- Perform path-relative navigations with
<Link relative="path">(#9160)Bug Fixes
- Path resolution is now trailing slash agnostic (#8861)
useLocationreturns the scoped location inside a<Routes location>component (#9094)- respect the
<Link replace>prop if it is defined (#8779)Updated Dependencies
Commits
d405320chore: update versions for releasec4a27f7chore: Update version for release (pre) (#9316)aeceb7dfix changeset config + update changelogsc430329fix: properly handle?indexon fetchergetsubmissions (#9312)8b00e7afix: preserve state from initialEntries (#9288)e20a6f7fix: [Bug]: react-router-dom does not list dependency@remix-run/router(#924...87851fbchore: Update version for release (#9239)ab0da65chore: addenginesfield topackage.json(#8951)e3d4596chore: Update version for release (pre) (#9229)c17512dfix: Remove the internal router singleton (#9227)- Additional commits viewable in compare view
Dependabot will resolve any conflicts with this PR as long as you don't alter it yourself. You can also trigger a rebase manually by commenting @dependabot rebase.
Dependabot commands and options
You can trigger Dependabot actions by commenting on this PR:
@dependabot rebasewill rebase this PR@dependabot recreatewill recreate this PR, overwriting any edits that have been made to it@dependabot mergewill merge this PR after your CI passes on it@dependabot squash and mergewill squash and merge this PR after your CI passes on it@dependabot cancel mergewill cancel a previously requested merge and block automerging@dependabot reopenwill reopen this PR if it is closed@dependabot closewill close this PR and stop Dependabot recreating it. You can achieve the same result by closing it manually@dependabot ignore this major versionwill close this PR and stop Dependabot creating any more for this major version (unless you reopen the PR or upgrade to it yourself)@dependabot ignore this minor versionwill close this PR and stop Dependabot creating any more for this minor version (unless you reopen the PR or upgrade to it yourself)@dependabot ignore this dependencywill close this PR and stop Dependabot creating any more for this dependency (unless you reopen the PR or upgrade to it yourself)