UNPKG

eslint-config-xo-react

Version:

ESLint shareable config for React to be used with eslint-config-xo

238 lines (235 loc) 5.61 kB
import react from 'eslint-plugin-react'; import reactHooks from 'eslint-plugin-react-hooks'; export default [ { plugins: { react, 'react-hooks': reactHooks, }, languageOptions: { parserOptions: { ecmaFeatures: { jsx: true, }, }, }, settings: { react: { version: 'detect', }, }, rules: { 'react/boolean-prop-naming': [ 'error', { validateNested: true, }, ], 'react/button-has-type': 'error', 'react/checked-requires-onchange-or-readonly': 'error', 'react/jsx-child-element-spacing': 'error', 'react/default-props-match-prop-types': 'error', 'react/forward-ref-uses-ref': 'error', 'react/function-component-definition': [ 'error', { namedComponents: 'function-declaration', unnamedComponents: 'arrow-function', }, ], 'react/hook-use-state': [ 'error', { allowDestructuredState: true, }, ], 'react/iframe-missing-sandbox': 'error', 'react/no-access-state-in-setstate': 'error', 'react/no-array-index-key': 'error', 'react/no-arrow-function-lifecycle': 'error', 'react/no-children-prop': 'error', 'react/no-danger': 'error', 'react/no-danger-with-children': 'error', 'react/no-deprecated': 'error', 'react/no-did-update-set-state': 'error', 'react/no-direct-mutation-state': 'error', 'react/no-find-dom-node': 'error', 'react/no-invalid-html-attribute': 'error', 'react/no-is-mounted': 'error', 'react/no-namespace': 'error', 'react/no-object-type-as-default-prop': 'error', 'react/no-redundant-should-component-update': 'error', 'react/no-render-return-value': 'error', 'react/no-typos': 'error', 'react/no-string-refs': [ 'error', { noTemplateLiterals: true, }, ], 'react/no-this-in-sfc': 'error', 'react/no-unescaped-entities': 'error', 'react/no-unknown-property': [ 'error', { requireDataLowercase: true, }, ], 'react/no-unsafe': 'error', 'react/no-unused-prop-types': 'error', 'react/no-unused-state': 'error', 'react/prefer-read-only-props': 'error', 'react/prop-types': 'error', 'react/react-in-jsx-scope': 'error', 'react/require-default-props': [ 'error', { forbidDefaultForRequired: true, ignoreFunctionalComponents: true, }, ], 'react/self-closing-comp': 'error', 'react/state-in-constructor': ['error', 'never'], 'react/static-property-placement': 'error', 'react/style-prop-object': [ 'error', { allow: [ // This allows react-intl’s `<FormattedNumber value={0.42} style='percent'/>`. 'FormattedNumber', ], }, ], 'react/void-dom-elements-no-children': 'error', 'react/jsx-boolean-value': 'error', 'react/jsx-closing-bracket-location': [ 'error', { nonEmpty: 'tag-aligned', selfClosing: false, }, ], 'react/jsx-closing-tag-location': 'error', 'react/jsx-curly-newline': [ 'error', { multiline: 'consistent', singleline: 'forbid', }, ], 'react/jsx-curly-spacing': ['error', 'never'], 'react/jsx-equals-spacing': ['error', 'never'], 'react/jsx-first-prop-new-line': 'error', 'react/jsx-indent': [ 'error', 'tab', { checkAttributes: true, indentLogicalExpressions: true, }, ], 'react/jsx-indent-props': ['error', 'tab'], 'react/jsx-key': [ 'error', { checkFragmentShorthand: true, checkKeyMustBeforeSpread: true, warnOnDuplicates: true, }, ], 'react/jsx-max-props-per-line': [ 'error', { maximum: 3, when: 'multiline', }, ], 'react/jsx-no-bind': [ 'error', { allowArrowFunctions: true, }, ], 'react/jsx-no-comment-textnodes': 'error', 'react/jsx-no-constructed-context-values': 'error', 'react/jsx-no-duplicate-props': [ 'error', { ignoreCase: true, }, ], 'react/jsx-no-leaked-render': [ 'error', { validStrategies: [ 'ternary', 'coerce', ], }, ], 'react/jsx-no-script-url': [ 'error', { includeFromSettings: true, }, ], 'react/jsx-no-target-blank': [ 'error', { warnOnSpreadAttributes: true, forms: true, }, ], 'react/jsx-no-undef': 'error', 'react/jsx-no-useless-fragment': 'error', // Disabled for now as it produces too many errors // 'react/jsx-one-expression-per-line': ['error', {allow: 'single-child'}], 'react/jsx-curly-brace-presence': [ 'error', { props: 'never', children: 'never', propElementValues: 'always', }, ], 'react/jsx-fragments': ['error', 'syntax'], 'react/jsx-pascal-case': 'error', 'react/jsx-props-no-multi-spaces': 'error', 'react/jsx-props-no-spread-multi': 'error', 'react/jsx-sort-props': [ 'error', { callbacksLast: true, shorthandFirst: true, noSortAlphabetically: true, reservedFirst: true, }, ], 'react/jsx-tag-spacing': [ 'error', { closingSlash: 'never', beforeSelfClosing: 'never', afterOpening: 'never', beforeClosing: 'never', }, ], 'react/jsx-uses-react': 'error', 'react/jsx-uses-vars': 'error', 'react/jsx-wrap-multilines': [ 'error', { declaration: 'parens-new-line', assignment: 'parens-new-line', return: 'parens-new-line', arrow: 'parens-new-line', condition: 'ignore', logical: 'ignore', prop: 'ignore', }, ], 'react-hooks/rules-of-hooks': 'error', 'react-hooks/exhaustive-deps': 'warn', }, }, ];