Use JS ESLint configs instead of JSON
This is to avoid ERR_IMPORT_ASSERTION_TYPE_MISSING on recent Node.js with updated ESLint. Fixes errors like the following: ".eslintrc.es6.json" needs an import assertion of type "json" [MAILPOET-5061]
This commit is contained in:
76
packages/js/eslint-config/.eslintrc-premium.ts.js
Normal file
76
packages/js/eslint-config/.eslintrc-premium.ts.js
Normal file
@ -0,0 +1,76 @@
|
||||
module.exports = {
|
||||
extends: [
|
||||
'eslint:recommended',
|
||||
'plugin:@typescript-eslint/recommended',
|
||||
'plugin:@typescript-eslint/recommended-requiring-type-checking',
|
||||
'airbnb',
|
||||
'airbnb-typescript',
|
||||
'plugin:react/jsx-runtime',
|
||||
'prettier',
|
||||
],
|
||||
env: {
|
||||
amd: true,
|
||||
browser: true,
|
||||
mocha: true,
|
||||
},
|
||||
parser: '@typescript-eslint/parser',
|
||||
parserOptions: {
|
||||
tsconfigRootDir: '.',
|
||||
project: ['./tsconfig.json'],
|
||||
ecmaVersion: 6,
|
||||
ecmaFeatures: {
|
||||
jsx: true,
|
||||
},
|
||||
},
|
||||
plugins: ['react-hooks', 'no-only-tests', '@typescript-eslint'],
|
||||
settings: {
|
||||
'import/resolver': 'webpack',
|
||||
},
|
||||
rules: {
|
||||
'class-methods-use-this': 0,
|
||||
// PropTypes
|
||||
'react/prop-types': 0,
|
||||
'react/require-default-props': 0,
|
||||
'react/jsx-props-no-spreading': 0,
|
||||
// Hooks
|
||||
'react-hooks/rules-of-hooks': 'error',
|
||||
'react-hooks/exhaustive-deps': 'warn',
|
||||
// Exceptions
|
||||
'no-void': 0, // can conflict with @typescript-eslint/no-floating-promises
|
||||
'react/jsx-filename-extension': 0,
|
||||
'@typescript-eslint/no-unsafe-return': 0, // we need to disable it for wordpress select :(
|
||||
'@typescript-eslint/no-unsafe-member-access': 0, // we need to disable it for wordpress select :(
|
||||
'@typescript-eslint/no-unsafe-call': 0, // this needs to match the one defined for free plugin
|
||||
'@typescript-eslint/no-unsafe-assignment': 0, // this needs to match the one defined for free plugin
|
||||
'import/extensions': 0, // we wouldn't be able to import jQuery without this line
|
||||
'import/prefer-default-export': 0, // we want to stop using default exports and start using named exports
|
||||
'react/destructuring-assignment': 0, // that would be too many changes to fix this one
|
||||
'prefer-destructuring': 0, // that would be too many changes to fix this one
|
||||
'jsx-a11y/label-has-for': [
|
||||
2,
|
||||
{
|
||||
required: { some: ['nesting', 'id'] }, // some of our labels are hidden and we cannot nest those
|
||||
},
|
||||
],
|
||||
'jsx-a11y/anchor-is-valid': 0, // cannot fix this one, it would break wprdpress themes
|
||||
'jsx-a11y/label-has-associated-control': [
|
||||
2,
|
||||
{
|
||||
either: 'either', // control has to be either nested or associated via htmlFor
|
||||
},
|
||||
],
|
||||
'import/no-default-export': 1, // no default exports
|
||||
},
|
||||
overrides: [
|
||||
{
|
||||
files: ['**/_stories/*.tsx'],
|
||||
rules: {
|
||||
'import/no-extraneous-dependencies': [
|
||||
'error',
|
||||
{ devDependencies: true },
|
||||
],
|
||||
'import/no-default-export': 0,
|
||||
},
|
||||
},
|
||||
],
|
||||
};
|
Reference in New Issue
Block a user