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

[Compiler Bug]: eslint plugin erroneously flags third-party functions starting with "use" as hooks #32109

Open
1 of 4 tasks
ddolcimascolo opened this issue Jan 17, 2025 · 2 comments
Labels
Component: Optimizing Compiler Status: Unconfirmed A potential issue that we haven't yet confirmed as a bug Type: Bug

Comments

@ddolcimascolo
Copy link

What kind of issue is this?

  • React Compiler core (the JS output is incorrect, or your app works incorrectly after optimization)
  • babel-plugin-react-compiler (build issue installing or using the Babel plugin)
  • eslint-plugin-react-compiler (build issue installing or using the eslint plugin)
  • react-compiler-healthcheck (build issue installing or using the healthcheck script)

Link to repro

https://playground.react.dev/#N4Igzg9grgTgxgUxALhASwLYAcIwC4AEwBUYCAMgIYCe0eAogGaMJyEC+BjMEGBA5DASU2-ANwAdAHaYc+AgCoClMMowBhABaV8q7rwEABShjjbdAehNmdeMABYLcXAnHTpCAB5zCAEwSMlFAANoSMUFJsaBBSBACy1ACCWFgAFACURNIEJGRUtFAMzKx4qRkEALwAfFmxOWpatmAAdKQIACqaCBgIqVIhwemSdewANAQA2gC66e51QniwsanZ9QA8vmgAbgQWVauzUuzSIOxAA

Repro steps

In the simplified playground example above, I'm using amCharts.useTheme which is not a hook at all, just a random function of an external library that happen to start with use.

How often does this bug happen?

Every time

What version of React are you using?

react@19.0.0

What version of React Compiler are you using?

babel-plugin-react-compiler@19.0.0-beta-e552027-20250112

@ddolcimascolo ddolcimascolo added Component: Optimizing Compiler Status: Unconfirmed A potential issue that we haven't yet confirmed as a bug Type: Bug labels Jan 17, 2025
@ddolcimascolo
Copy link
Author

Workaround

function amChartsUseTheme(theme) {
  return amCharts.useTheme(theme);
}

@mofeiZ
Copy link
Contributor

mofeiZ commented Jan 17, 2025

Thanks for the report! Another workaround is const amChartsUseTheme = amCharts.useTheme (or amCharts.useTheme.bind(...)). We've seen a few other instances of this issue as well, but unfortunately there isn't a clean fix right now. An example of a fix would be typescript adopting Flow's component syntax to explicitly annotate component and hook types.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Component: Optimizing Compiler Status: Unconfirmed A potential issue that we haven't yet confirmed as a bug Type: Bug
Projects
None yet
Development

No branches or pull requests

2 participants