.eslintrc.js 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. module.exports = {
  2. env: {
  3. browser: true,
  4. es6: true,
  5. jest: true,
  6. },
  7. extends: [
  8. 'eslint:recommended',
  9. 'plugin:react/recommended',
  10. 'plugin:@typescript-eslint/recommended',
  11. 'prettier',
  12. 'prettier/@typescript-eslint',
  13. ],
  14. settings: {
  15. react: {
  16. version: 'detect',
  17. },
  18. },
  19. globals: {
  20. JSX: true,
  21. module: true,
  22. shallow: true,
  23. render: true,
  24. mount: true,
  25. global: true,
  26. },
  27. parser: '@typescript-eslint/parser',
  28. parserOptions: {
  29. ecmaFeatures: {
  30. jsx: true,
  31. },
  32. ecmaVersion: 2018,
  33. sourceType: 'module',
  34. parserOptions: {
  35. project: './tsconfig.json',
  36. },
  37. },
  38. plugins: ['@typescript-eslint'],
  39. rules: {
  40. // TypeScript Rules
  41. '@typescript-eslint/no-explicit-any': 0,
  42. // JavaScript Rules
  43. 'arrow-body-style': ['warn', 'as-needed'],
  44. 'arrow-parens': ['warn', 'as-needed'],
  45. 'arrow-spacing': 'error',
  46. 'block-spacing': ['error', 'never'],
  47. camelcase: ['error', {properties: 'always'}],
  48. 'comma-dangle': 0,
  49. 'comma-spacing': ['error', {before: false, after: true}],
  50. 'comma-style': ['error', 'last'],
  51. 'global-require': 0,
  52. indent: ['error', 2],
  53. 'key-spacing': ['error', {beforeColon: false, afterColon: true}],
  54. 'keyword-spacing': ['error', {before: true, after: true}],
  55. 'linebreak-style': ['error', 'unix'],
  56. 'linebreak-style': ['error', 'unix'],
  57. 'max-len': ['error', 120],
  58. 'no-confusing-arrow': ['error', {allowParens: false}],
  59. 'no-multi-spaces': 'error',
  60. 'no-shadow': 1,
  61. 'no-trailing-spaces': 'error',
  62. 'no-unused-expressions': 1,
  63. 'no-unused-vars': 1,
  64. 'no-useless-rename': 'error',
  65. 'no-whitespace-before-property': 'error',
  66. 'object-curly-newline': ['error', {consistent: true}],
  67. 'object-curly-spacing': ['error', 'never'],
  68. quotes: ['error', 'single'],
  69. semi: ['error', 'always'],
  70. 'semi-spacing': ['error', {before: false, after: true}],
  71. 'space-before-blocks': ['error', 'always'],
  72. 'space-before-function-paren': [
  73. 'error',
  74. {
  75. anonymous: 'never',
  76. named: 'never',
  77. asyncArrow: 'always',
  78. },
  79. ],
  80. 'space-in-parens': ['error', 'never'],
  81. 'space-infix-ops': ['error', {int32Hint: false}],
  82. 'space-unary-ops': [2, {words: true, nonwords: false}],
  83. // React Rules
  84. 'react/jsx-filename-extension': ['error', {extensions: ['.jsx', '.tsx']}],
  85. 'react/jsx-indent': [1, 2],
  86. 'react/jsx-key': 1,
  87. 'react/jsx-no-comment-textnodes': 1,
  88. 'react/jsx-no-duplicate-props': 1,
  89. 'react/jsx-no-target-blank': 2,
  90. 'react/jsx-props-no-multi-spaces': 1,
  91. 'react/jsx-sort-props': 1,
  92. 'react/jsx-tag-spacing': ['warn', {beforeSelfClosing: true}],
  93. 'react/no-children-prop': 1,
  94. 'react/no-deprecated': 1,
  95. 'react/no-direct-mutation-state': 2,
  96. 'react/no-typos': 1,
  97. 'react/no-unknown-property': 1,
  98. 'react/prefer-stateless-function': 1,
  99. 'react/prop-types': 1,
  100. 'react/react-in-jsx-scope': 2,
  101. 'react/require-default-props': 1,
  102. 'react/require-render-return': 1,
  103. 'react/sort-comp': 1,
  104. 'react/jsx-wrap-multilines': [
  105. 1,
  106. {
  107. declaration: 'parens-new-line',
  108. assignment: 'parens-new-line',
  109. return: 'parens-new-line',
  110. arrow: 'parens-new-line',
  111. condition: 'parens-new-line',
  112. logical: 'parens-new-line',
  113. prop: 'parens-new-line',
  114. },
  115. ],
  116. },
  117. };