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
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
|
/** @type {import('eslint').Linter.Config} */
module.exports = {
root: true,
parserOptions: {
ecmaFeatures: {
jsx: true,
},
ecmaVersion: 'latest',
sourceType: 'module',
project: './tsconfig.json',
},
ignorePatterns: ['node_modules', 'build', 'recipes'],
extends: [
'airbnb',
'plugin:react/jsx-runtime',
'plugin:jest/recommended',
'plugin:unicorn/recommended',
'plugin:sonar/recommended',
'plugin:prettier/recommended',
],
plugins: ['jest'],
settings: {
react: {
pragma: 'React', // Pragma to use, default to "React"
version: 'detect', // React version. "detect" automatically picks the version you have installed.
},
},
globals: {
use: true,
},
env: {
browser: true,
es2024: true,
node: true,
jest: true,
},
reportUnusedDisableDirectives: true,
overrides: [
{
files: ['**/*.ts', '**/*.tsx'],
extends: [
'airbnb-typescript',
'plugin:@typescript-eslint/eslint-recommended',
'plugin:@typescript-eslint/strict',
// TODO: Opt-in to a stricter ruleset in the future
// 'plugin:@typescript-eslint/strict-type-checked',
'plugin:@typescript-eslint/stylistic-type-checked',
],
parser: '@typescript-eslint/parser',
plugins: [],
rules: {
// eslint
'no-use-before-define': 2,
// @typescript-eslint
// This is necessary as workaround for window.ferdium vs window['ferdium']
'@typescript-eslint/dot-notation': 0,
'@typescript-eslint/indent': 0,
'@typescript-eslint/no-shadow': 0,
'@typescript-eslint/no-var-requires': 0,
'@typescript-eslint/no-explicit-any': 0,
'@typescript-eslint/no-inferrable-types': 0,
'@typescript-eslint/no-non-null-assertion': 0,
'@typescript-eslint/prefer-nullish-coalescing': 0,
'@typescript-eslint/consistent-indexed-object-style': 0,
'@typescript-eslint/consistent-type-assertions': 0,
'@typescript-eslint/consistent-type-definitions': 0,
'@typescript-eslint/no-empty-interface': 0,
// eslint-plugin-import
'import/no-extraneous-dependencies': 0,
},
},
],
rules: {
// eslint
'array-callback-return': 1,
'class-methods-use-this': 0,
'consistent-return': 1,
'no-await-in-loop': 1,
'no-return-assign': 1,
'no-console': [
1,
{
allow: ['warn', 'error'],
},
],
'no-param-reassign': 1,
'no-restricted-syntax': 0,
'no-underscore-dangle': 0,
'prefer-destructuring': 1,
// eslint-plugin-import
'import/extensions': 0,
'import/prefer-default-export': 0,
'import/no-unresolved': 0,
'import/no-cycle': 1,
'import/no-extraneous-dependencies': 0,
// eslint-plugin-react
'react/forbid-prop-types': 1,
'react/destructuring-assignment': 0,
'react/jsx-filename-extension': 1,
'react/jsx-no-bind': 1,
'react/jsx-props-no-spreading': 0,
'react/prefer-stateless-function': 1,
'react/static-property-placement': 0,
'react/state-in-constructor': 1,
'react/sort-comp': 0,
'react/function-component-definition': 0,
'react/default-props-match-prop-types': 0,
'react/require-default-props': 0,
'react/no-unused-prop-types': 1,
'react/no-deprecated': 1,
// eslint-plugin-jsx-a11y
'jsx-a11y/click-events-have-key-events': 1,
'jsx-a11y/no-static-element-interactions': 1,
'jsx-a11y/no-noninteractive-element-interactions': 1,
'jsx-a11y/label-has-for': [
2,
{
components: ['Label'],
required: {
every: ['id'],
},
allowChildren: false,
},
],
'jsx-a11y/control-has-associated-label': 0,
// eslint-plugin-unicorn
'unicorn/filename-case': 0,
'unicorn/no-null': 0,
'unicorn/prefer-module': 0,
'unicorn/prevent-abbreviations': 0,
'unicorn/import-style': [
2,
{
styles: {
path: {
named: true,
},
},
},
],
'unicorn/consistent-destructuring': 0,
// eslint-plugin-sonar
'sonar/function-name': 0,
},
};
|