-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path.eslintrc
81 lines (77 loc) · 4.78 KB
/
.eslintrc
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
{
"parser": "babel-eslint",
"parserOptions": {
"ecmaVersion": 7,
"ecmaFeatures": {
"jsx": true
}
},
"extends": "airbnb",
"env": {
"mocha": true,
"browser": true,
"node": false
},
"globals": {
"benchmark": true,
"chai": true,
"expect": true,
"geminiReact": true,
"React": true,
"suite": true,
"require": true,
"module": true // webpack hot loader
},
"rules": {
"max-len": ["error", 120, 4, {"ignoreComments": true}],
"arrow-parens": 0, //для удобной записи, где нужно реально показать что это параментр, чтобы не запутаться, и для случаев где не нужно оборачиваться в скобочки
"no-nested-ternary": 0, //в основном записи "? :" очень простые, в несколько строк для понятия, поэтому сложностей не вызывают
"no-multi-spaces": 0, //для красоты необходимо
"no-multiple-empty-lines": 0, //нужно для наглядного визуального разделения кусков кода
// "no-trailing-spaces": ["error", { "skipBlankLines": true }], //линии нужня для отделения логических кусков кода
"class-methods-use-this": 0, //иногда в рендерах не используется this, но в будущем может переделываться, поэтому нужно оставлять их не статиками
"arrow-body-style": 0, //методы render должны единообразно выглядеть, если даже в них один return
"key-spacing": ["error", { "mode": "minimum" }], //чтобы можно было выравнивать значение для визуального удобства
"prefer-arrow-callback": [ "error", { "allowNamedFunctions": true } ], // чтобы унифицировать и не потерять контекст (к примеру mocha describe it сделаем эту настройку)
"lines-between-class-members": 0, // стиль группировки
"implicit-arrow-linebreak": 0, // чтобы строчки разбивать по chain операциям
"import/no-named-as-default": 0, // неудобно, порой нужно называть функцию отдельно в экпорт и ту же в экспорт дефолт
"import/no-named-as-default-member": 0, // неудобно, порой нужно называть функцию отдельно в экпорт и ту же в экспорт дефолт
"global-require": 0, // require используется не в node а для webpack
"jsx-a11y/label-has-for": 0, // label for требует id, но в компонентах id очень редко бывают
"react/prefer-stateless-function": 0,
"react/react-in-jsx-scope": 0,
"react/jsx-indent-props": [2, 2],
"react/jsx-boolean-value": ["error", "always"],
"react/jsx-curly-spacing": [2, "always", {"spacing": {
"objectLiterals": "never"
}}], //чтобы в jsx были пробелы для наглядного расположения параметров
"react/forbid-prop-types": 0, // часто нужно обозначить мапу, а PropTypes.object запрещен
"react/sort-comp": 0, // мы утилиты распологаем над жизненным циклом, а он ругается
"react/require-default-props": 0, // не удобно все проставлять
"import/no-extraneous-dependencies": 0, // многие библиотеки есть в front-core но! // todo @ANKU @LOW @BUT_OUT - packageDir не работает на multiple, пока эта таска не заапрувится https://github.com/benmosher/eslint-plugin-import/pull/1104
"import/prefer-default-export": 0 //у нас другой стиль, не всегда есть default для единообразия
// //чтобы поддержать функциональность абсолютного импорта из-под src "import Test from 'components/Test'"
// "import/no-unresolved": 0,
// "import/extensions": 0,
// "import/no-extraneous-dependencies": 0,
//
// "no-tabs": 0,
// "object-curly-newline": [
// "error",
// {
// "ObjectExpression": { "minProperties": 2 },
// "ObjectPattern": "always"
// }
// ],
// "object-property-newline": "error",
// "indent": [
// "error",
// 2,
// {
// "ObjectExpression": 1
// }
// ]
// "react/jsx-one-expression-per-line": [<enabled>, { "allow": "none"|"literal"|"single-child" }]
}
}