|
|
|
module.exports = {
|
|
|
|
env: {
|
|
|
|
browser: true,
|
|
|
|
es6: true,
|
|
|
|
jest: true,
|
|
|
|
},
|
|
|
|
extends: [
|
|
|
|
'plugin:react/recommended',
|
|
|
|
'airbnb',
|
|
|
|
],
|
|
|
|
globals: {
|
|
|
|
Atomics: 'readonly',
|
|
|
|
SharedArrayBuffer: 'readonly',
|
|
|
|
},
|
|
|
|
parser: 'babel-eslint',
|
|
|
|
parserOptions: {
|
|
|
|
ecmaFeatures: {
|
|
|
|
jsx: true,
|
|
|
|
},
|
|
|
|
ecmaVersion: 2018,
|
|
|
|
sourceType: 'module',
|
|
|
|
},
|
|
|
|
plugins: [
|
|
|
|
'react',
|
|
|
|
'react-hooks',
|
|
|
|
],
|
|
|
|
rules: {
|
|
|
|
'react/jsx-props-no-spreading': 'off',
|
|
|
|
'import/extensions': 'off',
|
|
|
|
'react/jsx-indent': [
|
|
|
|
'error',
|
|
|
|
4,
|
|
|
|
{
|
|
|
|
checkAttributes: true,
|
|
|
|
indentLogicalExpressions: true,
|
|
|
|
},
|
|
|
|
],
|
|
|
|
'react/require-default-props': 'off',
|
|
|
|
'react/prop-types': 'off',
|
|
|
|
'react-hooks/rules-of-hooks': 'error',
|
|
|
|
'react-hooks/exhaustive-deps': 'error',
|
|
|
|
'max-len': ['warn', { code: 120, tabWidth: 4 }],
|
|
|
|
'no-unused-vars': 'warn',
|
|
|
|
'no-console': 'off',
|
|
|
|
'no-shadow': 'warn',
|
|
|
|
'no-multi-str': 'warn',
|
|
|
|
'no-underscore-dangle': 0,
|
|
|
|
'jsx-a11y/label-has-associated-control': [2, {
|
|
|
|
labelAttributes: ['label'],
|
|
|
|
controlComponents: ['Input'],
|
|
|
|
depth: 3,
|
|
|
|
}],
|
|
|
|
},
|
|
|
|
settings: {
|
|
|
|
'import/resolver': {
|
|
|
|
node: {
|
|
|
|
extensions: ['.js', '.jsx'],
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
};
|