Releases: molefrog/wouter
v2.10.1: Bugfixes
This release fixes missing export error caused by incorrect import of useInsertionEffect hook in React <18. See #292
Thanks to @hudochenkov!
Other changes:
- Rollup plugin is no longer listed as dependency, #301
v2.10.0: `useSyncExternalStore`
In this alpha release, we're migrating useLocation hook to useSyncExternalStore under the hood (the new API for subscribing to external state sources compatible for concurrent mode).
This hook is available in React 18, for all earlier versions we've included a shim. We've also done some heavy refactoring which should lead to better performance and new features such as:
- useSearchexported from- wouter/use-locationfor subscribing to- location.search
- useLocationPropertyfor subscribing to arbitrary location updates.
- Standalone navigatewith stable reference and no dependency on current location, which means that your components that only perform navigation won't have unnecessary re-renders.
import { useSearch, useLocationProperty, navigate } from 'wouter/use-location';
// get all search params:
const search = useSearch();
// set all search params:
navigate("?name=john");
// get individual search param (will not trigger a re-render if other params change! 🎉 )
const nameValue = useLocationProperty(() => new URLSearchParams(window.location.search).get("name"));
// set individual search param:
const params = new URLSearchParams(window.location.search);
params.set("name", "john");
navigate("?" + params.toString()); Thanks @HansBrende for their contribution.
v2.9.1: Type fixes
- TypeScript declarations now include proper types for parentprop inRouter, #270
v2.8.1: TypeScript Improvements
- When route parameters can be inferred from the path, they now have a type of { readonly [k in string]: string | undefined }. This takes into account optional segments that can beundefined#262, thanks @HansBrende
- Proper typings of Routechildren: it does not allow mixing render props and other elements together #263, thanks @HansBrende
- Switchnow has less strict type of its children to allow conditional rendering and avoid confusion 8f943ab
v2.8.0: It's been a while
- Feature: Route parameters are now automatically inferred in TypeScript. @itsMapleLeaf via #211
- Feature: Linkcomponent will now forward ref to the underlyingaelement of custom component provided by user. @trymoto via #259
- Optimization: use useStateinstead ofuseReffor values that must be initialized only once. @HelKyle via #252 and #251
- Bugfix: Prevent Link navigation when event was cancelled. @Tomas2D via #239
🇺🇦 We stand with Ukraine
Donate or spread the world to help Ukrainian soldiers and refugees
Bug fixes & code size optimizations
- Fix a bug with a Switchnot being able to process falsy children @jacobbuck via #212
- Code size optimizations @cbbfcd via #191 and #186
Bugfixes
v2.7.3
v2.7.0: React 17 support and absolute routes within a subpath
We're continuing to improve the library by keeping it small and simple, thanks to our wonderful contributors. First of all, it's the React 17 support: I'm sure many of you have already upgraded your project to the new version of React, which apparently "has no new features". Wouter now has proper peerDependencies that allow you to use it with React 17 thanks to @omgovich!
Another important update is that it's now possible to access the routes outside of the base scope when using a base parameter:
<Router base="/app">
  <Link href="/relative">Relative Link</Link>
  {/* 
      by prexing a path with tilda, you can reference a global route: when you click on this link 
      it navigates you to "/absolute", and not "/app/absolute" 
   */}
  <Link href="~/absolute">Absolute Link</Link>
</Router>Maintenance release
This patch release contains a few important bug-fixes:
- baseparameter in- Routeris now case-insensitive. Thanks @Veranete @cbbfcd via #138
- Fixed a "func.apply is not a function" error when using a custom matcher. @cbbfcd via #137
- The list of eventsis now exported from theuse-location.jsmodule. @o-alexandrov via #129
Happy wouting!