Multiple major react versions in a pnpm monorepo?
Answered
Southern rough shrimp posted this in #help-forum
data:image/s3,"s3://crabby-images/94e1a/94e1ac800d8a95184132dd36579f1c150df7a772" alt="Avatar"
Southern rough shrimpOP
I'd love to have one app using react19, and the other using react18. However when I try to build either of them, there's a clash of versions and my IDE doesn't like it. See screenshots
repro: https://github.com/pippinmole/pnpm-monorepo-major-reactversions/ @Rafael Almeida
repro: https://github.com/pippinmole/pnpm-monorepo-major-reactversions/ @Rafael Almeida
data:image/s3,"s3://crabby-images/5cc21/5cc21a081eefaa978ea3e1314419ce5ee667c95e" alt="Image"
Answered by Rafael Almeida
this is what I get trying to build it:
I am not sure this is related to TS or pnpm 🤔
> plasmo build --target=chrome-mv3
🟣 Plasmo v0.89.4
🔴 The Browser Extension Framework
🔵 INFO | Prepare to bundle the extension...
🔵 INFO | Building for target: chrome-mv3
🔵 INFO | Loaded environment variables from: []
(node:87004) [DEP0040] DeprecationWarning: The `punycode` module is deprecated. Please use a userland alternative instead.
(Use `node --trace-deprecation ...` to show where the warning was created)
Segmentation fault (core dumped)
ELIFECYCLE Command failed with exit code 139.
I am not sure this is related to TS or pnpm 🤔
12 Replies
data:image/s3,"s3://crabby-images/94e1a/94e1ac800d8a95184132dd36579f1c150df7a772" alt="Avatar"
Southern rough shrimpOP
You can see that if I delete the
web
application from apps/web
, and run pnpm install
again, then the error is gonedata:image/s3,"s3://crabby-images/a40c9/a40c996219aede79ab2b11c58f96b28f2dd0743b" alt="Image"
data:image/s3,"s3://crabby-images/8615e/8615e1d966803796422823887a53d25c80f131b0" alt="Avatar"
I think TS is is looking at the wrong definitions because of how pnpm handles the folders in a monorepo. try directly setting the react types path on
tsconfig.compilerOptions.paths
:"react": ["./node_modules/@types/react"],
this is what I have on tsconfig and it seems to work:
{
"extends": "plasmo/templates/tsconfig.base",
"exclude": [
"node_modules"
],
"include": [
".plasmo/index.d.ts",
"./**/*.ts",
"./**/*.tsx"
],
"compilerOptions": {
"paths": {
"react": ["./node_modules/@types/react"],
"@/*": ["./src/*"]
},
"baseUrl": "."
}
}
data:image/s3,"s3://crabby-images/8615e/8615e1d966803796422823887a53d25c80f131b0" alt="Avatar"
@Rafael Almeida this is what I have on tsconfig and it seems to work:
json
{
"extends": "plasmo/templates/tsconfig.base",
"exclude": [
"node_modules"
],
"include": [
".plasmo/index.d.ts",
"./**/*.ts",
"./**/*.tsx"
],
"compilerOptions": {
"paths": {
"react": ["./node_modules/@types/react"],
"@/*": ["./src/*"]
},
"baseUrl": "."
}
}
data:image/s3,"s3://crabby-images/94e1a/94e1ac800d8a95184132dd36579f1c150df7a772" alt="Avatar"
Southern rough shrimpOP
Just to clarify, was there typescript errors before you added that line in
Also I remember adding this and it didn’t seem to work
I even restarted the typescript server
data:image/s3,"s3://crabby-images/8615e/8615e1d966803796422823887a53d25c80f131b0" alt="Avatar"
yeah I saw some errors because of forwardRef on the Input component, I restarted the ts server after adding the line
data:image/s3,"s3://crabby-images/8615e/8615e1d966803796422823887a53d25c80f131b0" alt="Avatar"
@Rafael Almeida yeah I saw some errors because of forwardRef on the Input component, I restarted the ts server after adding the line
data:image/s3,"s3://crabby-images/94e1a/94e1ac800d8a95184132dd36579f1c150df7a772" alt="Avatar"
Southern rough shrimpOP
Interesting, that did solve the IDE issues
But also, try running
turbo run build --filter=chromeextension
Or even
turbo run build
data:image/s3,"s3://crabby-images/94e1a/94e1ac800d8a95184132dd36579f1c150df7a772" alt="Avatar"
@Southern rough shrimp But also, try running turbo run build --filter=chromeextension
data:image/s3,"s3://crabby-images/8615e/8615e1d966803796422823887a53d25c80f131b0" alt="Avatar"
this is what I get trying to build it:
I am not sure this is related to TS or pnpm 🤔
> plasmo build --target=chrome-mv3
🟣 Plasmo v0.89.4
🔴 The Browser Extension Framework
🔵 INFO | Prepare to bundle the extension...
🔵 INFO | Building for target: chrome-mv3
🔵 INFO | Loaded environment variables from: []
(node:87004) [DEP0040] DeprecationWarning: The `punycode` module is deprecated. Please use a userland alternative instead.
(Use `node --trace-deprecation ...` to show where the warning was created)
Segmentation fault (core dumped)
ELIFECYCLE Command failed with exit code 139.
I am not sure this is related to TS or pnpm 🤔
Answer
data:image/s3,"s3://crabby-images/94e1a/94e1ac800d8a95184132dd36579f1c150df7a772" alt="Avatar"
Southern rough shrimpOP
Closing as the issue has magically disappeared.