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

feat(css): allow specifying stopDir for postcss config resolution #11390

Closed
wants to merge 1 commit into from

Conversation

rexxars
Copy link
Contributor

@rexxars rexxars commented Dec 15, 2022

Description

postcss-load-config has a behavior where it will find any postcss.config.js (or other supported postcss configuration formats) recursively from the current directory to the home directory of the user.

As of Sanity Studio v3, we're using Vite to power the development experience, and we are seeing quite a large number of reports from people who get an error such as this one upon starting the studio:

[plugin:vite:css] [postcss] Cannot read properties of undefined (reading 'config')
    at getTailwindConfig (/Users/adamsmith/Desktop/codingprojects/portfolio/node_modules/tailwindcss/lib/lib/setupTrackingContext.js:84:63)
    at /Users/adamsmith/Desktop/codingprojects/portfolio/node_modules/tailwindcss/lib/lib/setupTrackingContext.js:96:92
    at /Users/adamsmith/Desktop/codingprojects/portfolio/node_modules/tailwindcss/lib/processTailwindFeatures.js:46:11
    at plugins (/Users/adamsmith/Desktop/codingprojects/portfolio/node_modules/tailwindcss/lib/index.js:38:63)
    ...

This is caused by the user having a postcss configuration file in a parent folder, which while technically speaking is a documented behavior, is not easy to understand or discover for the user.

We are wanting to disable this behavior for our users, instead requiring a postcss configuration to reside inside of the project folder. This can be done by passing a stopDir option to cosmicconfig (technically speaking, lilconfig), which is used by postcss-load-config in order to find the configuration file in vite.

This PR introduces a new option to the CSS options of vite, resolveOptions, which currently only accepts the stopDir option (the other options did not quite make sense to me in the context of vite on first look, so I decided to limit it for now).

Open to other suggestions for how to solve this.


What is the purpose of this pull request?

  • Bug fix
  • New Feature
  • Documentation update
  • Other

Before submitting the PR, please make sure you do the following

  • Read the Contributing Guidelines.
  • Read the Pull Request Guidelines and follow the PR Title Convention.
  • Check that there isn't already a PR that solves the problem the same way to avoid creating a duplicate.
  • Provide a description in this PR that addresses what the PR is solving, or reference the issue that it solves (e.g. fixes #123).
  • Ideally, include relevant tests that fail without this PR but pass with it.

@MrBartusek
Copy link

I've just stumbled upon this issue and it's annoying. Why an postcss config file that is in the home directory can affect the build process of projects that don't have one? I don't think that anybody would want for anything outside the project root to be able to influence the build process. This just produces wired issues like this one. I think this newly proposed stopDir should actually stop on the project root by default.

There is a quick workaround in the vite config file to disable this behaviour, if anyone stumbles on this issue:

export default defineConfig({
  css: {
    postcss: {} // Disable Post CSS
  }
})

@erfanimani
Copy link

I've just come across this and it was very confusing to figure out. On my local I use Docker and only mount the subdirectory so the issue didn't appear there. However, the entire repo is pushed to Vercel, which would cause the error:

Error: Cannot find module 'postcss-import'

This was for a brand new Sanity.io Studio project, which made it even more strange.

@rexxars rexxars force-pushed the feat/postcss-stop-dir branch from a31a240 to a3c76d3 Compare April 16, 2024 17:34
@sapphi-red
Copy link
Member

Closing as #18440 was merged. It will be released in Vite 6. Thanks for the PR 🙏

@sapphi-red sapphi-red closed this Oct 30, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
p2-to-be-discussed Enhancement under consideration (priority)
Projects
Archived in project
Development

Successfully merging this pull request may close these issues.

5 participants