218 lines
5.1 KiB
JavaScript
218 lines
5.1 KiB
JavaScript
module.exports = {
|
|
root: true,
|
|
|
|
extends: [
|
|
'eslint:recommended',
|
|
'plugin:react/recommended',
|
|
'plugin:jsx-a11y/recommended',
|
|
'plugin:import/recommended',
|
|
'plugin:promise/recommended',
|
|
],
|
|
|
|
env: {
|
|
browser: true,
|
|
node: true,
|
|
es6: true,
|
|
jest: true,
|
|
},
|
|
|
|
globals: {
|
|
ATTACHMENT_HOST: false,
|
|
},
|
|
|
|
parser: '@babel/eslint-parser',
|
|
|
|
plugins: [
|
|
'react',
|
|
'jsx-a11y',
|
|
'import',
|
|
'promise',
|
|
],
|
|
|
|
parserOptions: {
|
|
sourceType: 'module',
|
|
ecmaFeatures: {
|
|
experimentalObjectRestSpread: true,
|
|
jsx: true,
|
|
},
|
|
ecmaVersion: 2021,
|
|
},
|
|
|
|
settings: {
|
|
react: {
|
|
version: 'detect',
|
|
},
|
|
'import/extensions': [
|
|
'.js', '.jsx',
|
|
],
|
|
'import/ignore': [
|
|
'node_modules',
|
|
'\\.(css|scss|json)$',
|
|
],
|
|
'import/resolver': {
|
|
node: {
|
|
paths: ['app/javascript'],
|
|
extensions: ['.js', '.jsx'],
|
|
},
|
|
},
|
|
},
|
|
|
|
rules: {
|
|
'brace-style': 'warn',
|
|
'comma-dangle': ['error', 'always-multiline'],
|
|
'comma-spacing': [
|
|
'warn',
|
|
{
|
|
before: false,
|
|
after: true,
|
|
},
|
|
],
|
|
'comma-style': ['warn', 'last'],
|
|
'consistent-return': 'error',
|
|
'dot-notation': 'error',
|
|
eqeqeq: 'error',
|
|
indent: ['warn', 2],
|
|
'jsx-quotes': ['error', 'prefer-single'],
|
|
'no-case-declarations': 'off',
|
|
'no-catch-shadow': 'error',
|
|
'no-console': [
|
|
'warn',
|
|
{
|
|
allow: [
|
|
'error',
|
|
'warn',
|
|
],
|
|
},
|
|
],
|
|
'no-empty': 'off',
|
|
'no-restricted-properties': [
|
|
'error',
|
|
{ property: 'substring', message: 'Use .slice instead of .substring.' },
|
|
{ property: 'substr', message: 'Use .slice instead of .substr.' },
|
|
],
|
|
'no-self-assign': 'off',
|
|
'no-trailing-spaces': 'warn',
|
|
'no-unused-expressions': 'error',
|
|
'no-unused-vars': [
|
|
'error',
|
|
{
|
|
vars: 'all',
|
|
args: 'after-used',
|
|
ignoreRestSiblings: true,
|
|
},
|
|
],
|
|
'object-curly-spacing': ['error', 'always'],
|
|
'padded-blocks': [
|
|
'error',
|
|
{
|
|
classes: 'always',
|
|
},
|
|
],
|
|
quotes: ['error', 'single'],
|
|
semi: 'error',
|
|
'valid-typeof': 'error',
|
|
|
|
'react/jsx-filename-extension': ['error', { 'allow': 'as-needed' }],
|
|
'react/jsx-boolean-value': 'error',
|
|
'react/jsx-closing-bracket-location': ['error', 'line-aligned'],
|
|
'react/jsx-curly-spacing': 'error',
|
|
'react/display-name': 'off',
|
|
'react/jsx-equals-spacing': 'error',
|
|
'react/jsx-first-prop-new-line': ['error', 'multiline-multiprop'],
|
|
'react/jsx-indent': ['error', 2],
|
|
'react/jsx-no-bind': 'error',
|
|
'react/jsx-no-target-blank': 'off',
|
|
'react/jsx-tag-spacing': 'error',
|
|
'react/jsx-wrap-multilines': 'error',
|
|
'react/no-deprecated': 'off',
|
|
'react/no-unknown-property': 'off',
|
|
'react/self-closing-comp': 'error',
|
|
|
|
// recommended values found in https://github.com/jsx-eslint/eslint-plugin-jsx-a11y/blob/main/src/index.js
|
|
'jsx-a11y/accessible-emoji': 'warn',
|
|
'jsx-a11y/click-events-have-key-events': 'off',
|
|
'jsx-a11y/label-has-associated-control': 'off',
|
|
'jsx-a11y/media-has-caption': 'off',
|
|
'jsx-a11y/no-autofocus': 'off',
|
|
// recommended rule is:
|
|
// 'jsx-a11y/no-interactive-element-to-noninteractive-role': [
|
|
// 'error',
|
|
// {
|
|
// tr: ['none', 'presentation'],
|
|
// canvas: ['img'],
|
|
// },
|
|
// ],
|
|
'jsx-a11y/no-interactive-element-to-noninteractive-role': 'off',
|
|
// recommended rule is:
|
|
// 'jsx-a11y/no-noninteractive-element-interactions': [
|
|
// 'error',
|
|
// {
|
|
// body: ['onError', 'onLoad'],
|
|
// iframe: ['onError', 'onLoad'],
|
|
// img: ['onError', 'onLoad'],
|
|
// },
|
|
// ],
|
|
'jsx-a11y/no-noninteractive-element-interactions': [
|
|
'warn',
|
|
{
|
|
handlers: [
|
|
'onClick',
|
|
],
|
|
},
|
|
],
|
|
// recommended rule is:
|
|
// 'jsx-a11y/no-noninteractive-tabindex': [
|
|
// 'error',
|
|
// {
|
|
// tags: [],
|
|
// roles: ['tabpanel'],
|
|
// allowExpressionValues: true,
|
|
// },
|
|
// ],
|
|
'jsx-a11y/no-noninteractive-tabindex': 'off',
|
|
'jsx-a11y/no-onchange': 'warn',
|
|
// recommended is full 'error'
|
|
'jsx-a11y/no-static-element-interactions': [
|
|
'warn',
|
|
{
|
|
handlers: [
|
|
'onClick',
|
|
],
|
|
},
|
|
],
|
|
|
|
// See https://github.com/import-js/eslint-plugin-import/blob/main/config/recommended.js
|
|
'import/extensions': [
|
|
'error',
|
|
'always',
|
|
{
|
|
js: 'never',
|
|
jsx: 'never',
|
|
},
|
|
],
|
|
'import/newline-after-import': 'error',
|
|
'import/no-extraneous-dependencies': [
|
|
'error',
|
|
{
|
|
devDependencies: [
|
|
'config/webpack/**',
|
|
'app/javascript/mastodon/test_setup.js',
|
|
'app/javascript/**/__tests__/**',
|
|
],
|
|
},
|
|
],
|
|
'import/no-webpack-loader-syntax': 'error',
|
|
|
|
'promise/always-return': 'off',
|
|
'promise/catch-or-return': [
|
|
'error',
|
|
{
|
|
allowFinally: true,
|
|
},
|
|
],
|
|
'promise/no-callback-in-promise': 'off',
|
|
'promise/no-nesting': 'off',
|
|
'promise/no-promise-in-callback': 'off',
|
|
},
|
|
};
|