Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Prettier v3 peerDependency conflict with local installation of prettier #1388

Closed
equinusocio opened this issue Nov 14, 2024 · 4 comments · Fixed by #1389
Closed

Prettier v3 peerDependency conflict with local installation of prettier #1388

equinusocio opened this issue Nov 14, 2024 · 4 comments · Fixed by #1389
Labels
4.0 dependencies Pull requests that update a dependency file discuss

Comments

@equinusocio
Copy link

equinusocio commented Nov 14, 2024

We get this error after upgrading to 4.2. Reverting to 4.1 works as expected

Error [ERR_MODULE_NOT_FOUND]: Cannot find module '/Workspaces/ui/node_modules/.pnpm/[email protected][email protected]/node_modules/prettier/plugins/babel' imported from /Workspaces/ui/node_modules/.pnpm/[email protected][email protected]/node_modules/style-dictionary/lib/common/formats.js
at finalizeResolution (node:internal/modules/esm/resolve:264:11)
at moduleResolve (node:internal/modules/esm/resolve:917:10)
at defaultResolve (node:internal/modules/esm/resolve:1130:11)
at nextResolve (node:internal/modules/esm/hooks:865:28)
at resolveBase (file:///Workspaces/ui/node_modules/.pnpm/[email protected]/node_modules/tsx/dist/esm/index.mjs?1731584854185:2:3212)
resolveDirectory (file:///Workspaces/ui/node_modules/.pnpm/[email protected]/node_modules/tsx/dist/esm/index.mjs?1731584854185:2:3584)
resolveTsPaths (file:///Workspaces/ui/node_modules/.pnpm/[email protected]/node_modules/tsx/dist/esm/index.mjs?1731584854185:2:4073)
@jorenbroekema
Copy link
Collaborator

jorenbroekema commented Nov 14, 2024

Did you get any warnings when you installed dependencies about prettier not meeting the peer dependency requirements of style-dictionary, namely it being 2.8.8 and style-dictionary requires 3.0.0 or higher? I'm not sure how PNPM handles these but in NPM you would get a fatal error upon installation:

Screenshot 2024-11-14 at 13 32 28

To my knowledge this can only be fixed by migrating to Prettier v3

Running npm install --legacy-peer-deps will just ignore the peer dep and result in the error which you are now getting because then it resolves the prettier 3.x.x peer dep on the v2 installation and that's missing the babel plugin.
Same for --force flag.

NPM "overrides" also doesn't seem to work as expected, I would expect:

{
  "dependencies": {
    "prettier": "2.8.8",
    "style-dictionary": "^4.2.0"
  },
  "overrides": {
    "prettier": "^2.8.8",
    "style-dictionary": {
      "prettier": "$prettier"
     // $prettier means "take the version from style-dictionary's dependency on prettier". 
     //^3.0.0 also doesn't work. I guess overrides ignores peer deps... >.>
    }
  }
}

To install prettier v2 in the root node_modules and prettier v3 in node_modules/style-dictionary/node_modules which is what would happen if prettier was a regular dependency and not a peer dependency of style-dictionary, but NPM apparently disagrees with me. Doesn't seem like any filed a bug report for this yet....

I don't use PNPM so I don't know exactly how they resolve peer dependency conflicts, you'll have to do some research there and some npm ls prettier to figure out what will make PNPM install prettier v2 and v3 correctly. Or just migrate to Prettier v3 I suppose. Good luck!

@jorenbroekema jorenbroekema added discuss dependencies Pull requests that update a dependency file 4.0 labels Nov 14, 2024
@jorenbroekema jorenbroekema changed the title Module not found: [email protected][email protected] Prettier v3 peerDependency conflict with local installation of prettier Nov 14, 2024
@equinusocio
Copy link
Author

equinusocio commented Nov 15, 2024

Did you get any warnings when you installed dependencies about prettier not meeting the peer dependency requirements of style-dictionary, namely it being 2.8.8 and style-dictionary requires 3.0.0 or higher?

Nope, pnpm installs without errors or warnings with both SD 4.1 and 4.2.

@equinusocio
Copy link
Author

Any release ETA for this fix?

@jorenbroekema
Copy link
Collaborator

jorenbroekema commented Nov 20, 2024

I wanna get these into the release as well, probably end of this week / beginning of next week. All of these PRs are 95%+ done

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
4.0 dependencies Pull requests that update a dependency file discuss
Projects
None yet
Development

Successfully merging a pull request may close this issue.

2 participants