4.7. Admin Development Tips
In this chapter, you'll find some tips for developing your admin.
Send Requests to API Routes#
To send a request to an API route in the Medusa Application, use Medusa's JS SDK with Tanstack Query. Both of these tools are installed in your project by default.
v5.64.2 as a development dependency.First, create the file src/admin/lib/sdk.ts to set up the SDK for use in your customizations:
Notice that in a Medusa project, you use import.meta.env to access environment variables in your customizations, whereas in a plugin you use the global variable __BACKEND_URL__ to access the backend URL. You can learn more in the Admin Environment Variables chapter.
Then, use the configured SDK with the useQuery Tanstack Query hook to send GET requests, and the useMutation hook to send POST or DELETE requests.
For example:
You can also send requests to custom routes, as explained in the JS SDK reference.
Use Route Loaders for Initial Data#
You may need to retrieve data before your component is rendered, or you may need to pass some initial data to your component to be used while data is being fetched. In those cases, you can use a route loader.
Troubleshooting#
No QueryClient set
If you're using pnpm as a package manager in your Medusa application, you might face the following error when you try to access the admin dashboard:
This is a known issue when using pnpm. To fix it, you need to install the @tanstack/react-query package manually. Make sure to install the same version installed in @medusajs/dashboard.
Learn more in the Errors with pnpm troubleshooting guide.
Global Variables in Admin Customizations#
In your admin customizations, you can use the following global variables:
- __BASE__: The base path of the Medusa Admin, as set in the admin.path configuration in- medusa-config.ts.
- __BACKEND_URL__: The URL to the Medusa backend, as set in the admin.backendUrl configuration in- medusa-config.ts.
- __STOREFRONT_URL__: The URL to the storefront, as set in the admin.storefrontUrl configuration in- medusa-config.ts.
If you get type errors while using these variables, create the file src/admin/vite-env.d.ts with the following content:
Admin Translations#
The Medusa Admin dashboard can be displayed in languages other than English, which is the default. Other languages are added through community contributions.
Learn how to add a new language translation for the Medusa Admin in this guide.


