title | description |
---|---|
Migration guide to v2 |
How to update your code to use nuqs@2.0.0 |
It may seem weird to drop support for a single patch version, and keep it for older versions, but this is due to a bug in shallow routing in Next.js 14.0.3 that was fixed in 14.0.4, and that became hard to work around without ugly hacks as Next.js releases evolved.
See #423 for context and a table of supported versions.
nuqs@2.0.0
is now an ESM-only
package. This should not be much of an issue since
Next.js supports ESM in app code since version 12, but if you are bundling
nuqs
code into an intermediate CJS library to be consumed in Next.js,
you'll run into import issues:
[ERR_REQUIRE_ESM]: require() of ES Module not supported
If converting your library to ESM is not possible, your main option is to
dynamically import nuqs
:
const { useQueryState } = await import('nuqs')
Some of the v1 API was marked as deprecated back in September 2023, and has been
removed in nuqs@2.0.0
.
The queryTypes
object has been removed in favor of individual parser exports,
for better tree-shaking.
Replace with parseAsXYZ
to match:
- import { queryTypes } from 'nuqs'
+ import { parseAsString, parseAsInteger, ... } from 'nuqs'
- useQueryState('q', queryTypes.string.withOptions({ ... }))
- useQueryState('page', queryTypes.integer.withDefault(1))
+ useQueryState('q', parseAsString.withOptions({ ... }))
+ useQueryState('page', parseAsInteger.withDefault(1))
Next.js 14.1.0 makes useSearchParams
reactive to shallow search params updates,
which makes this internal helper function redundant. See #425 for context.
When introducing the server cache in #387, the dedicated export for parsers was
reused as it didn't include the "use client"
directive. Since it now contains
more than parsers and probably will be extended with server-only code in the future,
it has been renamed to a clearer export name.
Find and replace all occurrences of nuqs/parsers
to nuqs/server
in your code:
- import { parseAsInteger, createSearchParamsCache } from 'nuqs/parsers'
+ import { parseAsInteger, createSearchParamsCache } from 'nuqs/server'
After the rename to nuqs
, the debugging printout detection logic handled either
next-usequerystate
or nuqs
being present in the localStorage.debug
variable.
nuqs@2.0.0
only checks for the presence of the nuqs
substring to enable logs.
Update your local dev environments to match by running this once in the devtools console:
if (localStorage.debug) {
localStorage.debug = localStorage.debug.replace('next-usequerystate', 'nuqs')
}