@alexlit/lint-kit 176.0.1 → 177.0.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.
Files changed (293) hide show
  1. package/package.json +1 -1
  2. package/packages/config-stylelint/package.json +5 -5
  3. package/packages/config-stylelint/plugins/color-format.js +1 -5
  4. package/packages/config-stylelint/plugins/logical-css.js +1 -4
  5. package/packages/config-eslint/node_modules/@eslint/core/LICENSE +0 -201
  6. package/packages/config-eslint/node_modules/@eslint/core/README.md +0 -29
  7. package/packages/config-eslint/node_modules/@eslint/core/dist/cjs/types.d.cts +0 -1179
  8. package/packages/config-eslint/node_modules/@eslint/core/dist/esm/types.d.ts +0 -1179
  9. package/packages/config-eslint/node_modules/@eslint/core/package.json +0 -49
  10. package/packages/config-eslint/node_modules/@eslint/plugin-kit/LICENSE +0 -201
  11. package/packages/config-eslint/node_modules/@eslint/plugin-kit/README.md +0 -273
  12. package/packages/config-eslint/node_modules/@eslint/plugin-kit/dist/cjs/index.cjs +0 -884
  13. package/packages/config-eslint/node_modules/@eslint/plugin-kit/dist/cjs/index.d.cts +0 -328
  14. package/packages/config-eslint/node_modules/@eslint/plugin-kit/dist/cjs/types.cts +0 -7
  15. package/packages/config-eslint/node_modules/@eslint/plugin-kit/dist/esm/index.d.ts +0 -328
  16. package/packages/config-eslint/node_modules/@eslint/plugin-kit/dist/esm/index.js +0 -879
  17. package/packages/config-eslint/node_modules/@eslint/plugin-kit/dist/esm/types.d.ts +0 -6
  18. package/packages/config-eslint/node_modules/@eslint/plugin-kit/dist/esm/types.ts +0 -7
  19. package/packages/config-eslint/node_modules/@eslint/plugin-kit/package.json +0 -61
  20. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/configs/flat-config-base.js +0 -9
  21. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/index.d.ts +0 -17
  22. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/index.js +0 -91
  23. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/license +0 -9
  24. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/node_modules/globals/globals.json +0 -3345
  25. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/node_modules/globals/index.d.ts +0 -3452
  26. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/node_modules/globals/index.js +0 -2
  27. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/node_modules/globals/license +0 -9
  28. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/node_modules/globals/package.json +0 -117
  29. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/node_modules/globals/readme.md +0 -42
  30. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/package.json +0 -128
  31. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/readme.md +0 -261
  32. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/call-or-new-expression.js +0 -120
  33. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/function-types.js +0 -7
  34. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/index.js +0 -30
  35. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-arrow-function-body.js +0 -3
  36. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-directive.js +0 -4
  37. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-empty-array-expression.js +0 -5
  38. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-empty-node.js +0 -17
  39. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-expression-statement.js +0 -7
  40. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-function.js +0 -5
  41. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-member-expression.js +0 -98
  42. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-method-call.js +0 -62
  43. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-negative-one.js +0 -8
  44. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-reference-identifier.js +0 -159
  45. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-static-require.js +0 -10
  46. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-tagged-template-literal.js +0 -24
  47. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/is-undefined.js +0 -3
  48. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/ast/literal.js +0 -24
  49. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/better-regex.js +0 -146
  50. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/catch-error-name.js +0 -138
  51. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/consistent-assert.js +0 -98
  52. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/consistent-date-clone.js +0 -54
  53. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/consistent-destructuring.js +0 -168
  54. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/consistent-empty-array-spread.js +0 -127
  55. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/consistent-existence-index-check.js +0 -137
  56. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/consistent-function-scoping.js +0 -265
  57. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/custom-error-definition.js +0 -218
  58. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/empty-brace-spaces.js +0 -62
  59. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/error-message.js +0 -98
  60. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/escape-case.js +0 -86
  61. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/expiring-todo-comments.js +0 -584
  62. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/explicit-length-check.js +0 -236
  63. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/filename-case.js +0 -276
  64. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/add-parenthesizes-to-return-or-throw-expression.js +0 -29
  65. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/append-argument.js +0 -30
  66. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/extend-fix-range.js +0 -11
  67. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/fix-space-around-keywords.js +0 -43
  68. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/index.js +0 -23
  69. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/remove-argument.js +0 -40
  70. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/remove-expression-statement.js +0 -34
  71. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/remove-method-call.js +0 -28
  72. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/remove-object-property.js +0 -21
  73. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/remove-parentheses.js +0 -19
  74. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/remove-spaces-after.js +0 -22
  75. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/remove-specifier.js +0 -59
  76. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/rename-variable.js +0 -8
  77. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/replace-argument.js +0 -17
  78. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/replace-member-expression-property.js +0 -25
  79. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/replace-node-or-token-and-spaces-before.js +0 -31
  80. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/replace-reference-identifier.js +0 -32
  81. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/replace-string-raw.js +0 -12
  82. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/replace-template-element.js +0 -10
  83. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/switch-call-expression-to-new-expression.js +0 -29
  84. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/fix/switch-new-expression-to-call-expression.js +0 -42
  85. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/import-style.js +0 -375
  86. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/index.js +0 -143
  87. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/new-for-builtins.js +0 -112
  88. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-abusive-eslint-disable.js +0 -63
  89. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-accessor-recursion.js +0 -160
  90. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-anonymous-default-export.js +0 -210
  91. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-array-callback-reference.js +0 -285
  92. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-array-for-each.js +0 -496
  93. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-array-method-this-argument.js +0 -223
  94. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-array-reduce.js +0 -128
  95. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-array-reverse.js +0 -6
  96. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-array-sort.js +0 -6
  97. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-await-expression-member.js +0 -85
  98. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-await-in-promise-methods.js +0 -69
  99. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-console-spaces.js +0 -89
  100. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-document-cookie.js +0 -27
  101. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-empty-file.js +0 -58
  102. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-for-loop.js +0 -419
  103. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-hex-escape.js +0 -54
  104. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-immediate-mutation.js +0 -778
  105. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-instanceof-builtins.js +0 -216
  106. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-invalid-fetch-options.js +0 -112
  107. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-invalid-remove-event-listener.js +0 -61
  108. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-keyword-prefix.js +0 -202
  109. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-lonely-if.js +0 -155
  110. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-magic-array-flat-depth.js +0 -55
  111. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-named-default.js +0 -101
  112. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-negated-condition.js +0 -145
  113. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-negation-in-equality-check.js +0 -99
  114. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-nested-ternary.js +0 -60
  115. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-new-array.js +0 -106
  116. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-new-buffer.js +0 -100
  117. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-null.js +0 -153
  118. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-object-as-default-parameter.js +0 -52
  119. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-process-exit.js +0 -106
  120. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-single-promise-in-promise-methods.js +0 -179
  121. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-static-only-class.js +0 -226
  122. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-thenable.js +0 -194
  123. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-this-assignment.js +0 -40
  124. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-typeof-undefined.js +0 -146
  125. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-unnecessary-array-flat-depth.js +0 -49
  126. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-unnecessary-array-splice-count.js +0 -23
  127. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-unnecessary-await.js +0 -110
  128. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-unnecessary-polyfills.js +0 -174
  129. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-unnecessary-slice-end.js +0 -22
  130. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-unreadable-array-destructuring.js +0 -85
  131. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-unreadable-iife.js +0 -43
  132. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-unused-properties.js +0 -240
  133. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-useless-collection-argument.js +0 -101
  134. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-useless-error-capture-stack-trace.js +0 -146
  135. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-useless-fallback-in-spread.js +0 -66
  136. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-useless-length-check.js +0 -150
  137. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-useless-promise-resolve-reject.js +0 -210
  138. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-useless-spread.js +0 -389
  139. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-useless-switch-case.js +0 -59
  140. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-useless-undefined.js +0 -275
  141. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/no-zero-fractions.js +0 -81
  142. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/number-literal-case.js +0 -82
  143. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/numeric-separators-style.js +0 -189
  144. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-add-event-listener.js +0 -191
  145. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-array-find.js +0 -458
  146. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-array-flat-map.js +0 -86
  147. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-array-flat.js +0 -279
  148. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-array-index-of.js +0 -34
  149. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-array-some.js +0 -219
  150. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-at.js +0 -380
  151. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-bigint-literals.js +0 -129
  152. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-blob-reading-methods.js +0 -47
  153. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-class-fields.js +0 -158
  154. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-classlist-toggle.js +0 -255
  155. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-code-point.js +0 -56
  156. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-date-now.js +0 -133
  157. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-default-parameters.js +0 -218
  158. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-dom-node-append.js +0 -50
  159. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-dom-node-dataset.js +0 -135
  160. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-dom-node-remove.js +0 -124
  161. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-dom-node-text-content.js +0 -77
  162. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-event-target.js +0 -119
  163. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-export-from.js +0 -367
  164. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-global-this.js +0 -222
  165. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-import-meta-properties.js +0 -320
  166. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-includes.js +0 -111
  167. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-json-parse-buffer.js +0 -161
  168. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-keyboard-event-key.js +0 -188
  169. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-logical-operator-over-ternary.js +0 -162
  170. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-math-min-max.js +0 -205
  171. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-math-trunc.js +0 -111
  172. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-modern-dom-apis.js +0 -145
  173. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-modern-math-apis.js +0 -210
  174. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-module.js +0 -377
  175. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-native-coercion-functions.js +0 -187
  176. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-negative-index.js +0 -211
  177. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-node-protocol.js +0 -86
  178. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-number-properties.js +0 -142
  179. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-object-from-entries.js +0 -256
  180. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-optional-catch-binding.js +0 -77
  181. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-prototype-methods.js +0 -162
  182. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-query-selector.js +0 -170
  183. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-reflect-apply.js +0 -99
  184. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-regexp-test.js +0 -155
  185. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-response-static-json.js +0 -85
  186. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-set-has.js +0 -181
  187. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-set-size.js +0 -106
  188. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-single-call.js +0 -188
  189. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-spread.js +0 -521
  190. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-string-raw.js +0 -149
  191. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-string-replace-all.js +0 -180
  192. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-string-slice.js +0 -180
  193. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-string-starts-ends-with.js +0 -201
  194. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-string-trim-start-end.js +0 -46
  195. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-structured-clone.js +0 -149
  196. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-switch.js +0 -357
  197. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-ternary.js +0 -288
  198. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-top-level-await.js +0 -154
  199. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prefer-type-error.js +0 -169
  200. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/prevent-abbreviations.js +0 -655
  201. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/relative-url-style.js +0 -171
  202. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/require-array-join-separator.js +0 -65
  203. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/require-module-attributes.js +0 -120
  204. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/require-module-specifiers.js +0 -158
  205. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/require-number-to-fixed-digits-argument.js +0 -55
  206. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/require-post-message-target-origin.js +0 -74
  207. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/rule/get-documentation-url.js +0 -9
  208. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/rule/index.js +0 -9
  209. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/rule/to-eslint-create.js +0 -51
  210. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/rule/to-eslint-listener.js +0 -40
  211. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/rule/to-eslint-problem.js +0 -38
  212. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/rule/to-eslint-rule-fixer.js +0 -49
  213. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/rule/to-eslint-rule.js +0 -38
  214. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/rule/to-eslint-rules.js +0 -13
  215. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/rule/unicorn-context.js +0 -36
  216. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/rule/unicorn-listeners.js +0 -65
  217. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/rule/utilities.js +0 -27
  218. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/shared/abbreviations.js +0 -270
  219. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/shared/builtin-errors.js +0 -14
  220. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/shared/dom-events.js +0 -275
  221. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/shared/event-keys.js +0 -54
  222. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/shared/negative-index.js +0 -52
  223. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/shared/no-array-mutate-rule.js +0 -139
  224. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/shared/no-unnecessary-length-or-infinity-rule.js +0 -80
  225. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/shared/package-json.js +0 -42
  226. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/shared/simple-array-search-rule.js +0 -126
  227. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/shared/typed-array.js +0 -17
  228. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/string-content.js +0 -192
  229. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/switch-case-braces.js +0 -114
  230. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/template-indent.js +0 -219
  231. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/text-encoding-identifier-case.js +0 -130
  232. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/throw-new-error.js +0 -60
  233. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/array-or-object-prototype-property.js +0 -57
  234. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/assert-token.js +0 -29
  235. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/boolean.js +0 -88
  236. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/builtins.js +0 -30
  237. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/cartesian-product-samples.js +0 -22
  238. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/create-deprecated-rules.js +0 -29
  239. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/escape-string.js +0 -24
  240. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/escape-template-element-raw.js +0 -6
  241. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-ancestor.js +0 -15
  242. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-available-variable-name.js +0 -147
  243. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-builtin-rule.js +0 -5
  244. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-call-expression-arguments-text.js +0 -36
  245. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-call-or-new-expression-tokens.js +0 -67
  246. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-class-head-location.js +0 -22
  247. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-documentation-url.js +0 -9
  248. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-indent-string.js +0 -18
  249. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-references.js +0 -5
  250. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-scopes.js +0 -12
  251. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-sibling-node.js +0 -38
  252. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-switch-case-head-location.js +0 -22
  253. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-token-store.js +0 -24
  254. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/get-variable-identifiers.js +0 -7
  255. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/global-reference-tracker.js +0 -68
  256. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/has-optional-chain-element.js +0 -17
  257. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/has-same-range.js +0 -7
  258. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/index.js +0 -59
  259. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-function-self-used-inside.js +0 -39
  260. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-left-hand-side.js +0 -20
  261. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-logical-expression.js +0 -14
  262. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-method-named.js +0 -7
  263. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-new-expression-with-parentheses.js +0 -28
  264. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-node-matches.js +0 -58
  265. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-node-value-not-dom-node.js +0 -20
  266. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-node-value-not-function.js +0 -40
  267. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-number.js +0 -224
  268. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-object-method.js +0 -10
  269. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-on-same-line.js +0 -7
  270. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-same-identifier.js +0 -5
  271. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-same-reference.js +0 -170
  272. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-shorthand-export-local.js +0 -8
  273. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-shorthand-import-local.js +0 -8
  274. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-shorthand-property-assignment-pattern-left.js +0 -8
  275. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-shorthand-property-value.js +0 -6
  276. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-unresolved-variable.js +0 -14
  277. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/is-value-not-usable.js +0 -5
  278. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/needs-semicolon.js +0 -118
  279. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/numeric.js +0 -49
  280. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/parentheses.js +0 -71
  281. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/resolve-variable-name.js +0 -18
  282. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/rule.js +0 -27
  283. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/should-add-parentheses-to-await-expression-argument.js +0 -17
  284. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/should-add-parentheses-to-call-expression-callee.js +0 -18
  285. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/should-add-parentheses-to-conditional-expression-child.js +0 -13
  286. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/should-add-parentheses-to-expression-statement-expression.js +0 -22
  287. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/should-add-parentheses-to-logical-expression-child.js +0 -43
  288. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/should-add-parentheses-to-member-expression-object.js +0 -47
  289. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/should-add-parentheses-to-new-expression-callee.js +0 -28
  290. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/should-add-parentheses-to-unary-expression.js +0 -24
  291. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/singular.js +0 -16
  292. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/string-cases.js +0 -2
  293. package/packages/config-eslint/node_modules/eslint-plugin-unicorn/rules/utils/to-location.js +0 -25
@@ -1,458 +0,0 @@
1
- import {isParenthesized, findVariable} from '@eslint-community/eslint-utils';
2
- import {
3
- extendFixRange,
4
- removeMemberExpressionProperty,
5
- removeMethodCall,
6
- renameVariable,
7
- } from './fix/index.js';
8
- import {
9
- isLeftHandSide,
10
- singular,
11
- getScopes,
12
- getAvailableVariableName,
13
- getVariableIdentifiers,
14
- } from './utils/index.js';
15
- import {isMethodCall} from './ast/index.js';
16
-
17
- const ERROR_ZERO_INDEX = 'error-zero-index';
18
- const ERROR_SHIFT = 'error-shift';
19
- const ERROR_POP = 'error-pop';
20
- const ERROR_AT_ZERO = 'error-at-zero';
21
- const ERROR_AT_MINUS_ONE = 'error-at-minus-one';
22
- const ERROR_DESTRUCTURING_DECLARATION = 'error-destructuring-declaration';
23
- const ERROR_DESTRUCTURING_ASSIGNMENT = 'error-destructuring-assignment';
24
- const ERROR_DECLARATION = 'error-variable';
25
- const SUGGESTION_NULLISH_COALESCING_OPERATOR = 'suggest-nullish-coalescing-operator';
26
- const SUGGESTION_LOGICAL_OR_OPERATOR = 'suggest-logical-or-operator';
27
- const messages = {
28
- [ERROR_DECLARATION]: 'Prefer `.find(…)` over `.filter(…)`.',
29
- [ERROR_ZERO_INDEX]: 'Prefer `.find(…)` over `.filter(…)[0]`.',
30
- [ERROR_AT_ZERO]: 'Prefer `.find(…)` over `.filter(…).at(0)`.',
31
- [ERROR_SHIFT]: 'Prefer `.find(…)` over `.filter(…).shift()`.',
32
- [ERROR_POP]: 'Prefer `.findLast(…)` over `.filter(…).pop()`.',
33
- [ERROR_AT_MINUS_ONE]: 'Prefer `.findLast(…)` over `.filter(…).at(-1)`.',
34
- [ERROR_DESTRUCTURING_DECLARATION]: 'Prefer `.find(…)` over destructuring `.filter(…)`.',
35
- // Same message as `ERROR_DESTRUCTURING_DECLARATION`, but different case
36
- [ERROR_DESTRUCTURING_ASSIGNMENT]: 'Prefer `.find(…)` over destructuring `.filter(…)`.',
37
- [SUGGESTION_NULLISH_COALESCING_OPERATOR]: 'Replace `.filter(…)` with `.find(…) ?? …`.',
38
- [SUGGESTION_LOGICAL_OR_OPERATOR]: 'Replace `.filter(…)` with `.find(…) || …`.',
39
- };
40
-
41
- const isArrayFilterCall = (node, options) => isMethodCall(node, {
42
- method: 'filter',
43
- minimumArguments: 1,
44
- maximumArguments: 2,
45
- optionalCall: false,
46
- ...options,
47
- });
48
-
49
- // Need add `()` to the `AssignmentExpression`
50
- // - `ObjectExpression`: `[{foo}] = array.filter(bar)` fix to `{foo} = array.find(bar)`
51
- // - `ObjectPattern`: `[{foo = baz}] = array.filter(bar)`
52
- const assignmentNeedParenthesize = (node, sourceCode) => {
53
- const isAssign = node.type === 'AssignmentExpression';
54
-
55
- if (!isAssign || isParenthesized(node, sourceCode)) {
56
- return false;
57
- }
58
-
59
- const {left} = getDestructuringLeftAndRight(node);
60
- const [element] = left.elements;
61
- const {type} = element.type === 'AssignmentPattern' ? element.left : element;
62
- return type === 'ObjectExpression' || type === 'ObjectPattern';
63
- };
64
-
65
- // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/Operator_Precedence#Table
66
- const hasLowerPrecedence = (node, operator) => (
67
- (node.type === 'LogicalExpression' && (
68
- node.operator === operator
69
- // https://tc39.es/proposal-nullish-coalescing/ says
70
- // `??` has lower precedence than `||`
71
- // But MDN says
72
- // `??` has higher precedence than `||`
73
- || (operator === '||' && node.operator === '??')
74
- || (operator === '??' && (node.operator === '||' || node.operator === '&&'))
75
- ))
76
- || node.type === 'ConditionalExpression'
77
- // Lower than `assignment`, should already parenthesized
78
- /* c8 ignore next */
79
- || node.type === 'AssignmentExpression'
80
- || node.type === 'YieldExpression'
81
- || node.type === 'SequenceExpression'
82
- );
83
-
84
- const getDestructuringLeftAndRight = node => {
85
- /* c8 ignore next 3 */
86
- if (!node) {
87
- return {};
88
- }
89
-
90
- if (node.type === 'AssignmentExpression') {
91
- return node;
92
- }
93
-
94
- if (node.type === 'VariableDeclarator') {
95
- return {left: node.id, right: node.init};
96
- }
97
-
98
- return {};
99
- };
100
-
101
- function * fixDestructuring(node, sourceCode, fixer) {
102
- const {left} = getDestructuringLeftAndRight(node);
103
- const [element] = left.elements;
104
-
105
- const leftText = sourceCode.getText(element.type === 'AssignmentPattern' ? element.left : element);
106
- yield fixer.replaceText(left, leftText);
107
-
108
- // `AssignmentExpression` always starts with `[` or `(`, so we don't need check ASI
109
- if (assignmentNeedParenthesize(node, sourceCode)) {
110
- yield fixer.insertTextBefore(node, '(');
111
- yield fixer.insertTextAfter(node, ')');
112
- }
113
- }
114
-
115
- const hasDefaultValue = node => getDestructuringLeftAndRight(node).left.elements[0].type === 'AssignmentPattern';
116
-
117
- const fixDestructuringDefaultValue = (node, sourceCode, fixer, operator) => {
118
- const {left, right} = getDestructuringLeftAndRight(node);
119
- const [element] = left.elements;
120
- const defaultValue = element.right;
121
- let defaultValueText = sourceCode.getText(defaultValue);
122
-
123
- if (isParenthesized(defaultValue, sourceCode) || hasLowerPrecedence(defaultValue, operator)) {
124
- defaultValueText = `(${defaultValueText})`;
125
- }
126
-
127
- return fixer.insertTextAfter(right, ` ${operator} ${defaultValueText}`);
128
- };
129
-
130
- const fixDestructuringAndReplaceFilter = (sourceCode, node) => {
131
- const {property} = getDestructuringLeftAndRight(node).right.callee;
132
-
133
- let suggest;
134
- let fix;
135
-
136
- if (hasDefaultValue(node)) {
137
- suggest = [
138
- {operator: '??', messageId: SUGGESTION_NULLISH_COALESCING_OPERATOR},
139
- {operator: '||', messageId: SUGGESTION_LOGICAL_OR_OPERATOR},
140
- ].map(({messageId, operator}) => ({
141
- messageId,
142
- * fix(fixer) {
143
- yield fixer.replaceText(property, 'find');
144
- yield fixDestructuringDefaultValue(node, sourceCode, fixer, operator);
145
- yield fixDestructuring(node, sourceCode, fixer);
146
- },
147
- }));
148
- } else {
149
- fix = function * (fixer) {
150
- yield fixer.replaceText(property, 'find');
151
- yield fixDestructuring(node, sourceCode, fixer);
152
- };
153
- }
154
-
155
- return {fix, suggest};
156
- };
157
-
158
- const isAccessingZeroIndex = node =>
159
- node.parent.type === 'MemberExpression'
160
- && node.parent.computed === true
161
- && node.parent.object === node
162
- && node.parent.property.type === 'Literal'
163
- && node.parent.property.raw === '0';
164
-
165
- const isDestructuringFirstElement = node => {
166
- const {left, right} = getDestructuringLeftAndRight(node.parent);
167
- return left
168
- && right
169
- && right === node
170
- && left.type === 'ArrayPattern'
171
- && left.elements.length === 1
172
- && left.elements[0]
173
- && left.elements[0].type !== 'RestElement';
174
- };
175
-
176
- /** @param {import('eslint').Rule.RuleContext} context */
177
- const create = context => {
178
- const {sourceCode} = context;
179
- const {
180
- checkFromLast,
181
- } = {
182
- checkFromLast: true,
183
- ...context.options[0],
184
- };
185
-
186
- // Zero index access
187
- // `array.filter()[0]`
188
- // `array?.filter()[0]`
189
- context.on('MemberExpression', node => {
190
- if (!(
191
- node.computed
192
- && node.property.type === 'Literal'
193
- && node.property.raw === '0'
194
- && isArrayFilterCall(node.object)
195
- && !isLeftHandSide(node)
196
- )) {
197
- return;
198
- }
199
-
200
- return {
201
- node: node.object.callee.property,
202
- messageId: ERROR_ZERO_INDEX,
203
- fix: fixer => [
204
- fixer.replaceText(node.object.callee.property, 'find'),
205
- removeMemberExpressionProperty(fixer, node, context),
206
- ],
207
- };
208
- });
209
-
210
- // `array.filter().shift()`
211
- // `array?.filter().shift()`
212
- context.on('CallExpression', node => {
213
- if (!(
214
- isMethodCall(node, {
215
- method: 'shift',
216
- argumentsLength: 0,
217
- optionalCall: false,
218
- optionalMember: false,
219
- })
220
- && isArrayFilterCall(node.callee.object)
221
- )) {
222
- return;
223
- }
224
-
225
- return {
226
- node: node.callee.object.callee.property,
227
- messageId: ERROR_SHIFT,
228
- fix: fixer => [
229
- fixer.replaceText(node.callee.object.callee.property, 'find'),
230
- ...removeMethodCall(fixer, node, context),
231
- ],
232
- };
233
- });
234
-
235
- // `const [foo] = array.filter()`
236
- context.on('VariableDeclarator', node => {
237
- if (!(
238
- node.id.type === 'ArrayPattern'
239
- && node.id.elements.length === 1
240
- && node.id.elements[0]
241
- && node.id.elements[0].type !== 'RestElement'
242
- && isArrayFilterCall(node.init, {optionalMember: false})
243
- )) {
244
- return;
245
- }
246
-
247
- return {
248
- node: node.init.callee.property,
249
- messageId: ERROR_DESTRUCTURING_DECLARATION,
250
- ...fixDestructuringAndReplaceFilter(sourceCode, node),
251
- };
252
- });
253
-
254
- // `[foo] = array.filter()`
255
- context.on('AssignmentExpression', node => {
256
- if (!(
257
- node.left.type === 'ArrayPattern'
258
- && node.left.elements.length === 1
259
- && node.left.elements[0]
260
- && node.left.elements[0].type !== 'RestElement'
261
- && isArrayFilterCall(node.right, {optionalMember: false})
262
- )) {
263
- return;
264
- }
265
-
266
- return {
267
- node: node.right.callee.property,
268
- messageId: ERROR_DESTRUCTURING_ASSIGNMENT,
269
- ...fixDestructuringAndReplaceFilter(sourceCode, node),
270
- };
271
- });
272
-
273
- // `const foo = array.filter(); foo[0]; [bar] = foo`
274
- context.on('VariableDeclarator', node => {
275
- if (!(
276
- node.id.type === 'Identifier'
277
- && isArrayFilterCall(node.init, {optionalMember: false})
278
- && node.parent.type === 'VariableDeclaration'
279
- && node.parent.declarations.includes(node)
280
- // Exclude `export const foo = [];`
281
- && !(
282
- node.parent.parent.type === 'ExportNamedDeclaration'
283
- && node.parent.parent.declaration === node.parent
284
- )
285
- )) {
286
- return;
287
- }
288
-
289
- const scope = sourceCode.getScope(node);
290
- const variable = findVariable(scope, node.id);
291
- const identifiers = getVariableIdentifiers(variable).filter(identifier => identifier !== node.id);
292
-
293
- if (identifiers.length === 0) {
294
- return;
295
- }
296
-
297
- const zeroIndexNodes = [];
298
- const destructuringNodes = [];
299
- for (const identifier of identifiers) {
300
- if (isAccessingZeroIndex(identifier)) {
301
- zeroIndexNodes.push(identifier.parent);
302
- } else if (isDestructuringFirstElement(identifier)) {
303
- destructuringNodes.push(identifier.parent);
304
- } else {
305
- return;
306
- }
307
- }
308
-
309
- const problem = {
310
- node: node.init.callee.property,
311
- messageId: ERROR_DECLARATION,
312
- };
313
-
314
- // `const [foo = bar] = baz` is not fixable
315
- if (!destructuringNodes.some(node => hasDefaultValue(node))) {
316
- problem.fix = function * (fixer) {
317
- yield fixer.replaceText(node.init.callee.property, 'find');
318
-
319
- const singularName = singular(node.id.name);
320
- if (singularName) {
321
- // Rename variable to be singularized now that it refers to a single item in the array instead of the entire array.
322
- const singularizedName = getAvailableVariableName(singularName, getScopes(scope));
323
- yield renameVariable(variable, singularizedName, context, fixer);
324
-
325
- // Prevent possible variable conflicts
326
- yield extendFixRange(fixer, sourceCode.getRange(sourceCode.ast));
327
- }
328
-
329
- for (const node of zeroIndexNodes) {
330
- yield removeMemberExpressionProperty(fixer, node, context);
331
- }
332
-
333
- for (const node of destructuringNodes) {
334
- yield fixDestructuring(node, sourceCode, fixer);
335
- }
336
- };
337
- }
338
-
339
- return problem;
340
- });
341
-
342
- // `array.filter().at(0)`
343
- // `array?.filter().at(0)`
344
- context.on('CallExpression', node => {
345
- if (!(
346
- isMethodCall(node, {
347
- method: 'at',
348
- argumentsLength: 1,
349
- optionalCall: false,
350
- optionalMember: false,
351
- })
352
- && node.arguments[0].type === 'Literal'
353
- && node.arguments[0].raw === '0'
354
- && isArrayFilterCall(node.callee.object)
355
- )) {
356
- return;
357
- }
358
-
359
- return {
360
- node: node.callee.object.callee.property,
361
- messageId: ERROR_AT_ZERO,
362
- fix: fixer => [
363
- fixer.replaceText(node.callee.object.callee.property, 'find'),
364
- ...removeMethodCall(fixer, node, context),
365
- ],
366
- };
367
- });
368
-
369
- if (!checkFromLast) {
370
- return;
371
- }
372
-
373
- // `array.filter().pop()`
374
- // `array?.filter().pop()`
375
- context.on('CallExpression', node => {
376
- if (!(
377
- isMethodCall(node, {
378
- method: 'pop',
379
- argumentsLength: 0,
380
- optionalCall: false,
381
- optionalMember: false,
382
- })
383
- && isArrayFilterCall(node.callee.object)
384
- )) {
385
- return;
386
- }
387
-
388
- return {
389
- node: node.callee.object.callee.property,
390
- messageId: ERROR_POP,
391
- fix: fixer => [
392
- fixer.replaceText(node.callee.object.callee.property, 'findLast'),
393
- ...removeMethodCall(fixer, node, context),
394
- ],
395
- };
396
- });
397
-
398
- // `array.filter().at(-1)`
399
- // `array?.filter().at(-1)`
400
- context.on('CallExpression', node => {
401
- if (!(
402
- isMethodCall(node, {
403
- method: 'at',
404
- argumentsLength: 1,
405
- optionalCall: false,
406
- optionalMember: false,
407
- })
408
- && node.arguments[0].type === 'UnaryExpression'
409
- && node.arguments[0].operator === '-'
410
- && node.arguments[0].prefix
411
- && node.arguments[0].argument.type === 'Literal'
412
- && node.arguments[0].argument.raw === '1'
413
- && isArrayFilterCall(node.callee.object)
414
- )) {
415
- return;
416
- }
417
-
418
- return {
419
- node: node.callee.object.callee.property,
420
- messageId: ERROR_AT_MINUS_ONE,
421
- fix: fixer => [
422
- fixer.replaceText(node.callee.object.callee.property, 'findLast'),
423
- ...removeMethodCall(fixer, node, context),
424
- ],
425
- };
426
- });
427
- };
428
-
429
- const schema = [
430
- {
431
- type: 'object',
432
- additionalProperties: false,
433
- properties: {
434
- checkFromLast: {
435
- type: 'boolean',
436
- },
437
- },
438
- },
439
- ];
440
-
441
- /** @type {import('eslint').Rule.RuleModule} */
442
- const config = {
443
- create,
444
- meta: {
445
- type: 'suggestion',
446
- docs: {
447
- description: 'Prefer `.find(…)` and `.findLast(…)` over the first or last element from `.filter(…)`.',
448
- recommended: 'unopinionated',
449
- },
450
- fixable: 'code',
451
- hasSuggestions: true,
452
- schema,
453
- defaultOptions: [{checkFromLast: true}],
454
- messages,
455
- },
456
- };
457
-
458
- export default config;
@@ -1,86 +0,0 @@
1
- import {isNodeMatches} from './utils/is-node-matches.js';
2
- import {isMethodCall} from './ast/index.js';
3
- import {removeMethodCall} from './fix/index.js';
4
-
5
- const MESSAGE_ID = 'prefer-array-flat-map';
6
- const messages = {
7
- [MESSAGE_ID]: 'Prefer `.flatMap(…)` over `.map(…).flat()`.',
8
- };
9
-
10
- const ignored = ['React.Children', 'Children'];
11
-
12
- /** @param {import('eslint').Rule.RuleContext} context */
13
- const create = context => ({
14
- CallExpression(callExpression) {
15
- if (!(
16
- isMethodCall(callExpression, {
17
- method: 'flat',
18
- optionalCall: false,
19
- optionalMember: false,
20
- })
21
- && (
22
- callExpression.arguments.length === 0
23
- || (
24
- callExpression.arguments.length === 1
25
- && callExpression.arguments[0].type === 'Literal'
26
- && callExpression.arguments[0].raw === '1'
27
- )
28
- )
29
- && isMethodCall(callExpression.callee.object, {
30
- method: 'map',
31
- optionalCall: false,
32
- })
33
- )) {
34
- return;
35
- }
36
-
37
- const flatCallExpression = callExpression;
38
- const mapCallExpression = flatCallExpression.callee.object;
39
- if (isNodeMatches(mapCallExpression.callee.object, ignored)) {
40
- return;
41
- }
42
-
43
- const {sourceCode} = context;
44
- const mapProperty = mapCallExpression.callee.property;
45
-
46
- return {
47
- node: flatCallExpression,
48
- loc: {
49
- start: sourceCode.getLoc(mapProperty).start,
50
- end: sourceCode.getLoc(flatCallExpression).end,
51
- },
52
- messageId: MESSAGE_ID,
53
- * fix(fixer) {
54
- // Removes:
55
- // map(…).flat();
56
- // ^^^^^^^
57
- // (map(…)).flat();
58
- // ^^^^^^^
59
- yield removeMethodCall(fixer, flatCallExpression, context);
60
-
61
- // Renames:
62
- // map(…).flat();
63
- // ^^^
64
- // (map(…)).flat();
65
- // ^^^
66
- yield fixer.replaceText(mapProperty, 'flatMap');
67
- },
68
- };
69
- },
70
- });
71
-
72
- /** @type {import('eslint').Rule.RuleModule} */
73
- const config = {
74
- create,
75
- meta: {
76
- type: 'suggestion',
77
- docs: {
78
- description: 'Prefer `.flatMap(…)` over `.map(…).flat()`.',
79
- recommended: 'unopinionated',
80
- },
81
- fixable: 'code',
82
- messages,
83
- },
84
- };
85
-
86
- export default config;