Rewrite .eslintrc.premium.js to new config format

[MAILPOET-5015]
This commit is contained in:
Jan Jakes
2023-03-24 16:20:39 +01:00
committed by Jan Jakeš
parent 542ac60626
commit e2d658e5fc
2 changed files with 54 additions and 34 deletions

View File

@ -1,34 +0,0 @@
module.exports = {
extends: ['airbnb', 'plugin:react/jsx-runtime', 'prettier'],
env: {
browser: true,
},
parser: '@babel/eslint-parser',
parserOptions: {
ecmaVersion: 6,
ecmaFeatures: {
jsx: true,
},
},
plugins: ['react-hooks'],
settings: {
'import/resolver': 'webpack',
},
rules: {
'class-methods-use-this': 0,
// React hooks rules
'react-hooks/rules-of-hooks': 'error',
'react-hooks/exhaustive-deps': 'warn',
'import/prefer-default-export': 0, // we want to stop using default exports and start using named exports
// Exceptions
'import/extensions': 0, // we wouldn't be able to import jQuery without this line
'jsx-a11y/anchor-is-valid': [
'error',
{
components: ['Link'],
specialLink: ['to'],
},
],
'import/no-default-export': 1, // no default exports
},
};

View File

@ -0,0 +1,54 @@
const babelParser = require('@babel/eslint-parser');
const FlatCompat = require('@eslint/eslintrc').FlatCompat;
const airbnbConfig = require('eslint-config-airbnb');
const prettierConfig = require('eslint-config-prettier');
const webpackResolver = require('eslint-import-resolver-webpack');
const reactJsxRuntimeConfig = require('eslint-plugin-react/configs/jsx-runtime');
const reactHooksPlugin = require('eslint-plugin-react-hooks');
const globals = require('globals');
// compat configs
const compat = new FlatCompat({ baseDirectory: __dirname });
const airbnbCompatConfig = compat.config(airbnbConfig);
const prettierCompatConfig = compat.config(prettierConfig);
// React plugin is already defined by airbnb config. This fixes:
// TypeError: Key "plugins": Cannot redefine plugin "react"
delete reactJsxRuntimeConfig.plugins.react;
module.exports = [
...airbnbCompatConfig,
reactJsxRuntimeConfig,
...prettierCompatConfig,
{
languageOptions: {
parser: babelParser,
globals: {
...globals.browser,
},
},
settings: {
'import/resolver': { webpack: webpackResolver },
},
plugins: {
'react-hooks': reactHooksPlugin,
},
rules: {
'class-methods-use-this': 0,
// React hooks rules
'react-hooks/rules-of-hooks': 'error',
'react-hooks/exhaustive-deps': 'warn',
'import/prefer-default-export': 0, // we want to stop using default exports and start using named exports
// Exceptions
'import/extensions': 0, // we wouldn't be able to import jQuery without this line
'jsx-a11y/anchor-is-valid': [
'error',
{
components: ['Link'],
specialLink: ['to'],
},
],
'import/no-default-export': 1, // no default exports
},
},
];