ESLINT_REACT_RULES_REQUIRED

Requires that a workspace package is configured with required React plugins and rules
Table of Contents

Conformance is available on Enterprise plans

This Conformance check requires that ESLint plugins for React are configured correctly in your application, including:

These plugins help to catch common React issues, such as incorrect React hooks usage, helping to reduce bugs and to improve application accessibility.

A Conformance error occurred in test "ESLINT_REACT_RULES_REQUIRED".
 
These ESLint plugins must have rules configured to run: @next/next
 
To find out more information and how to fix this error, visit
https://vercel.com/docs/workflow-collaboration/conformance/rules/ESLINT_REACT_RULES_REQUIRED.
 
If this violation should be ignored, add the following entry to
/apps/dashboard/.allowlists/ESLINT_REACT_RULES_REQUIRED.allowlist.json and
get approval from the appropriate person.
 
{
  "testName": "ESLINT_REACT_RULES_REQUIRED",
  "reason": "TODO: Add reason why this violation is allowed to be ignored.",
  "location": {
    "workspace": "dashboard"
  },
}

This check requires that certain ESLint plugins are installed and rules within those plugins are configured to be errors. If you are missing required plugins, you will receive an error such as:

ESLint configuration is missing required security plugins:
  Missing plugins: react, react-hooks, and jsx-a11y
  Registered plugins: import and @typescript-eslint

For more information on ESLint plugins and rules, see plugins and rules.

The recommended approach for configuring ESLint in a monorepo is to have a shared ESLint config in an internal package. See the Turbo docs on ESLint to get started.

Once your monorepo has a shared ESLint config, you can add a .eslintrc.cjs file to the root folder of your workspace with the contents:

.eslintrc.cjs
module.exports = {
  root: true,
  extends: ['eslint-config-custom/base'],
};

You should also add "eslint-config-custom": "workspace:*" to your devDependencies.

Last updated on July 23, 2024