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

Next 15 update throws deprecation warning in console using sass #71638

Open
pierre-isb opened this issue Oct 22, 2024 · 22 comments · May be fixed by #72423
Open

Next 15 update throws deprecation warning in console using sass #71638

pierre-isb opened this issue Oct 22, 2024 · 22 comments · May be fixed by #72423
Labels
bug Issue was opened via the bug report template. linear: next Confirmed issue that is tracked by the Next.js team.

Comments

@pierre-isb
Copy link

Link to the code that reproduces this issue

https://codesandbox.io/p/devbox/dark-architecture-go8s7s

To Reproduce

  1. install sass (yarn add -D sass)
  2. import styles from a SCSS module file
  3. Update Next to v15.0.0

Current vs. Expected behavior

A deprecation warning appears from sass : "Deprecation The legacy JS API is deprecated and will be removed in Dart Sass 2.0.0".
Is the deprecation related to a Next.js deprecated use of .scss modules that will be fixed ? Or does that mean that scss modules is deprecated in Next.js ?

Provide environment information

Operating System:
 Platform: macOS
 Version: 14.7
Binaries:
 Node: 22.10.0
 yarn: 1.22.19
Packages:
 next: 15.0.0
 sass: 1.80.1
Next.js Config:
 reactStrictMode: true,
 images: {
  unoptimized: true
 }

Which area(s) are affected? (Select all that apply)

Not sure

Which stage(s) are affected? (Select all that apply)

next dev (local)

Additional context

No response

@pierre-isb pierre-isb added the bug Issue was opened via the bug report template. label Oct 22, 2024
@pierre-isb pierre-isb changed the title Next 15 update deprecation warning using sass Next 15 update throws deprecation warning in console using sass Oct 22, 2024
@jadenv
Copy link

jadenv commented Oct 22, 2024

We started getting this warning today too when trying out Next 15.

Looks like PR #70067 updated sass-loader to a version that is new enough to throw the deprecation warning, but didn't fully upgrade to v16 that would default to the modern Sass JS API.

I believe next updating sass-loader to v16+ would fix this. Our projects seem to work fine locally with the modern-compiler option turned on.

@Netail
Copy link
Contributor

Netail commented Oct 22, 2024

The SASS team even mentioned this already themself; #67931

@alfarodarwaynejay
Copy link

Hello, is there any way to just suppress the warning for the meantime?

@pierre-isb
Copy link
Author

@alfarodarwaynejay I believe you can use next config if you want to silence these warnings :

const nextConfig: NextConfig = {
  sassOptions: {
    silenceDeprecations: ['legacy-js-api'],
  }
}

cf. https://nextjs.org/docs/app/building-your-application/styling/sass and https://sass-lang.com/documentation/breaking-changes/legacy-js-api/#silencing-warnings

tr1s added a commit to tr1s/trisanity that referenced this issue Oct 23, 2024
@voltuer

This comment was marked as spam.

@JosipPardon

This comment was marked as off-topic.

@controversial
Copy link
Contributor

@JosipPardon This is unrelated to this issue

@emdagon

This comment was marked as off-topic.

@github-actions github-actions bot added the linear: next Confirmed issue that is tracked by the Next.js team. label Oct 28, 2024
@controversial
Copy link
Contributor

@emdagon That article is also about an unrelated deprecation

This issue is about Next’s webpack config loading the “legacy JS API” instead of the “modern JS API”

@feedthejim
Copy link
Contributor

Hey, thanks for opening the issue. I'm considering:

  • introducing an experimental option to use the upgraded sass
  • silence the warning

We won't be able to upgrade it by default since it would require yet another major. Does that sound like a good compromise?

@Eigilak
Copy link

Eigilak commented Nov 4, 2024

Yeaaah buddy

@tr1s
Copy link

tr1s commented Nov 4, 2024

@feedthejim what are the implications of using an "experimental option to use the upgraded sass" vs "upgrade it by default"?

@controversial
Copy link
Contributor

@tr1s an experimental option will allow people to opt-in to the new Sass API, which may require users to update their sassOptions at the same time

Upgrading it by default would require everyone to update their sassOptions, and might break their builds before they do so—so “upgrade it by default” would be a breaking change that can only be made in a semver-major release

@pierre-isb
Copy link
Author

@feedthejim love the idea, thanks 🙏

@lmf-git

This comment was marked as spam.

@andreynovikov
Copy link

This is my temporary solution:

  1. Install sass-loader
  2. Modify next.config.js:
/**
 * Webpack config modification adopted from https://github.com/vercel/next.js/issues/11629
 */
const regexEqual = (x, y) => {
    return (
        x instanceof RegExp &&
        y instanceof RegExp &&
        x.source === y.source &&
        x.global === y.global &&
        x.ignoreCase === y.ignoreCase &&
        x.multiline === y.multiline
    )
}

module.exports = {
    webpack: config => {
        const oneOf = config.module.rules.find(
            rule => typeof rule.oneOf === 'object'
        )

        if (oneOf) {
            const sassRule = oneOf.oneOf.find(rule => regexEqual(rule.test, /\.module\.(scss|sass)$/))
            if (sassRule) {
                const sassLoader = sassRule.use.find(
                    el => el.loader.includes('next/dist/compiled/sass-loader')
                )
                if (sassLoader) {
                    sassLoader.loader = 'sass-loader'
                }
            }
        }

        return config
    }
}

Important! This is not compatible with Turbopack, I'm not using it.

@wslp12
Copy link

wslp12 commented Nov 12, 2024

This is my temporary solution:

  1. Install sass-loader
  2. Modify next.config.js:
/**
 * Webpack config modification adopted from https://github.com/vercel/next.js/issues/11629
 */
const regexEqual = (x, y) => {
    return (
        x instanceof RegExp &&
        y instanceof RegExp &&
        x.source === y.source &&
        x.global === y.global &&
        x.ignoreCase === y.ignoreCase &&
        x.multiline === y.multiline
    )
}

module.exports = {
    webpack: config => {
        const oneOf = config.module.rules.find(
            rule => typeof rule.oneOf === 'object'
        )

        if (oneOf) {
            const sassRule = oneOf.oneOf.find(rule => regexEqual(rule.test, /\.module\.(scss|sass)$/))
            if (sassRule) {
                const sassLoader = sassRule.use.find(
                    el => el.loader.includes('next/dist/compiled/sass-loader')
                )
                if (sassLoader) {
                    sassLoader.loader = 'sass-loader'
                }
            }
        }

        return config
    }
}

Important! This is not compatible with Turbopack, I'm not using it.

thank but my case not work
sass options - prependData @use "src/styles/shome"; <- can't find stylesheet to import.

@Maclay74
Copy link

sass options - prependData @use "src/styles/shome"; <- can't find stylesheet to import.

I have the same problem, @import works, whereas @use throws this error using both Turbopack and webpack.

devjiwonchoi added a commit that referenced this issue Nov 14, 2024
### Why?

This PR silences `legacy-js-api` warning enabled from PR
#70067 by updating the
`sass-loader` to v15. Will follow up with adding an option to enable the
sass-loader v16 by PR #72423.

x-ref: #71638
jenfrani pushed a commit to jenfrani/FretboardVisualizer that referenced this issue Nov 15, 2024
@cheema-corellian

This comment was marked as off-topic.

jorins added a commit to jorins/jorin.se that referenced this issue Nov 24, 2024
@hormesiel
Copy link

@alfarodarwaynejay I believe you can use next config if you want to silence these warnings :

const nextConfig: NextConfig = {
  sassOptions: {
    silenceDeprecations: ['legacy-js-api'],
  }
}

cf. https://nextjs.org/docs/app/building-your-application/styling/sass and https://sass-lang.com/documentation/breaking-changes/legacy-js-api/#silencing-warnings

If, like me, you did this but the warnings keep getting printed out when running next dev, remove the .next directory and it'll fix it.

joonassandell added a commit to joonassandell/portfolio that referenced this issue Nov 28, 2024
- Fix and update types, especially for useParallax
- Use react compiler
- Use latest motion alpha which fixes some types regarding className
- Use turbopack in dev
- next.config.mjs -> next.config.ts and remove all mjs related "hacks"
- Silence sass legacy api errors

Related issues and sources
- https://nextjs.org/docs/app/api-reference/next-config-js/turbo
- vercel/next.js#71638
- vercel/turborepo#4832
- motiondivision/motion#2843
@andreynovikov
Copy link

I have installed sass-loader and created the following next.config: https://github.com/andreynovikov/galleria-js/blob/13db458e368757c68eca40bb3163f1354c3ffeb1/next.config.mjs#L39-L57

NriotHrreion added a commit to qzqzcsclub/journal-site that referenced this issue Nov 30, 2024
@devjiwonchoi
Copy link
Member

Hey everyone, thank you for waiting! Silencing the warning was added at PR #72632, and released to canary in v15.0.4-canary.12, and will be added to the next release!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Issue was opened via the bug report template. linear: next Confirmed issue that is tracked by the Next.js team.
Projects
None yet
Development

Successfully merging a pull request may close this issue.