Medusa React: v4.0.2
Version 4.0.2 of Medusa React introduces a new update in its dependencies which can lead to breaking changes.
Overview
Medusa React previously required installing React Query v3 as a peer dependency. This version changes the peer dependency requirement to Tanstack Query - the updated version of React Query.
This requires additional actions related to installing the new dependency and changing imports.
Actions Required
Update Medusa Dependencies
To update to the latest version of Medusa React, run the following command in your custom storefront or admin to update both Medusa React and the core package:
- npm
- Yarn
npm install medusa-react@latest @medusajs/medusa@latest
yarn add medusa-react@latest @medusajs/medusa@latest
Uninstall React Query v3
As React Query v3 is not required as a peer dependency anymore, uninstall it from your custom storefront or admin:
- npm
- Yarn
npm uninstall react-query
yarn remove react-query
Install Tanstack Query
Run the following command to install Tanstack Query:
- npm
- Yarn
npm install @tanstack/react-query
yarn add @tanstack/react-query
Update Imports
Across your custom storefront or admin project, change all imports from react-query
to @tanstack/react-query
.
For example, update the import for QueryClient
where you use it with Medusa Provider:
import { QueryClient } from "@tanstack/react-query"
// this remains the same
const queryClient = new QueryClient()
Fix No QueryClient set Errors
If you're using a Next.js storefront, you might face the following error after this update when you run your storefront:
No QueryClient set
This is due to an issue related to Tanstack Query shipping esm
modules in its latest versions and how Next.js uses Webpack.
Although in future versions of medusa-react
this issue will be fixed, you can add the following into next.config.js
to fix this error:
const path = require("path")
/** @type {import('next').NextConfig} */
const nextConfig = {
// ... other configs
webpack: (config, options) => {
if (options.isServer) {
config.externals = ["@tanstack/react-query", ...config.externals]
}
const reactQuery = path.resolve(
require.resolve("@tanstack/react-query")
)
config.resolve.alias["@tanstack/react-query"] = reactQuery
return config
},
}
module.exports = nextConfig