@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 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': ESLint.Plugin;
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
@@ -21,7 +21,8 @@ const config = {
21
21
  sourceType: 'module'
22
22
  },
23
23
  linterOptions: {
24
- reportUnusedDisableDirectives: 'error'
24
+ reportUnusedDisableDirectives: 'error',
25
+ reportUnusedInlineConfigs: 'error'
25
26
  },
26
27
  plugins: {
27
28
  '@stylistic': stylistic,
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': import("eslint").ESLint.Plugin;
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>;
@@ -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': import("eslint").ESLint.Plugin;
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 type { ESLint } from 'eslint';
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: ESLint.Plugin;
14
- readonly 'react-hooks': ESLint.Plugin;
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: 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": "warn";
152
+ readonly "vitest/prefer-to-be-falsy": "off";
148
153
  readonly "vitest/prefer-to-be-object": "warn";
149
- readonly "vitest/prefer-to-be-truthy": "warn";
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.5.0",
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.13.0",
10
+ "@stylistic/eslint-plugin": "~4.2.0",
11
11
  "eslint-plugin-import": "~2.31.0",
12
- "eslint-plugin-jsdoc": "~50.6.1",
13
- "eslint-plugin-n": "~17.15.1",
14
- "globals": "^15.14.0"
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.13.0",
18
- "@eslint/js": "~9.18.0",
19
- "@types/node": "^22.10.6",
20
- "@vitest/eslint-plugin": "~1.1.24",
21
- "eslint": "~9.18.0",
22
- "eslint-import-resolver-typescript": "~3.7.0",
23
- "eslint-plugin-jest": "~28.10.0",
24
- "eslint-plugin-react": "~7.37.3",
25
- "eslint-plugin-react-hooks": "~5.1.0",
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.7.3",
29
- "typescript-eslint": "~8.20.0"
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.10",
68
- "eslint": "^9.11.1",
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",