From eee82b132a8487f7a1852f75532486f699841384 Mon Sep 17 00:00:00 2001
From: Ankur Datta <64993082+ankur-arch@users.noreply.github.com>
Date: Fri, 2 Aug 2024 18:09:42 +0545
Subject: [PATCH] feat: add troubleshooting section for nuxt prisma module
(#6172)
---
.../900-prisma-nuxt-module.mdx | 59 +++++++++++++++++++
1 file changed, 59 insertions(+)
diff --git a/content/200-orm/800-more/600-help-and-troubleshooting/100-help-articles/900-prisma-nuxt-module.mdx b/content/200-orm/800-more/600-help-and-troubleshooting/100-help-articles/900-prisma-nuxt-module.mdx
index 491addf406..0820bdae57 100644
--- a/content/200-orm/800-more/600-help-and-troubleshooting/100-help-articles/900-prisma-nuxt-module.mdx
+++ b/content/200-orm/800-more/600-help-and-troubleshooting/100-help-articles/900-prisma-nuxt-module.mdx
@@ -31,6 +31,12 @@ This module provides several features to streamline the setup and usage of Prism
cd test-nuxt-app
npx nuxi@latest module add @prisma/nuxt
```
+
+ :::warning
+
+ If you're using `pnpm`, make sure to hoist Prisma dependencies. Follow the steps [here](/orm/more/help-and-troubleshooting/help-articles/prisma-nuxt-module#prisma-studio-not-opening-with-pnpm) for detailed instructions.
+
+ :::
3. Start the development server:
```terminal
@@ -234,6 +240,12 @@ export default prisma
if (process.env.NODE_ENV !== 'production') globalThis.prismaGlobal = prisma
```
+
+:::info
+
+Use the `prisma` instance from the `lib` folder if you want to leverage a client using [Prisma Client extensions](/orm/prisma-client/client-extensions).
+
+:::
#### Using the global Prisma Client instance in your API route
@@ -297,3 +309,50 @@ The `usePrismaClient` module does not currently allow for configuration of `Pris
### The `usePrismaClient` composable is not supported in edge runtimes
The `usePrismaClient` composable currently relies on a `PrismaClient` instance that does not work in edge runtimes. If you require edge support for the composable, please let us know on [Discord](https://pris.ly/discord) or [GitHub](https://github.com/prisma/nuxt-prisma).
+
+## Troubleshooting
+
+### Prisma Studio not opening with `pnpm`
+
+If you're encountering the following error when using `pnpm` and Prisma Studio isn't opening:
+
+```terminal
+Uncaught SyntaxError: The requested module '/_nuxt/node_modules/.pnpm/*@*/node_modules/@prisma/client/index-browser.js?v=' does not provide an export named 'PrismaClient' (at plugin.mjs?v=*)
+```
+
+To resolve this issue, create a `.npmrc` file in your project root and add the following configuration to hoist Prisma dependencies:
+
+```.npmrc file=.npmrc
+hoist-pattern[]=*prisma*
+```
+
+This will ensure that Prisma dependencies are properly resolved by `pnpm`.
+
+### Resolving `TypeError: Failed to resolve module specifier ".prisma/client/index-browser"`
+
+If you encounter the following error message in the browser console after building and previewing your application:
+
+```
+TypeError: Failed to resolve module specifier ".prisma/client/index-browser"
+```
+To resolve this issue, add the following configuration to your nuxt.config.ts file:
+
+```ts file=nuxt.config.ts
+import { defineNuxtConfig } from 'nuxt'
+
+export default defineNuxtConfig({
+ modules: [
+ '@prisma/nuxt',
+ ],
+ // additional config
+ vite: {
+ resolve: {
+ alias: {
+ '.prisma/client/index-browser': './node_modules/.prisma/client/index-browser.js',
+ },
+ },
+ },
+})
+```
+
+This configuration ensures that the module specifier is correctly mapped to the appropriate file.
\ No newline at end of file