Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

@eslint-react/shared

Rel1cx779.9kMIT1.29.0TypeScript support: included

ESLint React's Shared constants and functions.

readme

logo

ESLint React

More than 80 high-quality linting rules for writing better React code.

Features

  • Modern: First-class support for TypeScript, React 19, polymorphic components.
  • Flexible: Increased flexibility with more granular severity control.
  • Performant: Built with performance in mind, optimized for large codebases.
  • Comprehensive: Handles complex scenarios and identifies problems that other tools might miss.

Public Packages

Modular

All-In-One

Installation

Install

npm install --save-dev typescript-eslint @eslint-react/eslint-plugin

Setup

// eslint.config.js

// @ts-check
import eslintJs from "@eslint/js";
import eslintReact from "@eslint-react/eslint-plugin";
import tseslint from "typescript-eslint";

export default tseslint.config({
  files: ["**/*.ts", "**/*.tsx"],
  extends: [
    eslintJs.configs.recommended,
    tseslint.configs.recommended,
    eslintReact.configs["recommended-typescript"],
  ],
  languageOptions: {
    parser: tseslint.parser,
    parserOptions: {
      projectService: true,
    },
  },
  rules: {
    // Put rules you want to override here
    "@eslint-react/prefer-shorthand-boolean": "warn",
  },
});

Full Installation Guide ↗

Presets

Bare Bones

  • Core (core)\ Enable rules for "react".
  • DOM (dom)\ Enable rules for "react-dom".
  • Web API (web-api)\ Enable rules for interacting with Web APIs.

General Purpose

  • Recommended (recommended)\ Enforce rules that are recommended by ESLint React for general purpose React + React DOM projects.\ This preset includes the core, dom, and web-api presets.

TypeScript Specialized

  • Recommended TypeScript (recommended-typescript)\ Same as the recommended preset but disables rules that can be enforced by TypeScript.

  • Recommended Type-Checked (recommended-type-checked)\ Same as the recommended-typescript preset but enables additional rules that require type information.

Full Presets List ↗

Rules

Rules Overview ↗

FAQ

Frequently Asked Questions ↗

Roadmap

Notable Projects Using ESLint React

used-by

Community ESLint Configs Adopting ESLint React

Data collected from GitHub dependents network, if there are any mismatch or outdated information, feel free to [open issue](https://github.com/Rel1cx/eslint-react/issues/new?assignees=&labels=type%3A+documentation&projects=&template=docsreport.md&title=%5Bdocs%5D+) or pull request._

Find more on GitHub Dependents.

Contributing

Please follow our contributing guidelines.

License

This project is licensed under the MIT License - see the LICENSE file for details.

Inspiration

changelog

v1.29.0 (2025-03-01)

✨ New

🐞 Fixes

🪄 Improvements

New Contributors

v1.28.0 (2025-02-26)

✨ New

🪄 Improvements

v1.27.0 (2025-02-21)

✨ New

🪄 Improvements

v1.26.2 (2025-02-06)

🐞 Fixes

v1.26.1 (2025-02-03)

No notable changes have been made in this release.

v1.26.0 (2025-01-31)

✨ New

v1.25.0 (2025-01-27)

✨ New

🐞 Fixes

🪄 Improvements

v1.24.1 (2025-01-22)

🐞 Fixes

v1.24.0 (2025-01-21)

🪄 Improvements

  • perf: overhaul performance optimizations

v1.23.2 (2025-01-07)

✨ New

  • feat(plugins/x): add auto-fix to prefer-shorthand-fragment, closes #898 (#902)

v1.23.1 (2025-01-03)

🐞 Fixes

v1.23.0 (2024-12-31)

🪄 Improvements

  • refactor: JSX fragments related rules no longer rely on jsxPragma and jsxPragmaFrag settings to perform their checks by @Rel1cx in https://github.com/Rel1cx/eslint-react/pull/893
  • refactor: improve applicability of the no-useless-fragment and prefer-shorthand-fragment rules
  • refactor: deprecate settings["react-x"].jsxPragma and settings["react-x"].jsxPragmaFrag as they are no longer needed by any rules
  • refactor: replace short-unique-id w/ uid by @SukkaW in https://github.com/Rel1cx/eslint-react/pull/894

🐞 Fixes

v1.22.2 (2024-12-30)

🪄 Improvements

v1.22.1 (2024-12-24)

🪄 Improvements

  • docs: add getting started guides for JavaScript, TypeScript, and JavaScript with Babel
  • docs: improve code samples in rules docs
  • docs: improve eslint.config.js examples in README.md, docs and the examples folder
  • docs: improve the error message and description of various rules
  • refactor(website): better website layout and navigation experience

📝 Changes in examples

The eslint.config.js in the examples now uses tsconfig's includes and excludes as the SSoT glob patterns for ESLint's files and ignores fields.

This approach can fundamentally avoid the errors[1, 2, 3] caused by mismatched config scopes between tsconfig.json and eslint.config.js when using type-checked rules.

v1.22.0 (2024-12-22)

🪄 Improvements

  • refactor(plugins/x): rename jsx-use-vars to use-jsx-vars
  • refactor(plugins/x): rename jsx-no-duplicate-props to no-duplicate-jsx-props
  • refactor(plugins/dom): rename no-children-in-void-dom-elements to no-void-elements-with-children

📝 Changes you should be aware of

The following rules have been renamed:

  • jsx-uses-vars to use-jsx-vars
  • jsx-no-duplicate-props to no-duplicate-jsx-props
  • dom/no-children-in-void-dom-elements to dom/no-void-elements-with-children

The new rule names are aligned with the same rules in the biomejs/rules-sources/#eslint-plugin-react (if any) to enhance consistency. The old rule names will still be available until the next major update to avoid breaking changes.

v1.21.0 (2024-12-20)

✨ New

  • feat(plugins/hooks-extra): add no-useless-custom-hooks rule by @Rel1cx

🪄 Improvements

  • refactor(plugins/hooks-extra): deprecate rule no-redundant-custom-hook in favor of no-useless-custom-hooks (the previous rule will still be available until the next major update to avoid breaking changes)

📝 Changes in Rule implementation

no-useless-custom-hooks now detects Hook calls within comments and the following code no longer triggers a warning:

// ✅ Good: A Hook that will likely use some other Hooks later
function useAuth() {
  // TODO: Replace with this line when authentication is implemented:
  // return useContext(Auth);
  return TEST_USER;
}

v1.20.1 (2024-12-18)

🪄 Improvements

v1.20.0 (2024-12-16)

✨ New

🪄 Improvements

New Contributors

v1.19.0 (2024-12-10)

✨ New

  • feat(plugins/x): add no-context-provider rule by @Rel1cx
  • feat(plugins/x): add autofix for no-forward-ref rule by @Rel1cx in https://github.com/Rel1cx/eslint-react/pull/874
  • feat(plugins/eslint-plugin): add no-forward-ref and no-context-provider to recommended presets by @Rel1cx

🪄 Improvements

v1.18.0 (2024-12-08)

✨ New

🪄 Improvements

  • perf(plugins/dom): improve performance of no-void-elements-with-children by @Rel1cx

v1.17.3 (2024-12-03)

🐞 Fixes

🪄 Improvements

  • Update @typescript-eslint's packages to ^8.17.0

v1.17.2 (2024-12-01)

🪄 Improvements

  • Update eslint's packages to ^9.16.0
  • Update @typescript-eslint's packages to ^8.16.0
  • Update ts-api-utils to ^2.0.0

v1.17.1 (2024-11-22)

✨ New

  • feat(shared): add version detection logic;

🐞 Fixes

v1.17.0 (2024-11-21)

✨ New

  • feat(plugins/naming-convention): add 'ignoreFilesWithoutCode' option to 'filename-extension'

🐞 Fixes

  • refactor(plugins/x): xhtml entities should be allowed inside of 'no-useless-fragment', closes: #850
  • fix(plugins/eslint-plugin): unexpected top-level property 'name' in legacy presets, closes #863
  • fix(plugins/eslint-plugin): rules list in 'debug' and 'disable-debug' presets

v1.16.2 (2024-11-20)

🐞 Fixes

🪄 Improvements

v1.16.1 (2024-11-10)

✨ New

🪄 Improvements

v1.16.0 (2024-11-01)

✨ New

  • feat(plugins/react-x): add jsx-uses-vars, closes #834 by @Rel1cx in https://github.com/Rel1cx/eslint-react/pull/845
  • feat(plugins/react-dom): add no-unknown-property, closes #846 by @Rel1cx
  • feat: add recommended-typescript and recommended-typescript-legacy presets by @Rel1cx

🪄 Improvements

  • Update @typescript-eslint's packages to ^8.12.2

v1.15.2 (2024-10-29)

🪄 Improvements

  • Update @typescript-eslint's packages to ^8.12.1

v1.15.1 (2024-10-26)

✨ New

  • feat: added code fixer to react-x/avoid-shorthand-boolean and react-x/prefer-shorthand-fragment by @Rel1cx

🐞 Fixes

v1.15.0 (2024-10-12)

✨ New

🐞 Fixes

  • fix: Fix false positives when 'web-api/no-leaked-event-listener' passes a signal to an intermediate variable, closes #838

🪄 Improvements

New Contributors

Full Changelog: https://github.com/Rel1cx/eslint-react/compare/v1.14.3...v1.15.0

v1.14.3 (2024-09-29)

🪄 Improvements

  • Update @typescript-eslint's packages to ^8.7.0

v1.14.2 (2024-09-20)

🪄 Improvements

  • Update @typescript-eslint's packages to ^8.6.0

v1.14.1 (2024-09-12)

🐞 Fixes

  • Fixed false positives in rule web-api/no-leaked-resize-observer

v1.14.0 (2024-09-10)

🐞 Fixes

  • Fixed modular plugins missing default export
  • Fixed component name detection when the component name starts with a underscore

🪄 Improvements

  • Update @typescript-eslint's packages to ^8.5.0

v1.13.1 (2024-09-09)

🐞 Fixes

  • Fixed hooks-extra/no-unnecessary-use-callback and hooks-extra/no-unnecessary-use-memo false positives when there are references from nested scopes

v1.13.0 (2024-09-04)

✨ New

  • Added web-api/no-leaked-resize-observer rule to prevent leaked ResizeObserver

🐞 Fixes

  • hooks-extra/no-redundant-custom-hook should allow custom Hooks with empty body

🪄 Improvements

  • Rename debug/react-hooks to debug/hook
  • Rename hooks-extra/ensure-custom-using-hooks to hooks-extra/no-redundant-custom-hook
  • Rename hooks-extra/ensure-use-memo-has-non-empty-deps to hooks-extra/no-unnecessary-use-memo
  • Rename hooks-extra/ensure-use-callback-has-non-empty-deps to hooks-extra/no-unnecessary-use-callback
  • Upgrade @typescript-eslint's packages to ^8.4.0

(The rules that were renamed in this release will still be available until the next major update to avoid breaking changes.)

v1.12.4 (2024-08-31)

✨ New

  • Added useLayoutEffect and useInsertionEffect support to hooks-extra/no-direct-set-state-in-use-effect

🪄 Improvements

  • Deprecate rule hooks-extra/no-direct-set-state-in-use-layout-effect in favor of hooks-extra/no-direct-set-state-in-use-effect (the previous rule will still be available until the next major update to avoid breaking changes)

v1.12.3 (2024-08-29)

✨ New

  • Added support for detecting event listeners removed by abort signal in rule web-api/no-leaked-event-listener

🐞 Fixes

  • Fixed no-duplicate-key rule false positives when the key is a variable
  • Fixed web-api/no-leaked-set-timeout and web-api/no-leaked-set-interval false positives when a timer is assigned to a variable declared by let but not initialized

v1.12.3 (2024-08-29)

✨ New

  • Added support for detecting event listeners removed by abort signal in rule web-api/no-leaked-event-listener

🐞 Fixes

  • Fixed no-duplicate-key rule false positives when the key is an variable
  • Fixed web-api/no-leaked-set-timeout and web-api/no-leaked-set-interval false positives when a timer is assigned to a variable declared by let but not initialized

🪄 Improvements

  • Allow upper case letters in the rule naming-convention/component-name when the component name is less than 4 characters, e.g. UI, CSS, SVG

v1.12.2 (2024-08-27)

✨ New

  • Added type declarations for react-x settings to the @typescript-eslint/utils/ts-eslint module via the SharedConfigurationSettings interface

🪄 Improvements

  • Improve the performance of the no-missing-key and no-duplicate-key rules
  • Upgrade @typescript-eslint's packages to ^8.3.0

v1.12.1 (2024-08-22)

✨ New

  • Add the options allowAllCaps, allowNamespace, allowLeadingUnderscore to naming-convention/component-name and set their default values to false

🪄 Improvements

  • Normalize the component name in rule naming-convention/component-name before checking it against the pattern

v1.12.0 (2024-08-21)

✨ New

  • Added hooks-extra rules to recommended and recommended-legacy presets

v1.11.0 (2024-08-20)

✨ New

  • Added eslint-plugin-react-web-api - A plugin that provides rules for interacting with Web APIs in React applications
  • Added web-api/no-leaked-timeout rule to prevent leaked setTimeout
  • Added web-api/no-leaked-interval rule to prevent leaked setInterval
  • Added web-api/no-leaked-event-listener rule to prevent leaked addEventListener
  • Added web-api and web-api-legacy presets to enable all rules provided by eslint-plugin-react-web-api
  • Added react-web-api/no-leaked-event-listener to recommended and recommended-legacy presets

🪄 Improvements

  • Improve performance by skipping unnecessary checks when possible
  • Improve dts generation of the @eslint-react/eslint-plugin package
  • Improve website and documentation
  • Upgrade @typescript-eslint's packages to ^8.2.0

v1.10.1 (2024-08-13)

🐞 Fixes

  • Fixed hooks-extra/prefer-use-state-lazy-initialization false positive when using an initializer function

🪄 Improvements

  • Improve rule no-implicit-key error marker position and range
  • Upgrade @typescript-eslint's packages to ^8.1.0
  • Improve website and documentation

v1.10.0 (2024-08-11)

✨ New

  • Added disable-type-checked and disable-type-checked-legacy presets to disable all type-checked rules

🪄 Improvements

  • Rename off-dom and off-dom-legacy presets to disable-dom and disable-dom-legacy (the old names will still be available until the next major update to avoid breaking changes)

v1.9.1 (2024-08-08)

🐞 Fixes

  • Fixed dom/no-missing-iframe-sandbox false positive when the sandbox attribute is set to sandbox=""
  • Fixed all and all-legacy presets not including hooks-extra rules

v1.9.0 (2024-08-06)

✨ New

  • Add core preset that includes the most essential rules

🪄 Improvements

  • Upgrade @typescript-eslint's packages to 8.0.1

v1.8.2 (2024-08-03)

🐞 Fixes

  • Fixed legacy presets not being exported correctly in @eslint-react/eslint-plugin

v1.8.1 (2024-08-03)

🪄 Improvements

  • Enhance rule hooks-extra/no-direct-set-state-in-use-effect and hooks-extra/no-direct-set-state-in-use-layout-effect to support set function directly passed to useCallback and useMemo without explicitly calling it
  • Improve website and documentation

v1.8.0 (2024-08-02)

🐞 Fixes

  • Fixed ESLintReactSettings type not being exported correctly
  • Fixed the set function calls that are wrapped in a useMemo or useCallback like hook not being detected by hooks-extra/no-direct-set-state-in-use-effect and hooks-extra/no-direct-set-state-in-use-layout-effect

🪄 Improvements

  • Upgrade @typescript-eslint's packages to 8.0.0
  • Improve website and documentation

v1.7.1 (2024-07-31)

🐞 Fixes

  • Fixed the spread attributes support for dom related rules
  • Fixed the issue where the overridden value was retrieved when there were duplicate attributes on a JSX element

🪄 Improvements

  • Rule no-leaked-conditional-rendering now allows a falsy boolean literal to be used on the left side of the logical expression
  • Tweaked the default settings shipped with various presets
  • Overall performance improvements

v1.7.0 (2024-07-30)

✨ New

  • Add settings["react-x"].polymorphicPropName setting to specify the name of the prop that is used to determine the component type

🪄 Improvements

  • Dropped the current incomplete lint support for React.createElement to improve performance and subsequent code maintainability

v1.6.0 (2024-07-27)

✨ New

  • Add controlled setting to settings["react-x"].additionalComponents' attributes object to set whether it is controlled or not
  • Add glob support to settings["react-x"].additionalComponents' name setting
  • Add default settings for react-x settings to presets
  • Undeprecate rule no-implicit-key and improve its usefulness
  • Undeprecate rule no-complicated-conditional-rendering and rename it to no-complex-conditional-rendering (the previous rule will still be available until the next major update to avoid breaking changes)

🐞 Fixes

  • no-direct-set-state-in-use-(layout?)-effect should warn only for the set function

🪄 Improvements

  • Remove no-direct-set-state-in-use-(layout?)-effect from recommended presets

v1.5.30 (2024-07-22)

🐞 Fixes

  • Revert change @typescript-eslint's packages in dependencies to "^7.16.1 || ^rc-v8" as this format is not supported by all package managers

v1.5.29 (2024-07-22)

✨ New

  • Add rule no-prop-types
  • Add rule no-default-props
  • Add experimental settings["react-x"].additionalComponents settings (currently only the no-unsafe-target-blank rule uses it, but more rules will use it in the future)

🪄 Improvements

  • Add rule no-prop-types to recommended presets
  • Add rule no-default-props to recommended presets
  • Remove rule no-useless-fragment from recommended presets
  • Optimize performance of rule no-create-ref
  • Change @typescript-eslint' packages in dependencies to "^7.16.1 || ^rc-v8"

v1.5.28 (2024-07-20)

🐞 Fixes

  • Fix false positives and negatives in rule hooks-extra/no-direct-set-state-in-use-effect
  • Fix false positives and negatives in rule hooks-extra/no-direct-set-state-in-use-layout-effect
  • Fix rule prefer-read-only-props reports only the first component in a file

🪄 Improvements

  • Improve website and documentation

v1.5.27 (2024-07-16)

🐞 Fixes

  • Fix rule prefer-read-only-props that was accidentally added to the recommended type-checked presets
  • Fix false negatives in rule hooks-extra/no-direct-set-state-in-use-effect when call set function inside a non-function scope
  • Fix false negatives in rule hooks-extra/no-direct-set-state-in-use-layout-effect when call set function inside a non-function scope

🪄 Improvements

  • Rule no-leaked-conditional-rendering now supports BigInt literals on the left side of the logical expression
  • Rule no-leaked-conditional-rendering now allows a truthy number literal to be used on the left side of the logical expression
  • Optimize bundle size

v1.5.26 (2024-07-15)

✨ New

  • Add rule hooks-extra/no-direct-set-state-in-use-effect
  • Add rule hooks-extra/no-direct-set-state-in-use-layout-effect

🐞 Fixes

  • Fix false positives in rule hooks-extra/ensure-use-memo-has-non-empty-deps when referencing component block scope
  • Fix false positives in rule hooks-extra/no-unnecessary-use-callback when referencing component block scope

🪄 Improvements

  • Add rule hooks-extra/no-direct-set-state-in-use-effect to recommended presets
  • Add rule hooks-extra/no-direct-set-state-in-use-layout-effect to recommended presets
  • Add rule hooks-extra/prefer-use-state-lazy-initialization to recommended presets

v1.5.25 (2024-07-13)

🪄 Improvements

  • Optimize bundle size

v1.5.24 (2024-07-11)

🐞 Fixes

  • Fix rule prefer-read-only-props false positive when using ObjectPattern in function arguments

🪄 Improvements

  • Change typescript version in peerDependencies to "^4.9.5 || ^5.3.3"

v1.5.23 (2024-07-07)

🐞 Fixes

  • Fix rule prefer-read-only-props false negative when using ObjectPattern in function arguments

🪄 Improvements

  • Improve website and documentation

v1.5.22 (2024-07-05)

✨ New

  • Add rule prefer-read-only-props

🪄 Improvements

  • Downgrade @typescript-eslint's packages to v7, due to stability issues with v8

v1.5.21 (2024-07-03)

🐞 Fixes

  • Add missing dependencies to @eslint-react/eslint-plugin
  • Fix rule no-nested-components false negative when placing components inside JSX props

🪄 Improvements

  • Update @typescript-eslint's packages to v8
  • Improve rule no-leaked-conditional-rendering compatibility with different versions of typescript-eslint

v1.5.20 (2024-07-02)

🐞 Fixes

  • Fix rule prefer-destructuring-assignment false positive when the function looks like a component

🪄 Improvements

  • Improve utilities/jsx/is-jsx-value to better distinguish between normal values and JSX values
  • Improve core/component-collector to better distinguish between normal functions and components
  • Prevent potential function component detection related false positives
  • Switch to a more appropriate value for DEFAULT_COMPONENT_HINT

v1.5.19 (30 Sun Jun 2024)

🪄 Improvements

  • Reduce the number of dependencies by inlining tree-shaking optimized code while bundling
  • Deprecate reactOptions in favor of react-x in ESLint Shared Settings

v1.5.18 (28 Fri Jun 2024)

🐞 Fixes

  • Fix rule no-useless-fragment not respecting jsxPragma settings

🪄 Improvements

  • Update documentation for rule no-useless-fragment to reflect the actual behavior of the rule

v1.5.17 (2024-06-26)

🪄 Improvements

  • Remove rule no-children-prop from recommended presets
  • Improve documentation for rule no-useless-fragment

v1.5.16 (2024-06-17)

🐞 Fixes

  • Fix debug rules not exporting correctly in @eslint-react/eslint-plugin

🪄 Improvements

  • Remove rule prefer-shorthand-boolean from recommended presets
  • Remove rule prefer-shorthand-fragment from recommended presets
  • Remove rule prefer-destructuring-assignment from recommended presets

v1.5.15 (2024-06-08)

🐞 Fixes

  • Remove languageOptions.parser from presets
  • Remove @typescript-eslint/parser from peer dependencies
  • Rule no-leaked-conditional-rendering: object should be considered as valid left-hand type

v1.5.14 (2024-05-30)

✨ New

  • Add rule avoid-shorthand-boolean
  • Add rule avoid-shorthand-fragment

🐞 Fixes

  • Fix rule dom/no-missing-button-type false positive when using type attribute in a JSX expression

v1.5.13 (2024-05-28)

🐞 Fixes

  • Fix components that use getDerivedStateFromError should not be warned by rule no-class-component

🪄 Improvements

  • Update @typescript-eslint's packages to 7.11.0

v1.5.12 (2024-05-17)

🐞 Fixes

  • Fix ESLint peer dependency range in package.json

🪄 Improvements

  • Update @typescript-eslint's packages to 7.9.0
  • Minor improvements

v1.5.11 (2024-05-08)

✨ New

  • Rule no-class-component rule now allows class components with a componentDidCatch method
  • Settings reactOptions now supports importSource to specify the import source for React

🗑️ Deprecations

  • Deprecate rule no-implicit-key because it is stylistic and opinionated
  • Deprecate rule no-complicated-conditional-rendering because it is stylistic and opinionated

🪄 Improvements

  • Refactor React pragma and import name retrieval utils to support custom import source
  • Update @typescript-eslint's packages to 7.8.0

v1.5.10 (2024-04-28)

🪄 Improvements

  • Update react to 18.3.1
  • Update @typescript-eslint's packages to 7.7.1
  • Use a wider range of peerDependencies

v1.5.9 (2024-04-19)

🪄 Improvements

  • Optimize error messages of rules
  • Update @typescript-eslint's packages to 7.7.0

v1.5.8 (2024-04-11)

🪄 Improvements

  • Update @typescript-eslint's packages to 7.6.0

v1.5.7 (2024-03-28)

🪄 Improvements

  • Update @typescript-eslint's packages to 7.4.0

v1.5.6 (2024-03-12)

🪄 Improvements

  • Update @typescript-eslint's packages to 7.2.0

v1.5.5 (2024-02-18)

🐞 Fixes

  • Fix rule no-component-will-receive-props not working as expected

🪄 Improvements

  • Improve error messages and code samples in rule docs

v1.5.4 (2024-02-16)

🐞 Fixes

  • Fix rule dom/no-render-return-value not renamed in v1.0.0

🪄 Improvements

  • Improve code samples in rule docs
  • Update effect to 2.3.5
  • Update @typescript-eslint's packages to 7.0.1

v1.5.3 (2024-02-10)

🪄 Improvements

  • Improve diagnostic messages
  • Remove needless deps from peerDependencies
  • Update @typescript-eslint's packages to 6.21.0

v1.5.2 (2024-01-31)

🪄 Improvements

  • Remove needless deps from peerDependencies
  • Update @typescript-eslint's packages to 6.20.0
  • Update effect to 2.2.3

v1.5.2-beta.2 (2024-01-31)

🪄 Improvements

  • Update effect to 2.2.3
  • Remove needless deps from peerDependencies

v1.5.2-beta.0 (2024-01-30)

🪄 Improvements

  • Update @typescript-eslint's packages to 6.20.0

v1.5.1 (2024-01-29)

✨ New

  • Add off-dom and off-dom-legacy presets to disable all DOM related rules

🪄 Improvements

  • Reduce dependencies size

v1.5.0 (2024-01-29)

💥 Breaking Changes

  • Remove rule max-depth
  • Rename rule no-spreading-key to no-implicit-key
  • Rename rule no-constructed-context-value to no-unstable-context-value
  • Rename rule no-unstable-nested-components to no-nested-components
  • Switch to new name prefix of rules in @eslint-react/eslint-plugin
    • Replace jsx/ with in rule names
    • Replace react/ with in rule names
    • Replace react-dom/ with dom/ in rule names
    • Replace react-hooks/ with hooks-extra/ in rule names
  • Switch to new settings schema
    • Put settings under reactOptions instead of eslintReact
    • Replace jsx.pragma with jsxPragma
    • Replace jsx.fragment with jsxPragmaFrag
    • Replace react.version with version
    • Remove jsx.extensions

v1.0.2 (2024-01-27)

🐞 Fixes

  • Fix rule react-dom/no-namespace not renamed in v1.0.0
  • Fix rule react-dom/no-void-elements-with-children not renamed in v1.0.0

🪄 Improvements

  • Improve rules overview page on website
  • Remove jsx and hooks presets from documentation

v1.0.1 (2024-01-27)

🪄 Improvements

  • Improve jsx and jsx-legacy presets
  • Improve core and core-legacy presets
  • Improve recommended and recommended-legacy presets
  • Improve recommended-type-checked and recommended-type-checked-legacy presets

v1.0.0 (2024-01-27)

💥 Breaking Changes

  • Rename rule react/no-void-elements-with-children to react-dom/no-void-elements-with-children
  • Rename rule react/no-dangerously-set-innerhtml-with-children to react-dom/no-dangerously-set-innerhtml-with-children
  • Rename rule react/no-dangerously-set-innerhtml to react-dom/no-dangerously-set-innerhtml
  • Rename rule react/no-find-dom-node to react-dom/no-find-dom-node
  • Rename rule react/no-missing-button-type to react-dom/no-missing-button-type
  • Rename rule react/no-missing-iframe-sandbox to react-dom/no-missing-iframe-sandbox
  • Rename rule react/no-namespace to react-dom/no-namespace
  • Rename rule react/no-render-return-value to react-dom/no-render-return-value
  • Rename rule react/no-script-url to react-dom/no-script-url
  • Rename rule react/no-unsafe-iframe-sandbox to react-dom/no-unsafe-iframe-sandbox
  • Rename rule react/no-unsafe-target-blank to react-dom/no-unsafe-target-blank

✨ New

  • Make dom an alias of react-dom preset
  • Make hooks an alias of react-hooks preset
  • Add preset jsx and jsx-legacy
  • Add preset react-dom and dom-legacy
  • Add preset core and core-legacy
  • Add preset react-hooks and hooks-legacy

🐞 Fixes

  • Fix the lint message for rule react-dom/no-dangerously-set-innerhtml

v1.0.0-beta.3 (2024-01-26)

🐞 Fixes

  • Fix the name prefix for react-dom rules

v1.0.0-beta.2 (2024-01-26)

✨ New

  • Make dom an alias of react-dom preset
  • Make hooks an alias of react-hooks preset

v1.0.0-beta.1 (2024-01-26)

✨ New

  • Add preset jsx and jsx-legacy
  • Add preset dom and dom-legacy
  • Add preset core and core-legacy
  • Add preset hooks and hooks-legacy

v1.0.0-beta.0 (2024-01-26)

💥 Breaking Changes

  • Rename rule react/no-dangerously-set-innerhtml to react-dom/no-dangerously-set-innerhtml
  • Rename rule react/no-dangerously-set-innerhtml-with-children to react-dom/no-dangerously-set-innerhtml-with-children
  • Rename rule react/no-find-dom-node to react-dom/no-find-dom-node
  • Rename rule react/no-missing-button-type to react-dom/no-missing-button-type
  • Rename rule react/no-missing-iframe-sandbox to react-dom/no-missing-iframe-sandbox
  • Rename rule react/no-script-url to react-dom/no-script-url
  • Rename rule react/no-unsafe-iframe-sandbox to react-dom/no-unsafe-iframe-sandbox
  • Rename rule react/no-unsafe-target-blank to react-dom/no-unsafe-target-blank

v0.10.12 (2024-01-21)

🪄 Improvements

  • Remove unnecessary parserOptions fields from presets

v0.10.12-beta.0 (2024-01-21)

🪄 Improvements

  • Remove unnecessary parserOptions fields from presets

v0.10.11 (2024-01-20)

✨ New

  • Add rule react/no-access-state-in-setstate

🪄 Improvements

  • Improve rule react/no-unused-state to respect the usage of getDerivedStateFromProps
  • Update @typescript-eslint's packages to 6.19.0

v0.10.11-beta.2 (2024-01-19)

✨ New

  • Add rule react/no-access-state-in-setstate

v0.10.11-beta.1 (2024-01-16)

🪄 Improvements

  • Update @typescript-eslint's packages to 6.19.0

v0.10.11-beta.0 (2024-01-15)

🪄 Improvements

  • Improve rule react/no-unused-state to respect the usage of getDerivedStateFromProps

v0.10.10 (2024-01-14)

🪄 Improvements

  • Improve rule react/no-unused-state to support checking for more cases
  • Improve rule react/no-direct-mutation-state to support checking for more cases
  • Improve rule react/no-unused-class-component-members to support checking for more cases

v0.10.10-beta.0 (2024-01-14)

🪄 Improvements

  • Improve rule react/no-unused-state to support checking for more cases
  • Improve rule react/no-direct-mutation-state to support checking for more cases
  • Improve rule react/no-unused-class-component-members to support checking for more cases

v0.10.9 (2024-01-12)

🐞 Fixes

  • Fix bundle size is larger than expected

v0.10.8 (2024-01-11)

🐞 Fixes

  • Fix version format in v0.10.7's package.json

v0.10.7 (2024-01-11)

✨ New

  • Add rule react/no-unused-state

v0.10.6 (2024-01-09)

🐞 Fixes

  • Fix an issue where react/no-constructed-context-value and react/no-unstable-default-props would report false negatives when using LogicalExpression and ConditionalExpression

v0.10.6-beta.0 (2024-01-08)

🐞 Fixes

  • Fix an issue where react/no-constructed-context-value and react/no-unstable-default-props would report false negatives when using LogicalExpression and ConditionalExpression

v0.10.5 (2024-01-08)

✨ New

  • Add rule react/no-unused-class-component-members

🪄 Improvements

  • Update @typescript-eslint's packages to 6.18.0

v0.10.5-beta.0 (2024-01-07)

✨ New

  • Add rule react/no-unused-class-component-members

🪄 Improvements

  • Update @typescript-eslint's packages to 6.18.0

v0.10.4 (2024-01-06)

🪄 Improvements

  • Improve rule react/no-unstable-default-props to support checking for ObjectPatterns within VariableDeclarators that occur on props
  • Improve function component detection in rule react/no-unstable-nested-components and debug/function-component

🐞 Fixes

  • Fix same kind of error inside a component should not only be reported once in rule react/no-create-ref and react/no-constructed-context-value
  • Fix an issue where render functions wrapped in useCallback were accidentally detected as function components in rules react/no-unstable-nested-components and debug/function-component

v0.10.4-beta.1 (2024-01-06)

🪄 Improvements

  • Improve function component detection in rule react/no-unstable-nested-components and debug/function-component

🐞 Fixes

  • Fix an issue where render functions wrapped in useCallback were accidentally detected as function components in rules react/no-unstable-nested-components and debug/function-component

v0.10.4-beta.0 (2024-01-06)

🪄 Improvements

  • Improve rule react/no-unstable-default-props to support checking for ObjectPatterns within VariableDeclarators that occur on props

🐞 Fixes

  • Fix same kind of error inside a component should not only be reported once in rule react/no-create-ref and react/no-constructed-context-value

v0.10.3 (2024-01-05)

🪄 Improvements

  • Update @typescript-eslint's packages to 6.17.0

v0.10.3-beta.0 (2024-01-02)

🪄 Improvements

  • Update @typescript-eslint's packages to 6.17.0

v0.10.2 (2023-12-30)

✨ New

v0.10.2-beta.0 (2023-12-30)

✨ New

v0.10.1 (2023-12-27)

🪄 Improvements

  • Add react/no-clone-element to recommended and recommended-legacy presets
  • Improve rule react/no-unstable-nested-components, make its behavior closer to react-hooks/no-nested-components
  • Update @typescript-eslint's packages to 6.16.0

v0.10.1-beta.1 (2023-12-26)

🪄 Improvements

  • Update @typescript-eslint's packages to 6.16.0

v0.10.1-beta.0 (2023-12-25)

🪄 Improvements

  • Add react/no-clone-element to recommended and recommended-legacy presets
  • Improve rule react/no-unstable-nested-components, make its behavior closer to react-hooks/no-nested-components

v0.10.0 (2023-12-21)

✨ New

  • Add rule jsx/max-depth

🪄 Improvements

  • Improve recommended and recommended-legacy presets

v0.10.0-beta.0 (2023-12-21)

✨ New

  • Add rule jsx/max-depth

🪄 Improvements

  • Improve recommended and recommended-legacy presets

v0.9.8 (2023-12-19)

✨ New

  • Add rule react/ensure-forward-ref-using-ref

🪄 Improvements

  • Reduce false positives in rule react/no-unstable-nested-components
  • Reduce false positives in rule debug/function-component
  • Optimize recommended and recommended-legacy presets
  • Update @typescript-eslint's packages to 6.15.0

v0.9.8-beta.2 (2023-12-19)

🪄 Improvements

  • Optimize recommended and recommended-legacy presets

v0.9.8-beta.1 (2023-12-19)

🪄 Improvements

  • Minor improvements

v0.9.8-beta.0 (2023-12-17)

✨ New

  • Add rule react/ensure-forward-ref-using-ref

🪄 Improvements

  • Reduce false positives in rule react/no-unstable-nested-components

  • Reduce false positives in rule debug/function-component

v0.9.7 (2023-12-17)

💥 Breaking Changes

  • Rule named-convention/filename-extension rename rule option to allow

🐞 Fixes

  • Fix where functions in <Component footer={() => <div />} /> or <Component Footer={() => <div />} /> are treated as components
  • Fix false positive in rule react/no-unstable-nested-components
  • Fix false positive in rule debug/function-component

🪄 Improvements

  • Rules now support reading JSX extensions from settings.eslintReact.jsx.extensions

  • Replace ❌ Incorrect and ✅ Correct with Failing and Passing in rule docs

v0.9.7-beta.2 (2023-12-16)

🐞 Fixes

  • Update default rule option in named-convention/filename to PascalCase

v0.9.7-beta.1 (2023-12-14)

🪄 Improvements

  • Minor improvements

v0.9.7-beta.0 (2023-12-14)

💥 Breaking Changes

  • Rule named-convention/filename-extension rename rule option to allow

✨ New

  • Rule named-convention/filename add extensions option
  • Rule named-convention/filename-extension add extensions option

v0.9.6 (2023-12-12)

✨ New

  • Add rule react-hooks/prefer-use-state-lazy-initialization

🪄 Improvements

  • Rule named-convention/component-name add both string and object options support
  • Rule named-convention/filename add both string and object options support
  • Rule named-convention/filename-extension add both string and object options support
  • Rule debug/react-hooks reports hookCalls.length instead of cost
  • Update @typescript-eslint's packages to 6.14.0

v0.9.6-beta.5 (2023-12-12)

🪄 Improvements

  • Update @typescript-eslint's packages to 6.14.0

v0.9.6-beta.4 (2023-12-11)

🪄 Improvements

  • Rule named-convention/component-name add both string and object options support
  • Rule named-convention/filename add both string and object options support
  • Rule named-convention/filename-extension add both string and object options support

v0.9.6-beta.3 (2023-12-11)

🪄 Improvements

  • Remove rule react-hooks/prefer-use-state-lazy-initialization from recommended and recommended-legacy presets

v0.9.6-beta.2 (2023-12-11)

✨ New

  • Add rule react-hooks/prefer-use-state-lazy-initialization

🪄 Improvements

  • Rule named-convention/filename-extension switch options format from object to string

v0.9.6-beta.1 (2023-12-11)

🪄 Improvements

  • Rule debug/react-hooks reports hookCalls.length instead of cost

v0.9.5 (2023-12-11)

🪄 Improvements

  • Improve rule jsx/no-leaked-conditional-rendering error marker position and range
  • Improve rule react/no-missing-button-type error marker position and range
  • Improve rule react/no-missing-iframe-sandbox error marker position and range
  • Improve rule react/no-unsafe-iframe-sandbox error marker position and range

v0.9.4 (2023-12-08)

🪄 Improvements

  • Improve rule docs

v0.9.3 (2023-12-08)

✨ New

  • Add rule react/no-direct-mutation-state
  • Add rule naming-convention/use-state

🪄 Improvements

  • Update recommended and recommended-legacy presets
  • Improve rules overview page

v0.9.2 (2023-12-06)

✨ New

  • Add rule react/no-component-will-update
  • Add rule react/no-unsafe-component-will-update
  • Add rule react/no-component-will-receive-props
  • Add rule react/no-unsafe-component-will-receive-props
  • Add rule react/no-set-state-in-component-did-mount
  • Add rule react/no-set-state-in-component-did-update
  • Add rule react/no-set-state-in-component-will-update

v0.9.1 (2023-12-05)

✨ New

  • Add rule react/no-component-will-mount
  • Add rule react/no-unsafe-component-will-mount

v0.9.0 (2023-12-01)

💥 Breaking Changes

  • @eslint-react/eslint-plugin-jsx
    • Remove allowExpressions option from rule jsx/no-useless-fragment
  • @eslint-react/jsx
    • Remove isFragmentWithOnlyTextAndIsNotChild, isFragmentHasLessThanTwoChildren, isFragmentWithSingleExpression from @eslint-react/jsx's API

✨ New

  • Add rule react/no-redundant-should-component-update

🪄 Improvements

  • Update Options of rule jsx/no-useless-fragment
  • Optimize bundle size