-
Notifications
You must be signed in to change notification settings - Fork 0
/
index.js
executable file
·86 lines (84 loc) · 2.8 KB
/
index.js
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
82
83
84
85
86
const OFF = 0;
const WARNING = 1;
const ERROR = 2;
const config = {
env: {
browser: true,
es6: true,
},
extends: [
"airbnb-typescript",
"plugin:@typescript-eslint/recommended",
"@novatics-tools/eslint-config-react",
],
plugins: ["@typescript-eslint", "react", "jest"],
parser: "@typescript-eslint/parser",
rules: {
"react/prop-types": OFF,
// Remove regras de prop-types
"@typescript-eslint/no-unused-vars": ERROR,
// Variáveis que são declaradas e não usadas em nenhum lugar do código são provavelmente um erro devido à refatoração incompleta.
"@typescript-eslint/no-explicit-any": WARNING,
// Usar o any tipo anula o propósito de usar o TypeScript. Quando any é usado, todas as verificações de tipo de compilador em torno desse valor são ignoradas.
"@typescript-eslint/explicit-function-return-type": OFF,
// Isso garante que o valor de retorno seja atribuído a uma variável do tipo correto
"@typescript-eslint/explicit-member-accessibility": OFF,
// Deixar de lado o modificador de acessibilidade e tornar tudo público pode tornar sua interface difícil de usar por outras pessoas.
"@typescript-eslint/no-namespace": OFF,
// Módulos TypeScript personalizados ( module foo {}) e namespaces ( namespace foo {}) são considerados formas desatualizadas de organizar o código TypeScript.
"@typescript-eslint/explicit-module-boundary-types": OFF, // Tipos explícitos para valores de retorno de função e argumentos tornam claro para qualquer código de chamada qual é a entrada e saída do limite do módulo.
// ignore import com extensão explicita
"import/extensions": [
"error",
"ignorePackages",
{
js: "never",
jsx: "never",
ts: "never",
tsx: "never",
},
],
// Padronizar a declaração de interfaces, types e enums
"@typescript-eslint/naming-convention": [
ERROR,
{
selector: "interface",
format: ["StrictPascalCase"],
prefix: ["I"],
},
{
selector: ["typeAlias", "typeParameter"],
format: ["StrictPascalCase"],
prefix: ["T"],
},
{
selector: "enum",
format: ["StrictPascalCase"],
prefix: ["E"],
},
{
selector: ["variable"],
format: ["camelCase", "UPPER_CASE", "snake_case", "PascalCase"],
leadingUnderscore: "allow",
},
],
},
settings: {
react: {
version: "detect",
},
"import/parsers": {
"@typescript-eslint/parser": [".ts", ".tsx", ".jsx", ".js"],
},
"import/resolver": {
typescript: {
project: "./tsconfig.json",
node: {
paths: ["src"],
extensions: [".js", ".jsx", ".ts", ".tsx"],
},
},
},
},
};
module.exports = config;