.eslintrc.js 3.5 KB

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