@egy186/eslint-config 2.5.0 → 2.7.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/base.d.ts +5 -1
- package/dist/base.js +2 -1
- package/dist/browser.d.ts +5 -1
- package/dist/commonjs.d.ts +5 -1
- package/dist/react.d.ts +274 -3
- package/dist/react.js +1 -2
- package/dist/vitest.d.ts +13 -2
- package/dist/vitest.js +2 -0
- package/package.json +18 -18
package/dist/base.d.ts
CHANGED
|
@@ -144,9 +144,13 @@ declare const config: {
|
|
|
144
144
|
};
|
|
145
145
|
readonly linterOptions: {
|
|
146
146
|
readonly reportUnusedDisableDirectives: "error";
|
|
147
|
+
readonly reportUnusedInlineConfigs: "error";
|
|
147
148
|
};
|
|
148
149
|
readonly plugins: {
|
|
149
|
-
readonly '@stylistic':
|
|
150
|
+
readonly '@stylistic': {
|
|
151
|
+
rules: import("@stylistic/eslint-plugin").Rules;
|
|
152
|
+
configs: ESLint.Plugin["configs"] & import("@stylistic/eslint-plugin").Configs;
|
|
153
|
+
};
|
|
150
154
|
readonly import: ESLint.Plugin;
|
|
151
155
|
readonly jsdoc: ESLint.Plugin & {
|
|
152
156
|
configs: Record<`flat/${import("eslint-plugin-jsdoc").ConfigGroups}${import("eslint-plugin-jsdoc").ConfigVariants}${import("eslint-plugin-jsdoc").ErrorLevelVariants}`, import("eslint").Linter.Config>;
|
package/dist/base.js
CHANGED
package/dist/browser.d.ts
CHANGED
|
@@ -1705,9 +1705,13 @@ declare const config: {
|
|
|
1705
1705
|
readonly files: ["**/*.{js,jsx,mjs}", "**/*.{ts,tsx,mts}"];
|
|
1706
1706
|
readonly linterOptions: {
|
|
1707
1707
|
readonly reportUnusedDisableDirectives: "error";
|
|
1708
|
+
readonly reportUnusedInlineConfigs: "error";
|
|
1708
1709
|
};
|
|
1709
1710
|
readonly plugins: {
|
|
1710
|
-
readonly '@stylistic':
|
|
1711
|
+
readonly '@stylistic': {
|
|
1712
|
+
rules: import("@stylistic/eslint-plugin").Rules;
|
|
1713
|
+
configs: import("eslint").ESLint.Plugin["configs"] & import("@stylistic/eslint-plugin").Configs;
|
|
1714
|
+
};
|
|
1711
1715
|
readonly import: import("eslint").ESLint.Plugin;
|
|
1712
1716
|
readonly jsdoc: import("eslint").ESLint.Plugin & {
|
|
1713
1717
|
configs: Record<`flat/${import("eslint-plugin-jsdoc").ConfigGroups}${import("eslint-plugin-jsdoc").ConfigVariants}${import("eslint-plugin-jsdoc").ErrorLevelVariants}`, import("eslint").Linter.Config>;
|
package/dist/commonjs.d.ts
CHANGED
|
@@ -651,9 +651,13 @@ declare const config: {
|
|
|
651
651
|
};
|
|
652
652
|
readonly linterOptions: {
|
|
653
653
|
readonly reportUnusedDisableDirectives: "error";
|
|
654
|
+
readonly reportUnusedInlineConfigs: "error";
|
|
654
655
|
};
|
|
655
656
|
readonly plugins: {
|
|
656
|
-
readonly '@stylistic':
|
|
657
|
+
readonly '@stylistic': {
|
|
658
|
+
rules: import("@stylistic/eslint-plugin").Rules;
|
|
659
|
+
configs: import("eslint").ESLint.Plugin["configs"] & import("@stylistic/eslint-plugin").Configs;
|
|
660
|
+
};
|
|
657
661
|
readonly import: import("eslint").ESLint.Plugin;
|
|
658
662
|
readonly jsdoc: import("eslint").ESLint.Plugin & {
|
|
659
663
|
configs: Record<`flat/${import("eslint-plugin-jsdoc").ConfigGroups}${import("eslint-plugin-jsdoc").ConfigVariants}${import("eslint-plugin-jsdoc").ErrorLevelVariants}`, import("eslint").Linter.Config>;
|
package/dist/react.d.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
import
|
|
1
|
+
import react from 'eslint-plugin-react';
|
|
2
|
+
import reactHooksPlugin from 'eslint-plugin-react-hooks';
|
|
2
3
|
declare const config: {
|
|
3
4
|
readonly files: ["**/*.{jsx,tsx}"];
|
|
4
5
|
readonly languageOptions: {
|
|
@@ -10,8 +11,278 @@ declare const config: {
|
|
|
10
11
|
};
|
|
11
12
|
};
|
|
12
13
|
readonly plugins: {
|
|
13
|
-
readonly react:
|
|
14
|
-
|
|
14
|
+
readonly react: {
|
|
15
|
+
deprecatedRules: Partial<{
|
|
16
|
+
'boolean-prop-naming': import("eslint").Rule.RuleModule;
|
|
17
|
+
'button-has-type': import("eslint").Rule.RuleModule;
|
|
18
|
+
'checked-requires-onchange-or-readonly': import("eslint").Rule.RuleModule;
|
|
19
|
+
'default-props-match-prop-types': import("eslint").Rule.RuleModule;
|
|
20
|
+
'destructuring-assignment': import("eslint").Rule.RuleModule;
|
|
21
|
+
'display-name': import("eslint").Rule.RuleModule;
|
|
22
|
+
'forbid-component-props': import("eslint").Rule.RuleModule;
|
|
23
|
+
'forbid-dom-props': import("eslint").Rule.RuleModule;
|
|
24
|
+
'forbid-elements': import("eslint").Rule.RuleModule;
|
|
25
|
+
'forbid-foreign-prop-types': import("eslint").Rule.RuleModule;
|
|
26
|
+
'forbid-prop-types': import("eslint").Rule.RuleModule;
|
|
27
|
+
'forward-ref-uses-ref': import("eslint").Rule.RuleModule;
|
|
28
|
+
'function-component-definition': import("eslint").Rule.RuleModule;
|
|
29
|
+
'hook-use-state': import("eslint").Rule.RuleModule;
|
|
30
|
+
'iframe-missing-sandbox': import("eslint").Rule.RuleModule;
|
|
31
|
+
'jsx-boolean-value': import("eslint").Rule.RuleModule;
|
|
32
|
+
'jsx-child-element-spacing': import("eslint").Rule.RuleModule;
|
|
33
|
+
'jsx-closing-bracket-location': import("eslint").Rule.RuleModule;
|
|
34
|
+
'jsx-closing-tag-location': import("eslint").Rule.RuleModule;
|
|
35
|
+
'jsx-curly-spacing': import("eslint").Rule.RuleModule;
|
|
36
|
+
'jsx-curly-newline': import("eslint").Rule.RuleModule;
|
|
37
|
+
'jsx-equals-spacing': import("eslint").Rule.RuleModule;
|
|
38
|
+
'jsx-filename-extension': import("eslint").Rule.RuleModule;
|
|
39
|
+
'jsx-first-prop-new-line': import("eslint").Rule.RuleModule;
|
|
40
|
+
'jsx-handler-names': import("eslint").Rule.RuleModule;
|
|
41
|
+
'jsx-indent': import("eslint").Rule.RuleModule;
|
|
42
|
+
'jsx-indent-props': import("eslint").Rule.RuleModule;
|
|
43
|
+
'jsx-key': import("eslint").Rule.RuleModule;
|
|
44
|
+
'jsx-max-depth': import("eslint").Rule.RuleModule;
|
|
45
|
+
'jsx-max-props-per-line': import("eslint").Rule.RuleModule;
|
|
46
|
+
'jsx-newline': import("eslint").Rule.RuleModule;
|
|
47
|
+
'jsx-no-bind': import("eslint").Rule.RuleModule;
|
|
48
|
+
'jsx-no-comment-textnodes': import("eslint").Rule.RuleModule;
|
|
49
|
+
'jsx-no-constructed-context-values': import("eslint").Rule.RuleModule;
|
|
50
|
+
'jsx-no-duplicate-props': import("eslint").Rule.RuleModule;
|
|
51
|
+
'jsx-no-leaked-render': import("eslint").Rule.RuleModule;
|
|
52
|
+
'jsx-no-literals': import("eslint").Rule.RuleModule;
|
|
53
|
+
'jsx-no-script-url': import("eslint").Rule.RuleModule;
|
|
54
|
+
'jsx-no-target-blank': import("eslint").Rule.RuleModule;
|
|
55
|
+
'jsx-no-useless-fragment': import("eslint").Rule.RuleModule;
|
|
56
|
+
'jsx-one-expression-per-line': import("eslint").Rule.RuleModule;
|
|
57
|
+
'jsx-no-undef': import("eslint").Rule.RuleModule;
|
|
58
|
+
'jsx-curly-brace-presence': import("eslint").Rule.RuleModule;
|
|
59
|
+
'jsx-pascal-case': import("eslint").Rule.RuleModule;
|
|
60
|
+
'jsx-fragments': import("eslint").Rule.RuleModule;
|
|
61
|
+
'jsx-props-no-multi-spaces': import("eslint").Rule.RuleModule;
|
|
62
|
+
'jsx-props-no-spreading': import("eslint").Rule.RuleModule;
|
|
63
|
+
'jsx-props-no-spread-multi': import("eslint").Rule.RuleModule;
|
|
64
|
+
'jsx-sort-default-props': import("eslint").Rule.RuleModule;
|
|
65
|
+
'jsx-sort-props': import("eslint").Rule.RuleModule;
|
|
66
|
+
'jsx-space-before-closing': import("eslint").Rule.RuleModule;
|
|
67
|
+
'jsx-tag-spacing': import("eslint").Rule.RuleModule;
|
|
68
|
+
'jsx-uses-react': import("eslint").Rule.RuleModule;
|
|
69
|
+
'jsx-uses-vars': import("eslint").Rule.RuleModule;
|
|
70
|
+
'jsx-wrap-multilines': import("eslint").Rule.RuleModule;
|
|
71
|
+
'no-invalid-html-attribute': import("eslint").Rule.RuleModule;
|
|
72
|
+
'no-access-state-in-setstate': import("eslint").Rule.RuleModule;
|
|
73
|
+
'no-adjacent-inline-elements': import("eslint").Rule.RuleModule;
|
|
74
|
+
'no-array-index-key': import("eslint").Rule.RuleModule;
|
|
75
|
+
'no-arrow-function-lifecycle': import("eslint").Rule.RuleModule;
|
|
76
|
+
'no-children-prop': import("eslint").Rule.RuleModule;
|
|
77
|
+
'no-danger': import("eslint").Rule.RuleModule;
|
|
78
|
+
'no-danger-with-children': import("eslint").Rule.RuleModule;
|
|
79
|
+
'no-deprecated': import("eslint").Rule.RuleModule;
|
|
80
|
+
'no-did-mount-set-state': import("eslint").Rule.RuleModule;
|
|
81
|
+
'no-did-update-set-state': import("eslint").Rule.RuleModule;
|
|
82
|
+
'no-direct-mutation-state': import("eslint").Rule.RuleModule;
|
|
83
|
+
'no-find-dom-node': import("eslint").Rule.RuleModule;
|
|
84
|
+
'no-is-mounted': import("eslint").Rule.RuleModule;
|
|
85
|
+
'no-multi-comp': import("eslint").Rule.RuleModule;
|
|
86
|
+
'no-namespace': import("eslint").Rule.RuleModule;
|
|
87
|
+
'no-set-state': import("eslint").Rule.RuleModule;
|
|
88
|
+
'no-string-refs': import("eslint").Rule.RuleModule;
|
|
89
|
+
'no-redundant-should-component-update': import("eslint").Rule.RuleModule;
|
|
90
|
+
'no-render-return-value': import("eslint").Rule.RuleModule;
|
|
91
|
+
'no-this-in-sfc': import("eslint").Rule.RuleModule;
|
|
92
|
+
'no-typos': import("eslint").Rule.RuleModule;
|
|
93
|
+
'no-unescaped-entities': import("eslint").Rule.RuleModule;
|
|
94
|
+
'no-unknown-property': import("eslint").Rule.RuleModule;
|
|
95
|
+
'no-unsafe': import("eslint").Rule.RuleModule;
|
|
96
|
+
'no-unstable-nested-components': import("eslint").Rule.RuleModule;
|
|
97
|
+
'no-unused-class-component-methods': import("eslint").Rule.RuleModule;
|
|
98
|
+
'no-unused-prop-types': import("eslint").Rule.RuleModule;
|
|
99
|
+
'no-unused-state': import("eslint").Rule.RuleModule;
|
|
100
|
+
'no-object-type-as-default-prop': import("eslint").Rule.RuleModule;
|
|
101
|
+
'no-will-update-set-state': import("eslint").Rule.RuleModule;
|
|
102
|
+
'prefer-es6-class': import("eslint").Rule.RuleModule;
|
|
103
|
+
'prefer-exact-props': import("eslint").Rule.RuleModule;
|
|
104
|
+
'prefer-read-only-props': import("eslint").Rule.RuleModule;
|
|
105
|
+
'prefer-stateless-function': import("eslint").Rule.RuleModule;
|
|
106
|
+
'prop-types': import("eslint").Rule.RuleModule;
|
|
107
|
+
'react-in-jsx-scope': import("eslint").Rule.RuleModule;
|
|
108
|
+
'require-default-props': import("eslint").Rule.RuleModule;
|
|
109
|
+
'require-optimization': import("eslint").Rule.RuleModule;
|
|
110
|
+
'require-render-return': import("eslint").Rule.RuleModule;
|
|
111
|
+
'self-closing-comp': import("eslint").Rule.RuleModule;
|
|
112
|
+
'sort-comp': import("eslint").Rule.RuleModule;
|
|
113
|
+
'sort-default-props': import("eslint").Rule.RuleModule;
|
|
114
|
+
'sort-prop-types': import("eslint").Rule.RuleModule;
|
|
115
|
+
'state-in-constructor': import("eslint").Rule.RuleModule;
|
|
116
|
+
'static-property-placement': import("eslint").Rule.RuleModule;
|
|
117
|
+
'style-prop-object': import("eslint").Rule.RuleModule;
|
|
118
|
+
'void-dom-elements-no-children': import("eslint").Rule.RuleModule;
|
|
119
|
+
}>;
|
|
120
|
+
rules: {
|
|
121
|
+
'boolean-prop-naming': import("eslint").Rule.RuleModule;
|
|
122
|
+
'button-has-type': import("eslint").Rule.RuleModule;
|
|
123
|
+
'checked-requires-onchange-or-readonly': import("eslint").Rule.RuleModule;
|
|
124
|
+
'default-props-match-prop-types': import("eslint").Rule.RuleModule;
|
|
125
|
+
'destructuring-assignment': import("eslint").Rule.RuleModule;
|
|
126
|
+
'display-name': import("eslint").Rule.RuleModule;
|
|
127
|
+
'forbid-component-props': import("eslint").Rule.RuleModule;
|
|
128
|
+
'forbid-dom-props': import("eslint").Rule.RuleModule;
|
|
129
|
+
'forbid-elements': import("eslint").Rule.RuleModule;
|
|
130
|
+
'forbid-foreign-prop-types': import("eslint").Rule.RuleModule;
|
|
131
|
+
'forbid-prop-types': import("eslint").Rule.RuleModule;
|
|
132
|
+
'forward-ref-uses-ref': import("eslint").Rule.RuleModule;
|
|
133
|
+
'function-component-definition': import("eslint").Rule.RuleModule;
|
|
134
|
+
'hook-use-state': import("eslint").Rule.RuleModule;
|
|
135
|
+
'iframe-missing-sandbox': import("eslint").Rule.RuleModule;
|
|
136
|
+
'jsx-boolean-value': import("eslint").Rule.RuleModule;
|
|
137
|
+
'jsx-child-element-spacing': import("eslint").Rule.RuleModule;
|
|
138
|
+
'jsx-closing-bracket-location': import("eslint").Rule.RuleModule;
|
|
139
|
+
'jsx-closing-tag-location': import("eslint").Rule.RuleModule;
|
|
140
|
+
'jsx-curly-spacing': import("eslint").Rule.RuleModule;
|
|
141
|
+
'jsx-curly-newline': import("eslint").Rule.RuleModule;
|
|
142
|
+
'jsx-equals-spacing': import("eslint").Rule.RuleModule;
|
|
143
|
+
'jsx-filename-extension': import("eslint").Rule.RuleModule;
|
|
144
|
+
'jsx-first-prop-new-line': import("eslint").Rule.RuleModule;
|
|
145
|
+
'jsx-handler-names': import("eslint").Rule.RuleModule;
|
|
146
|
+
'jsx-indent': import("eslint").Rule.RuleModule;
|
|
147
|
+
'jsx-indent-props': import("eslint").Rule.RuleModule;
|
|
148
|
+
'jsx-key': import("eslint").Rule.RuleModule;
|
|
149
|
+
'jsx-max-depth': import("eslint").Rule.RuleModule;
|
|
150
|
+
'jsx-max-props-per-line': import("eslint").Rule.RuleModule;
|
|
151
|
+
'jsx-newline': import("eslint").Rule.RuleModule;
|
|
152
|
+
'jsx-no-bind': import("eslint").Rule.RuleModule;
|
|
153
|
+
'jsx-no-comment-textnodes': import("eslint").Rule.RuleModule;
|
|
154
|
+
'jsx-no-constructed-context-values': import("eslint").Rule.RuleModule;
|
|
155
|
+
'jsx-no-duplicate-props': import("eslint").Rule.RuleModule;
|
|
156
|
+
'jsx-no-leaked-render': import("eslint").Rule.RuleModule;
|
|
157
|
+
'jsx-no-literals': import("eslint").Rule.RuleModule;
|
|
158
|
+
'jsx-no-script-url': import("eslint").Rule.RuleModule;
|
|
159
|
+
'jsx-no-target-blank': import("eslint").Rule.RuleModule;
|
|
160
|
+
'jsx-no-useless-fragment': import("eslint").Rule.RuleModule;
|
|
161
|
+
'jsx-one-expression-per-line': import("eslint").Rule.RuleModule;
|
|
162
|
+
'jsx-no-undef': import("eslint").Rule.RuleModule;
|
|
163
|
+
'jsx-curly-brace-presence': import("eslint").Rule.RuleModule;
|
|
164
|
+
'jsx-pascal-case': import("eslint").Rule.RuleModule;
|
|
165
|
+
'jsx-fragments': import("eslint").Rule.RuleModule;
|
|
166
|
+
'jsx-props-no-multi-spaces': import("eslint").Rule.RuleModule;
|
|
167
|
+
'jsx-props-no-spreading': import("eslint").Rule.RuleModule;
|
|
168
|
+
'jsx-props-no-spread-multi': import("eslint").Rule.RuleModule;
|
|
169
|
+
'jsx-sort-default-props': import("eslint").Rule.RuleModule;
|
|
170
|
+
'jsx-sort-props': import("eslint").Rule.RuleModule;
|
|
171
|
+
'jsx-space-before-closing': import("eslint").Rule.RuleModule;
|
|
172
|
+
'jsx-tag-spacing': import("eslint").Rule.RuleModule;
|
|
173
|
+
'jsx-uses-react': import("eslint").Rule.RuleModule;
|
|
174
|
+
'jsx-uses-vars': import("eslint").Rule.RuleModule;
|
|
175
|
+
'jsx-wrap-multilines': import("eslint").Rule.RuleModule;
|
|
176
|
+
'no-invalid-html-attribute': import("eslint").Rule.RuleModule;
|
|
177
|
+
'no-access-state-in-setstate': import("eslint").Rule.RuleModule;
|
|
178
|
+
'no-adjacent-inline-elements': import("eslint").Rule.RuleModule;
|
|
179
|
+
'no-array-index-key': import("eslint").Rule.RuleModule;
|
|
180
|
+
'no-arrow-function-lifecycle': import("eslint").Rule.RuleModule;
|
|
181
|
+
'no-children-prop': import("eslint").Rule.RuleModule;
|
|
182
|
+
'no-danger': import("eslint").Rule.RuleModule;
|
|
183
|
+
'no-danger-with-children': import("eslint").Rule.RuleModule;
|
|
184
|
+
'no-deprecated': import("eslint").Rule.RuleModule;
|
|
185
|
+
'no-did-mount-set-state': import("eslint").Rule.RuleModule;
|
|
186
|
+
'no-did-update-set-state': import("eslint").Rule.RuleModule;
|
|
187
|
+
'no-direct-mutation-state': import("eslint").Rule.RuleModule;
|
|
188
|
+
'no-find-dom-node': import("eslint").Rule.RuleModule;
|
|
189
|
+
'no-is-mounted': import("eslint").Rule.RuleModule;
|
|
190
|
+
'no-multi-comp': import("eslint").Rule.RuleModule;
|
|
191
|
+
'no-namespace': import("eslint").Rule.RuleModule;
|
|
192
|
+
'no-set-state': import("eslint").Rule.RuleModule;
|
|
193
|
+
'no-string-refs': import("eslint").Rule.RuleModule;
|
|
194
|
+
'no-redundant-should-component-update': import("eslint").Rule.RuleModule;
|
|
195
|
+
'no-render-return-value': import("eslint").Rule.RuleModule;
|
|
196
|
+
'no-this-in-sfc': import("eslint").Rule.RuleModule;
|
|
197
|
+
'no-typos': import("eslint").Rule.RuleModule;
|
|
198
|
+
'no-unescaped-entities': import("eslint").Rule.RuleModule;
|
|
199
|
+
'no-unknown-property': import("eslint").Rule.RuleModule;
|
|
200
|
+
'no-unsafe': import("eslint").Rule.RuleModule;
|
|
201
|
+
'no-unstable-nested-components': import("eslint").Rule.RuleModule;
|
|
202
|
+
'no-unused-class-component-methods': import("eslint").Rule.RuleModule;
|
|
203
|
+
'no-unused-prop-types': import("eslint").Rule.RuleModule;
|
|
204
|
+
'no-unused-state': import("eslint").Rule.RuleModule;
|
|
205
|
+
'no-object-type-as-default-prop': import("eslint").Rule.RuleModule;
|
|
206
|
+
'no-will-update-set-state': import("eslint").Rule.RuleModule;
|
|
207
|
+
'prefer-es6-class': import("eslint").Rule.RuleModule;
|
|
208
|
+
'prefer-exact-props': import("eslint").Rule.RuleModule;
|
|
209
|
+
'prefer-read-only-props': import("eslint").Rule.RuleModule;
|
|
210
|
+
'prefer-stateless-function': import("eslint").Rule.RuleModule;
|
|
211
|
+
'prop-types': import("eslint").Rule.RuleModule;
|
|
212
|
+
'react-in-jsx-scope': import("eslint").Rule.RuleModule;
|
|
213
|
+
'require-default-props': import("eslint").Rule.RuleModule;
|
|
214
|
+
'require-optimization': import("eslint").Rule.RuleModule;
|
|
215
|
+
'require-render-return': import("eslint").Rule.RuleModule;
|
|
216
|
+
'self-closing-comp': import("eslint").Rule.RuleModule;
|
|
217
|
+
'sort-comp': import("eslint").Rule.RuleModule;
|
|
218
|
+
'sort-default-props': import("eslint").Rule.RuleModule;
|
|
219
|
+
'sort-prop-types': import("eslint").Rule.RuleModule;
|
|
220
|
+
'state-in-constructor': import("eslint").Rule.RuleModule;
|
|
221
|
+
'static-property-placement': import("eslint").Rule.RuleModule;
|
|
222
|
+
'style-prop-object': import("eslint").Rule.RuleModule;
|
|
223
|
+
'void-dom-elements-no-children': import("eslint").Rule.RuleModule;
|
|
224
|
+
};
|
|
225
|
+
configs: {
|
|
226
|
+
recommended: {
|
|
227
|
+
plugins: ["react"];
|
|
228
|
+
parserOptions: {
|
|
229
|
+
ecmaFeatures: {
|
|
230
|
+
jsx: boolean;
|
|
231
|
+
};
|
|
232
|
+
};
|
|
233
|
+
rules: {
|
|
234
|
+
"react/display-name": 2;
|
|
235
|
+
"react/jsx-key": 2;
|
|
236
|
+
"react/jsx-no-comment-textnodes": 2;
|
|
237
|
+
"react/jsx-no-duplicate-props": 2;
|
|
238
|
+
"react/jsx-no-target-blank": 2;
|
|
239
|
+
"react/jsx-no-undef": 2;
|
|
240
|
+
"react/jsx-uses-react": 2;
|
|
241
|
+
"react/jsx-uses-vars": 2;
|
|
242
|
+
"react/no-children-prop": 2;
|
|
243
|
+
"react/no-danger-with-children": 2;
|
|
244
|
+
"react/no-deprecated": 2;
|
|
245
|
+
"react/no-direct-mutation-state": 2;
|
|
246
|
+
"react/no-find-dom-node": 2;
|
|
247
|
+
"react/no-is-mounted": 2;
|
|
248
|
+
"react/no-render-return-value": 2;
|
|
249
|
+
"react/no-string-refs": 2;
|
|
250
|
+
"react/no-unescaped-entities": 2;
|
|
251
|
+
"react/no-unknown-property": 2;
|
|
252
|
+
"react/no-unsafe": 0;
|
|
253
|
+
"react/prop-types": 2;
|
|
254
|
+
"react/react-in-jsx-scope": 2;
|
|
255
|
+
"react/require-render-return": 2;
|
|
256
|
+
};
|
|
257
|
+
};
|
|
258
|
+
all: {
|
|
259
|
+
plugins: ["react"];
|
|
260
|
+
parserOptions: {
|
|
261
|
+
ecmaFeatures: {
|
|
262
|
+
jsx: boolean;
|
|
263
|
+
};
|
|
264
|
+
};
|
|
265
|
+
rules: Record<"boolean-prop-naming" | "button-has-type" | "checked-requires-onchange-or-readonly" | "default-props-match-prop-types" | "destructuring-assignment" | "display-name" | "forbid-component-props" | "forbid-dom-props" | "forbid-elements" | "forbid-foreign-prop-types" | "forbid-prop-types" | "prop-types" | "forward-ref-uses-ref" | "function-component-definition" | "hook-use-state" | "iframe-missing-sandbox" | "jsx-boolean-value" | "jsx-child-element-spacing" | "jsx-closing-bracket-location" | "jsx-closing-tag-location" | "jsx-curly-spacing" | "jsx-curly-newline" | "jsx-equals-spacing" | "jsx-filename-extension" | "jsx-first-prop-new-line" | "jsx-handler-names" | "jsx-indent" | "jsx-indent-props" | "jsx-key" | "jsx-max-depth" | "jsx-max-props-per-line" | "jsx-newline" | "jsx-no-bind" | "jsx-no-comment-textnodes" | "jsx-no-constructed-context-values" | "jsx-no-duplicate-props" | "jsx-no-leaked-render" | "jsx-no-literals" | "jsx-no-script-url" | "jsx-no-target-blank" | "jsx-no-useless-fragment" | "jsx-one-expression-per-line" | "jsx-no-undef" | "jsx-curly-brace-presence" | "jsx-pascal-case" | "jsx-fragments" | "jsx-props-no-multi-spaces" | "jsx-props-no-spreading" | "jsx-props-no-spread-multi" | "sort-default-props" | "jsx-sort-default-props" | "jsx-sort-props" | "jsx-tag-spacing" | "jsx-space-before-closing" | "jsx-uses-react" | "jsx-uses-vars" | "jsx-wrap-multilines" | "no-invalid-html-attribute" | "no-access-state-in-setstate" | "no-adjacent-inline-elements" | "no-array-index-key" | "no-arrow-function-lifecycle" | "no-children-prop" | "no-danger" | "no-danger-with-children" | "no-deprecated" | "no-direct-mutation-state" | "no-find-dom-node" | "no-is-mounted" | "no-multi-comp" | "no-namespace" | "no-set-state" | "no-string-refs" | "no-redundant-should-component-update" | "no-render-return-value" | "no-this-in-sfc" | "no-typos" | "no-unescaped-entities" | "no-unknown-property" | "no-unsafe" | "no-unstable-nested-components" | "no-unused-class-component-methods" | "no-unused-prop-types" | "no-unused-state" | "no-object-type-as-default-prop" | "prefer-es6-class" | "prefer-exact-props" | "prefer-read-only-props" | "prefer-stateless-function" | "react-in-jsx-scope" | "require-default-props" | "require-optimization" | "require-render-return" | "self-closing-comp" | "sort-comp" | "sort-prop-types" | "state-in-constructor" | "static-property-placement" | "style-prop-object" | "void-dom-elements-no-children" | "no-did-mount-set-state" | "no-did-update-set-state" | "no-will-update-set-state", 2 | "error">;
|
|
266
|
+
};
|
|
267
|
+
'jsx-runtime': {
|
|
268
|
+
plugins: ["react"];
|
|
269
|
+
parserOptions: {
|
|
270
|
+
ecmaFeatures: {
|
|
271
|
+
jsx: boolean;
|
|
272
|
+
};
|
|
273
|
+
jsxPragma: any;
|
|
274
|
+
};
|
|
275
|
+
rules: {
|
|
276
|
+
"react/react-in-jsx-scope": 0;
|
|
277
|
+
"react/jsx-uses-react": 0;
|
|
278
|
+
};
|
|
279
|
+
};
|
|
280
|
+
flat: Record<string, react.ReactFlatConfig>;
|
|
281
|
+
} & {
|
|
282
|
+
flat: Record<string, react.ReactFlatConfig>;
|
|
283
|
+
};
|
|
284
|
+
};
|
|
285
|
+
readonly 'react-hooks': typeof reactHooksPlugin;
|
|
15
286
|
};
|
|
16
287
|
readonly rules: {
|
|
17
288
|
readonly 'react-hooks/exhaustive-deps': "error";
|
package/dist/react.js
CHANGED
|
@@ -1,5 +1,4 @@
|
|
|
1
1
|
import react from 'eslint-plugin-react';
|
|
2
|
-
// @ts-expect-error TS7016
|
|
3
2
|
import reactHooksPlugin from 'eslint-plugin-react-hooks';
|
|
4
3
|
const config = {
|
|
5
4
|
files: ['**/*.{jsx,tsx}'],
|
|
@@ -10,7 +9,7 @@ const config = {
|
|
|
10
9
|
}
|
|
11
10
|
},
|
|
12
11
|
plugins: {
|
|
13
|
-
react
|
|
12
|
+
react,
|
|
14
13
|
'react-hooks': reactHooksPlugin
|
|
15
14
|
},
|
|
16
15
|
rules: {
|
package/dist/vitest.d.ts
CHANGED
|
@@ -69,6 +69,8 @@ declare const config: {
|
|
|
69
69
|
"padding-around-expect-groups": import("eslint").Rule.RuleModule;
|
|
70
70
|
"padding-around-test-blocks": import("eslint").Rule.RuleModule;
|
|
71
71
|
"valid-expect-in-promise": import("eslint").Rule.RuleModule;
|
|
72
|
+
"prefer-strict-boolean-matchers": import("eslint").Rule.RuleModule;
|
|
73
|
+
"require-mock-type-parameters": import("eslint").Rule.RuleModule;
|
|
72
74
|
};
|
|
73
75
|
environments: {
|
|
74
76
|
env: {
|
|
@@ -81,6 +83,7 @@ declare const config: {
|
|
|
81
83
|
assertType: true;
|
|
82
84
|
expect: true;
|
|
83
85
|
assert: true;
|
|
86
|
+
chai: true;
|
|
84
87
|
vitest: true;
|
|
85
88
|
vi: true;
|
|
86
89
|
beforeAll: true;
|
|
@@ -102,6 +105,7 @@ declare const config: {
|
|
|
102
105
|
rules: {};
|
|
103
106
|
};
|
|
104
107
|
recommended: {
|
|
108
|
+
name: string;
|
|
105
109
|
plugins: {
|
|
106
110
|
readonly vitest: import("eslint").ESLint.Plugin;
|
|
107
111
|
};
|
|
@@ -117,6 +121,7 @@ declare const config: {
|
|
|
117
121
|
};
|
|
118
122
|
};
|
|
119
123
|
all: {
|
|
124
|
+
name: string;
|
|
120
125
|
plugins: {
|
|
121
126
|
readonly vitest: import("eslint").ESLint.Plugin;
|
|
122
127
|
};
|
|
@@ -144,9 +149,9 @@ declare const config: {
|
|
|
144
149
|
readonly "vitest/no-test-prefixes": "warn";
|
|
145
150
|
readonly "vitest/no-test-return-statement": "warn";
|
|
146
151
|
readonly "vitest/prefer-called-with": "warn";
|
|
147
|
-
readonly "vitest/prefer-to-be-falsy": "
|
|
152
|
+
readonly "vitest/prefer-to-be-falsy": "off";
|
|
148
153
|
readonly "vitest/prefer-to-be-object": "warn";
|
|
149
|
-
readonly "vitest/prefer-to-be-truthy": "
|
|
154
|
+
readonly "vitest/prefer-to-be-truthy": "off";
|
|
150
155
|
readonly "vitest/prefer-to-have-length": "warn";
|
|
151
156
|
readonly "vitest/prefer-equality-matcher": "warn";
|
|
152
157
|
readonly "vitest/prefer-strict-equal": "warn";
|
|
@@ -183,9 +188,12 @@ declare const config: {
|
|
|
183
188
|
readonly "vitest/valid-describe-callback": "warn";
|
|
184
189
|
readonly "vitest/require-local-test-context-for-concurrent-snapshots": "warn";
|
|
185
190
|
readonly "vitest/no-import-node-test": "warn";
|
|
191
|
+
readonly "vitest/prefer-strict-boolean-matchers": "warn";
|
|
192
|
+
readonly "vitest/require-mock-type-parameters": "warn";
|
|
186
193
|
};
|
|
187
194
|
};
|
|
188
195
|
env: {
|
|
196
|
+
name: string;
|
|
189
197
|
languageOptions: {
|
|
190
198
|
globals: {
|
|
191
199
|
suite: "writable";
|
|
@@ -196,6 +204,7 @@ declare const config: {
|
|
|
196
204
|
assertType: "writable";
|
|
197
205
|
expect: "writable";
|
|
198
206
|
assert: "writable";
|
|
207
|
+
chai: "writable";
|
|
199
208
|
vitest: "writable";
|
|
200
209
|
vi: "writable";
|
|
201
210
|
beforeAll: "writable";
|
|
@@ -262,6 +271,7 @@ declare const config: {
|
|
|
262
271
|
readonly 'vitest/prefer-mock-promise-shorthand': "error";
|
|
263
272
|
readonly 'vitest/prefer-snapshot-hint': "error";
|
|
264
273
|
readonly 'vitest/prefer-spy-on': "error";
|
|
274
|
+
readonly 'vitest/prefer-strict-boolean-matchers': "error";
|
|
265
275
|
readonly 'vitest/prefer-strict-equal': "error";
|
|
266
276
|
readonly 'vitest/prefer-to-be': "error";
|
|
267
277
|
readonly 'vitest/prefer-to-be-falsy': "off";
|
|
@@ -273,6 +283,7 @@ declare const config: {
|
|
|
273
283
|
readonly 'vitest/prefer-vi-mocked': "error";
|
|
274
284
|
readonly 'vitest/require-hook': "error";
|
|
275
285
|
readonly 'vitest/require-local-test-context-for-concurrent-snapshots': "error";
|
|
286
|
+
readonly 'vitest/require-mock-type-parameters': "error";
|
|
276
287
|
readonly 'vitest/require-to-throw-message': "error";
|
|
277
288
|
readonly 'vitest/require-top-level-describe': "error";
|
|
278
289
|
readonly 'vitest/valid-describe-callback': "error";
|
package/dist/vitest.js
CHANGED
|
@@ -55,6 +55,7 @@ const config = {
|
|
|
55
55
|
'vitest/prefer-mock-promise-shorthand': 'error',
|
|
56
56
|
'vitest/prefer-snapshot-hint': 'error',
|
|
57
57
|
'vitest/prefer-spy-on': 'error',
|
|
58
|
+
'vitest/prefer-strict-boolean-matchers': 'error',
|
|
58
59
|
'vitest/prefer-strict-equal': 'error',
|
|
59
60
|
'vitest/prefer-to-be': 'error',
|
|
60
61
|
'vitest/prefer-to-be-falsy': 'off',
|
|
@@ -66,6 +67,7 @@ const config = {
|
|
|
66
67
|
'vitest/prefer-vi-mocked': 'error',
|
|
67
68
|
'vitest/require-hook': 'error',
|
|
68
69
|
'vitest/require-local-test-context-for-concurrent-snapshots': 'error',
|
|
70
|
+
'vitest/require-mock-type-parameters': 'error',
|
|
69
71
|
'vitest/require-to-throw-message': 'error',
|
|
70
72
|
'vitest/require-top-level-describe': 'error',
|
|
71
73
|
'vitest/valid-describe-callback': 'error',
|
package/package.json
CHANGED
|
@@ -1,32 +1,32 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@egy186/eslint-config",
|
|
3
3
|
"description": "Eslint shareable config",
|
|
4
|
-
"version": "2.
|
|
4
|
+
"version": "2.7.0",
|
|
5
5
|
"author": "egy186",
|
|
6
6
|
"bugs": {
|
|
7
7
|
"url": "https://github.com/egy186/eslint-config/issues"
|
|
8
8
|
},
|
|
9
9
|
"dependencies": {
|
|
10
|
-
"@stylistic/eslint-plugin": "~2.
|
|
10
|
+
"@stylistic/eslint-plugin": "~4.2.0",
|
|
11
11
|
"eslint-plugin-import": "~2.31.0",
|
|
12
|
-
"eslint-plugin-jsdoc": "~50.6.
|
|
13
|
-
"eslint-plugin-n": "~17.
|
|
14
|
-
"globals": "^
|
|
12
|
+
"eslint-plugin-jsdoc": "~50.6.6",
|
|
13
|
+
"eslint-plugin-n": "~17.16.2",
|
|
14
|
+
"globals": "^16.0.0"
|
|
15
15
|
},
|
|
16
16
|
"devDependencies": {
|
|
17
|
-
"@eslint-stylistic/metadata": "~2.
|
|
18
|
-
"@eslint/js": "~9.
|
|
19
|
-
"@types/node": "^22.10
|
|
20
|
-
"@vitest/eslint-plugin": "~1.1.
|
|
21
|
-
"eslint": "~9.
|
|
22
|
-
"eslint-import-resolver-typescript": "~3.7
|
|
23
|
-
"eslint-plugin-jest": "~28.
|
|
24
|
-
"eslint-plugin-react": "~7.37.
|
|
25
|
-
"eslint-plugin-react-hooks": "~5.
|
|
17
|
+
"@eslint-stylistic/metadata": "~4.2.0",
|
|
18
|
+
"@eslint/js": "~9.22.0",
|
|
19
|
+
"@types/node": "^22.13.10",
|
|
20
|
+
"@vitest/eslint-plugin": "~1.1.37",
|
|
21
|
+
"eslint": "~9.22.0",
|
|
22
|
+
"eslint-import-resolver-typescript": "~3.8.7",
|
|
23
|
+
"eslint-plugin-jest": "~28.11.0",
|
|
24
|
+
"eslint-plugin-react": "~7.37.4",
|
|
25
|
+
"eslint-plugin-react-hooks": "~5.2.0",
|
|
26
26
|
"husky": "^9.1.7",
|
|
27
27
|
"jiti": "^2.4.2",
|
|
28
|
-
"typescript": "~5.
|
|
29
|
-
"typescript-eslint": "~8.
|
|
28
|
+
"typescript": "~5.8.2",
|
|
29
|
+
"typescript-eslint": "~8.26.1"
|
|
30
30
|
},
|
|
31
31
|
"engines": {
|
|
32
32
|
"node": ">=18.18.0"
|
|
@@ -64,8 +64,8 @@
|
|
|
64
64
|
"license": "MIT",
|
|
65
65
|
"main": "./dist/index.js",
|
|
66
66
|
"peerDependencies": {
|
|
67
|
-
"@vitest/eslint-plugin": "^1.1.
|
|
68
|
-
"eslint": "^9.
|
|
67
|
+
"@vitest/eslint-plugin": "^1.1.37",
|
|
68
|
+
"eslint": "^9.19.0",
|
|
69
69
|
"eslint-import-resolver-typescript": "^3.6.1",
|
|
70
70
|
"eslint-plugin-jest": "^28.8.3",
|
|
71
71
|
"eslint-plugin-react": "^7.36.1",
|