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

@import rule is now deprecated. Migrate to @use and @forward #7031

Closed
justinbhopper opened this issue Oct 28, 2024 · 5 comments · Fixed by #7074 · May be fixed by #7157
Closed

@import rule is now deprecated. Migrate to @use and @forward #7031

justinbhopper opened this issue Oct 28, 2024 · 5 comments · Fixed by #7074 · May be fixed by #7157

Comments

@justinbhopper
Copy link
Contributor

justinbhopper commented Oct 28, 2024

Sass 1.80.0 has recently deprecated the @import rule, causing warnings to appear during compile. Now might be a good time to migrate blueprint's scss to @use and @forward rules, which have been supported since v1.23.0 (2019). Support for @import will be removed entirely in 2 years.

No doubt migration is non-trivial, but I believe the changes necessary are:

  1. For any @import occurring for the purpose of importing variables, mixins, or functions, use @use instead. Multiple files may need to be imported using @use, since Sass only includes variables that were defined in the file directly imported. The variables/functions will be available via a namespace, although it is possible to import them as global for an even easier migration.
  2. For any @import occurring for the purpose of including the contents of another file (e.g. as seen in core/src/blueprint.scss), use @forward instead.

They provide a migration tool, although I have not tried it so I cannot speak on it.

@justinbhopper
Copy link
Contributor Author

@adidahiya I'd like to contribute a PR in the future for this.

Would this be welcome, or would your team prefer this be done under the scope of something larger in the future roadmap?

@jscheiny
Copy link
Contributor

jscheiny commented Nov 5, 2024

Thanks for flagging this issue. We'd be open to a contribution for this change.

@ggdouglas
Copy link
Contributor

Hey @justinbhopper, we generally consider @blueprintjs/core/lib/scss/variables to be our public Sass API. Could you clarify which SCSS files you are consuming that are leading to these deprecation warnings? This will help us ensure proper alignment with our public API usage. Appreciate your insight!

@justinbhopper
Copy link
Contributor Author

@ggdouglas Sure, its my pleasure!

Regarding the public API: I believe these warnings would occur when importing @blueprintjs/core/lib/scss/variables with SASS 1.80.0, because variables.scss is using the @import rule to import other scss files.

Currently, our team is consuming core/src/blueprint.scss so that we can customize the colors/theme of Blueprint. It's my understanding this is not officially supported public API, but a large portion of the community is also doing this for similar reasons. I believe it's the only way to achieve color customization, and Blueprint has done a good job so far with unofficially supporting the practice.

Here is some extra info:

  1. When BlueprintJS upgrades to SASS 1.80.0 (currently, using 1.70.0), deprecation warnings will occur in BlueprintJS' internal SASS compile.
  2. BlueprintJS would not be able to upgrade to SASS v3.0 when it releases in a few years unless it migrates to using @use and @forward.
  3. Migrating to @use and @forward now will allow the community to continue to import the scss files. We can expect a larger percentage of the public community to begin this migration now that deprecation warnings are occurring.

@ggdouglas
Copy link
Contributor

@justinbhopper Thanks for the clarification—that makes sense. We're looking to formalize this customization process in future releases, but for now, I'm okay with migrating the syntax here as long as it doesn’t break current Blueprint consumers. 👍

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
3 participants