@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,171 +0,0 @@
1
- import {getStaticValue} from '@eslint-community/eslint-utils';
2
- import {isNewExpression, isStringLiteral} from './ast/index.js';
3
-
4
- const MESSAGE_ID_NEVER = 'never';
5
- const MESSAGE_ID_ALWAYS = 'always';
6
- const MESSAGE_ID_REMOVE = 'remove';
7
- const messages = {
8
- [MESSAGE_ID_NEVER]: 'Remove the `./` prefix from the relative URL.',
9
- [MESSAGE_ID_ALWAYS]: 'Add a `./` prefix to the relative URL.',
10
- [MESSAGE_ID_REMOVE]: 'Remove leading `./`.',
11
- };
12
-
13
- const DOT_SLASH = './';
14
- const TEST_URL_BASES = [
15
- 'https://example.com/a/b/',
16
- 'https://example.com/a/b.html',
17
- ];
18
- const isSafeToAddDotSlashToUrl = (url, base) => {
19
- try {
20
- return new URL(url, base).href === new URL(DOT_SLASH + url, base).href;
21
- } catch {}
22
-
23
- return false;
24
- };
25
-
26
- const isSafeToAddDotSlash = (url, bases = TEST_URL_BASES) => bases.every(base => isSafeToAddDotSlashToUrl(url, base));
27
- const isSafeToRemoveDotSlash = (url, bases = TEST_URL_BASES) => bases.every(base => isSafeToAddDotSlashToUrl(url.slice(DOT_SLASH.length), base));
28
-
29
- function canAddDotSlash(node, sourceCode) {
30
- const url = node.value;
31
- if (url.startsWith(DOT_SLASH) || url.startsWith('.') || url.startsWith('/')) {
32
- return false;
33
- }
34
-
35
- const baseNode = node.parent.arguments[1];
36
- const staticValueResult = getStaticValue(baseNode, sourceCode.getScope(node));
37
-
38
- if (
39
- typeof staticValueResult?.value === 'string'
40
- && isSafeToAddDotSlash(url, [staticValueResult.value])
41
- ) {
42
- return true;
43
- }
44
-
45
- return isSafeToAddDotSlash(url);
46
- }
47
-
48
- function canRemoveDotSlash(node, sourceCode) {
49
- const rawValue = node.raw.slice(1, -1);
50
- if (!rawValue.startsWith(DOT_SLASH)) {
51
- return false;
52
- }
53
-
54
- const baseNode = node.parent.arguments[1];
55
- const staticValueResult = getStaticValue(baseNode, sourceCode.getScope(node));
56
-
57
- if (
58
- typeof staticValueResult?.value === 'string'
59
- && isSafeToRemoveDotSlash(node.value, [staticValueResult.value])
60
- ) {
61
- return true;
62
- }
63
-
64
- return isSafeToRemoveDotSlash(node.value);
65
- }
66
-
67
- function addDotSlash(node, sourceCode) {
68
- if (!canAddDotSlash(node, sourceCode)) {
69
- return;
70
- }
71
-
72
- const insertPosition = sourceCode.getRange(node)[0] + 1; // After quote
73
- return fixer => fixer.insertTextAfterRange([insertPosition, insertPosition], DOT_SLASH);
74
- }
75
-
76
- function removeDotSlash(node, sourceCode) {
77
- if (!canRemoveDotSlash(node, sourceCode)) {
78
- return;
79
- }
80
-
81
- const start = sourceCode.getRange(node)[0] + 1; // After quote
82
- return fixer => fixer.removeRange([start, start + 2]);
83
- }
84
-
85
- /** @param {import('eslint').Rule.RuleContext} context */
86
- const create = context => {
87
- const style = context.options[0] || 'never';
88
-
89
- const listeners = {};
90
-
91
- // TemplateLiteral are not always safe to remove `./`, but if it's starts with `./` we'll report
92
- if (style === 'never') {
93
- listeners.TemplateLiteral = function (node) {
94
- if (!(
95
- isNewExpression(node.parent, {name: 'URL', argumentsLength: 2})
96
- && node.parent.arguments[0] === node
97
- )) {
98
- return;
99
- }
100
-
101
- const firstPart = node.quasis[0];
102
- if (!firstPart.value.raw.startsWith(DOT_SLASH)) {
103
- return;
104
- }
105
-
106
- return {
107
- node,
108
- messageId: style,
109
- suggest: [
110
- {
111
- messageId: MESSAGE_ID_REMOVE,
112
- fix(fixer) {
113
- const start = context.sourceCode.getRange(firstPart)[0] + 1;
114
- return fixer.removeRange([start, start + DOT_SLASH.length]);
115
- },
116
- },
117
- ],
118
- };
119
- };
120
- }
121
-
122
- listeners.Literal = function (node) {
123
- if (!(
124
- isStringLiteral(node)
125
- && isNewExpression(node.parent, {name: 'URL', argumentsLength: 2})
126
- && node.parent.arguments[0] === node
127
- )) {
128
- return;
129
- }
130
-
131
- const {sourceCode} = context;
132
- const fix = (style === 'never' ? removeDotSlash : addDotSlash)(node, sourceCode);
133
-
134
- if (!fix) {
135
- return;
136
- }
137
-
138
- return {
139
- node,
140
- messageId: style,
141
- fix,
142
- };
143
- };
144
-
145
- return listeners;
146
- };
147
-
148
- const schema = [
149
- {
150
- enum: ['never', 'always'],
151
- },
152
- ];
153
-
154
- /** @type {import('eslint').Rule.RuleModule} */
155
- const config = {
156
- create,
157
- meta: {
158
- type: 'suggestion',
159
- docs: {
160
- description: 'Enforce consistent relative URL style.',
161
- recommended: 'unopinionated',
162
- },
163
- fixable: 'code',
164
- hasSuggestions: true,
165
- schema,
166
- defaultOptions: ['never'],
167
- messages,
168
- },
169
- };
170
-
171
- export default config;
@@ -1,65 +0,0 @@
1
- import {appendArgument} from './fix/index.js';
2
- import {isMethodCall} from './ast/index.js';
3
- import {isArrayPrototypeProperty} from './utils/index.js';
4
-
5
- const MESSAGE_ID = 'require-array-join-separator';
6
- const messages = {
7
- [MESSAGE_ID]: 'Missing the separator argument.',
8
- };
9
-
10
- /** @param {import('eslint').Rule.RuleContext} context */
11
- const create = context => ({
12
- CallExpression(node) {
13
- if (!(
14
- // `foo.join()`
15
- isMethodCall(node, {
16
- method: 'join',
17
- argumentsLength: 0,
18
- optionalCall: false,
19
- })
20
- // `[].join.call(foo)` and `Array.prototype.join.call(foo)`
21
- || (
22
- isMethodCall(node, {
23
- method: 'call',
24
- argumentsLength: 1,
25
- optionalCall: false,
26
- optionalMember: false,
27
- })
28
- && isArrayPrototypeProperty(node.callee.object, {
29
- property: 'join',
30
- })
31
- )
32
- )) {
33
- return;
34
- }
35
-
36
- const {sourceCode} = context;
37
- const [penultimateToken, lastToken] = sourceCode.getLastTokens(node, 2);
38
- const isPrototypeMethod = node.arguments.length === 1;
39
- return {
40
- loc: {
41
- start: sourceCode.getLoc(penultimateToken)[isPrototypeMethod ? 'end' : 'start'],
42
- end: sourceCode.getLoc(lastToken).end,
43
- },
44
- messageId: MESSAGE_ID,
45
- /** @param {import('eslint').Rule.RuleFixer} fixer */
46
- fix: fixer => appendArgument(fixer, node, '\',\'', context),
47
- };
48
- },
49
- });
50
-
51
- /** @type {import('eslint').Rule.RuleModule} */
52
- const config = {
53
- create,
54
- meta: {
55
- type: 'suggestion',
56
- docs: {
57
- description: 'Enforce using the separator argument with `Array#join()`.',
58
- recommended: 'unopinionated',
59
- },
60
- fixable: 'code',
61
- messages,
62
- },
63
- };
64
-
65
- export default config;
@@ -1,120 +0,0 @@
1
- import {isCommaToken} from '@eslint-community/eslint-utils';
2
- import {removeObjectProperty} from './fix/index.js';
3
- import {getParentheses} from './utils/index.js';
4
-
5
- const MESSAGE_ID = 'require-module-attributes';
6
- const messages = {
7
- [MESSAGE_ID]: '{{type}} with empty attribute list is not allowed.',
8
- };
9
-
10
- const isWithToken = token => token?.type === 'Keyword' && token.value === 'with';
11
-
12
- /** @param {import('eslint').Rule.RuleContext} context */
13
- const create = context => {
14
- const {sourceCode} = context;
15
-
16
- context.on(['ImportDeclaration', 'ExportNamedDeclaration', 'ExportAllDeclaration'], declaration => {
17
- const {source, attributes} = declaration;
18
-
19
- if (!source || (Array.isArray(attributes) && attributes.length > 0)) {
20
- return;
21
- }
22
-
23
- const withToken = sourceCode.getTokenAfter(source);
24
-
25
- if (!isWithToken(withToken)) {
26
- return;
27
- }
28
-
29
- // `WithStatement` is not possible in modules, so we don't need worry it's not attributes
30
-
31
- const openingBraceToken = sourceCode.getTokenAfter(withToken);
32
- const closingBraceToken = sourceCode.getTokenAfter(openingBraceToken);
33
-
34
- return {
35
- node: declaration,
36
- loc: {
37
- start: sourceCode.getLoc(openingBraceToken).start,
38
- end: sourceCode.getLoc(closingBraceToken).end,
39
- },
40
- messageId: MESSAGE_ID,
41
- data: {
42
- type: declaration.type === 'ImportDeclaration' ? 'import statement' : 'export statement',
43
- },
44
- /** @param {import('eslint').Rule.RuleFixer} fixer */
45
- fix: fixer => [withToken, closingBraceToken, openingBraceToken].map(token => fixer.remove(token)),
46
- };
47
- });
48
-
49
- context.on('ImportExpression', importExpression => {
50
- const {options: optionsNode} = importExpression;
51
-
52
- if (optionsNode?.type !== 'ObjectExpression') {
53
- return;
54
- }
55
-
56
- const emptyWithProperty = optionsNode.properties.find(
57
- property =>
58
- property.type === 'Property'
59
- && !property.method
60
- && !property.shorthand
61
- && !property.computed
62
- && property.kind === 'init'
63
- && (
64
- (
65
- property.key.type === 'Identifier'
66
- && property.key.name === 'with'
67
- )
68
- || (
69
- property.key.type === 'Literal'
70
- && property.key.value === 'with'
71
- )
72
- )
73
- && property.value.type === 'ObjectExpression'
74
- && property.value.properties.length === 0,
75
- );
76
-
77
- const nodeToRemove = optionsNode.properties.length === 0 || (emptyWithProperty && optionsNode.properties.length === 1)
78
- ? optionsNode
79
- : emptyWithProperty;
80
-
81
- if (!nodeToRemove) {
82
- return;
83
- }
84
-
85
- const isProperty = nodeToRemove.type === 'Property';
86
-
87
- return {
88
- node: emptyWithProperty?.value ?? nodeToRemove,
89
- messageId: MESSAGE_ID,
90
- data: {
91
- type: 'import expression',
92
- },
93
- /** @param {import('eslint').Rule.RuleFixer} fixer */
94
- fix: fixer => isProperty
95
- ? removeObjectProperty(fixer, nodeToRemove, context)
96
- : [
97
- // Comma token before
98
- sourceCode.getTokenBefore(nodeToRemove, isCommaToken),
99
- ...sourceCode.getTokens(nodeToRemove),
100
- ...getParentheses(nodeToRemove, context),
101
- ].map(token => fixer.remove(token)),
102
- };
103
- });
104
- };
105
-
106
- /** @type {import('eslint').Rule.RuleModule} */
107
- const config = {
108
- create,
109
- meta: {
110
- type: 'suggestion',
111
- docs: {
112
- description: 'Require non-empty module attributes for imports and exports',
113
- recommended: 'unopinionated',
114
- },
115
- fixable: 'code',
116
- messages,
117
- },
118
- };
119
-
120
- export default config;
@@ -1,158 +0,0 @@
1
- import {isClosingBraceToken} from '@eslint-community/eslint-utils';
2
-
3
- const MESSAGE_ID_ERROR = 'error';
4
- const MESSAGE_ID_SUGGESTION_REMOVE_DECLARATION = 'suggestion/remove-declaration';
5
- const MESSAGE_ID_SUGGESTION_TO_SIDE_EFFECT_IMPORT = 'suggestion/to-side-effect-import';
6
- const messages = {
7
- [MESSAGE_ID_ERROR]: '{{type}} statement without specifiers is not allowed.',
8
- [MESSAGE_ID_SUGGESTION_REMOVE_DECLARATION]: 'Remove this {{type}} statement.',
9
- [MESSAGE_ID_SUGGESTION_TO_SIDE_EFFECT_IMPORT]: 'Switch to side effect import.',
10
- };
11
-
12
- const isFromToken = token => token.type === 'Identifier' && token.value === 'from';
13
-
14
- /** @param {import('eslint').Rule.RuleContext} context */
15
- const create = context => {
16
- const {sourceCode} = context;
17
-
18
- context.on('ImportDeclaration', importDeclaration => {
19
- const {specifiers} = importDeclaration;
20
-
21
- if (specifiers.some(node => node.type === 'ImportSpecifier' || node.type === 'ImportNamespaceSpecifier')) {
22
- return;
23
- }
24
-
25
- const {source, importKind} = importDeclaration;
26
- const fromToken = sourceCode.getTokenBefore(source);
27
- if (!isFromToken(fromToken)) {
28
- return;
29
- }
30
-
31
- const closingBraceToken = sourceCode.getTokenBefore(fromToken);
32
- if (!isClosingBraceToken(closingBraceToken)) {
33
- return;
34
- }
35
-
36
- const openingBraceToken = sourceCode.getTokenBefore(closingBraceToken);
37
-
38
- const problem = {
39
- node: importDeclaration,
40
- loc: {
41
- start: sourceCode.getLoc(openingBraceToken).start,
42
- end: sourceCode.getLoc(closingBraceToken).end,
43
- },
44
- messageId: MESSAGE_ID_ERROR,
45
- data: {
46
- type: 'import',
47
- },
48
- };
49
-
50
- // If there is a `ImportDefaultSpecifier`, it has to be the first.
51
- const importDefaultSpecifier = specifiers.length === 1 ? specifiers[0] : undefined;
52
- if (importKind === 'type' && !importDefaultSpecifier) {
53
- problem.fix = fixer => fixer.remove(importDeclaration);
54
- return problem;
55
- }
56
-
57
- if (importDefaultSpecifier) {
58
- problem.fix = function * (fixer) {
59
- yield fixer.remove(closingBraceToken);
60
- yield fixer.remove(openingBraceToken);
61
-
62
- const commaToken = sourceCode.getTokenBefore(openingBraceToken);
63
- yield fixer.remove(commaToken);
64
-
65
- if (sourceCode.getRange(closingBraceToken)[1] === sourceCode.getRange(fromToken)[0]) {
66
- yield fixer.insertTextBefore(fromToken, ' ');
67
- }
68
- };
69
-
70
- return problem;
71
- }
72
-
73
- problem.suggest = [
74
- {
75
- messageId: MESSAGE_ID_SUGGESTION_REMOVE_DECLARATION,
76
- fix: fixer => fixer.remove(importDeclaration),
77
- },
78
- {
79
- messageId: MESSAGE_ID_SUGGESTION_TO_SIDE_EFFECT_IMPORT,
80
- * fix(fixer) {
81
- yield fixer.remove(openingBraceToken);
82
- yield fixer.remove(closingBraceToken);
83
- yield fixer.remove(fromToken);
84
- },
85
- },
86
- ];
87
-
88
- return problem;
89
- });
90
-
91
- context.on('ExportNamedDeclaration', exportDeclaration => {
92
- const {specifiers, declaration} = exportDeclaration;
93
-
94
- if (declaration || specifiers.length > 0) {
95
- return;
96
- }
97
-
98
- const {source, exportKind} = exportDeclaration;
99
- const fromToken = source ? sourceCode.getTokenBefore(source) : undefined;
100
- const closingBraceToken = fromToken
101
- ? sourceCode.getTokenBefore(fromToken)
102
- : sourceCode.getLastToken(exportDeclaration, isClosingBraceToken);
103
- const openingBraceToken = sourceCode.getTokenBefore(closingBraceToken);
104
-
105
- const problem = {
106
- node: exportDeclaration,
107
- loc: {
108
- start: sourceCode.getLoc(openingBraceToken).start,
109
- end: sourceCode.getLoc(closingBraceToken).end,
110
- },
111
- messageId: MESSAGE_ID_ERROR,
112
- data: {
113
- type: 'export',
114
- },
115
- };
116
-
117
- if (!source || exportKind === 'type') {
118
- problem.fix = fixer => fixer.remove(exportDeclaration);
119
- return problem;
120
- }
121
-
122
- problem.suggest = [
123
- {
124
- messageId: MESSAGE_ID_SUGGESTION_REMOVE_DECLARATION,
125
- fix: fixer => fixer.remove(exportDeclaration),
126
- },
127
- {
128
- messageId: MESSAGE_ID_SUGGESTION_TO_SIDE_EFFECT_IMPORT,
129
- * fix(fixer) {
130
- const exportToken = sourceCode.getFirstToken(exportDeclaration);
131
- yield fixer.replaceText(exportToken, 'import');
132
- yield fixer.remove(openingBraceToken);
133
- yield fixer.remove(closingBraceToken);
134
- yield fixer.remove(fromToken);
135
- },
136
- },
137
- ];
138
-
139
- return problem;
140
- });
141
- };
142
-
143
- /** @type {import('eslint').Rule.RuleModule} */
144
- const config = {
145
- create,
146
- meta: {
147
- type: 'suggestion',
148
- docs: {
149
- description: 'Require non-empty specifier list in import and export statements.',
150
- recommended: 'unopinionated',
151
- },
152
- fixable: 'code',
153
- hasSuggestions: true,
154
- messages,
155
- },
156
- };
157
-
158
- export default config;
@@ -1,55 +0,0 @@
1
- import {appendArgument} from './fix/index.js';
2
- import {isMethodCall} from './ast/index.js';
3
-
4
- const MESSAGE_ID = 'require-number-to-fixed-digits-argument';
5
- const messages = {
6
- [MESSAGE_ID]: 'Missing the digits argument.',
7
- };
8
-
9
- /** @param {import('eslint').Rule.RuleContext} context */
10
- const create = context => ({
11
- CallExpression(node) {
12
- if (
13
- !isMethodCall(node, {
14
- method: 'toFixed',
15
- argumentsLength: 0,
16
- optionalCall: false,
17
- })
18
- || node.callee.object.type === 'NewExpression'
19
- ) {
20
- return;
21
- }
22
-
23
- const {sourceCode} = context;
24
- const [
25
- openingParenthesis,
26
- closingParenthesis,
27
- ] = sourceCode.getLastTokens(node, 2);
28
-
29
- return {
30
- loc: {
31
- start: sourceCode.getLoc(openingParenthesis).start,
32
- end: sourceCode.getLoc(closingParenthesis).end,
33
- },
34
- messageId: MESSAGE_ID,
35
- /** @param {import('eslint').Rule.RuleFixer} fixer */
36
- fix: fixer => appendArgument(fixer, node, '0', context),
37
- };
38
- },
39
- });
40
-
41
- /** @type {import('eslint').Rule.RuleModule} */
42
- const config = {
43
- create,
44
- meta: {
45
- type: 'suggestion',
46
- docs: {
47
- description: 'Enforce using the digits argument with `Number#toFixed()`.',
48
- recommended: 'unopinionated',
49
- },
50
- fixable: 'code',
51
- messages,
52
- },
53
- };
54
-
55
- export default config;
@@ -1,74 +0,0 @@
1
- import {isMethodCall} from './ast/index.js';
2
- import {appendArgument} from './fix/index.js';
3
-
4
- const ERROR = 'error';
5
- const SUGGESTION = 'suggestion';
6
- const messages = {
7
- [ERROR]: 'Missing the `targetOrigin` argument.',
8
- [SUGGESTION]: 'Use `{{code}}`.',
9
- };
10
-
11
- /** @param {import('eslint').Rule.RuleContext} context */
12
- function create(context) {
13
- const {sourceCode} = context;
14
- return {
15
- CallExpression(node) {
16
- if (!isMethodCall(node, {
17
- method: 'postMessage',
18
- argumentsLength: 1,
19
- optionalCall: false,
20
- })) {
21
- return;
22
- }
23
-
24
- const [penultimateToken, lastToken] = sourceCode.getLastTokens(node, 2);
25
- const replacements = [];
26
- const target = node.callee.object;
27
- if (target.type === 'Identifier') {
28
- const {name} = target;
29
-
30
- replacements.push(`${name}.location.origin`);
31
-
32
- if (name !== 'self' && name !== 'window' && name !== 'globalThis') {
33
- replacements.push('self.location.origin');
34
- }
35
- } else {
36
- replacements.push('self.location.origin');
37
- }
38
-
39
- replacements.push('\'*\'');
40
-
41
- return {
42
- loc: {
43
- start: sourceCode.getLoc(penultimateToken).end,
44
- end: sourceCode.getLoc(lastToken).end,
45
- },
46
- messageId: ERROR,
47
- suggest: replacements.map(code => ({
48
- messageId: SUGGESTION,
49
- data: {code},
50
- /** @param {import('eslint').Rule.RuleFixer} fixer */
51
- fix: fixer => appendArgument(fixer, node, code, context),
52
- })),
53
- };
54
- },
55
- };
56
- }
57
-
58
- /** @type {import('eslint').Rule.RuleModule} */
59
- const config = {
60
- create,
61
- meta: {
62
- type: 'problem',
63
- docs: {
64
- description: 'Enforce using the `targetOrigin` argument with `window.postMessage()`.',
65
- // Turned off because we can't distinguish `window.postMessage` and `{Worker,MessagePort,Client,BroadcastChannel}#postMessage()`
66
- // See #1396
67
- recommended: false,
68
- },
69
- hasSuggestions: true,
70
- messages,
71
- },
72
- };
73
-
74
- export default config;
@@ -1,9 +0,0 @@
1
- import path from 'node:path';
2
- import packageJson from '../../package.json' with {type: 'json'};
3
-
4
- const repoUrl = 'https://github.com/sindresorhus/eslint-plugin-unicorn';
5
-
6
- export default function getDocumentationUrl(filename) {
7
- const ruleName = path.basename(filename, '.js');
8
- return `${repoUrl}/blob/v${packageJson.version}/docs/rules/${ruleName}.md`;
9
- }
@@ -1,9 +0,0 @@
1
- /**
2
- @import * as ESLint from 'eslint';
3
- @import {UnicornCreate} from './to-eslint-create.js';
4
- @import {UnicornRule} from './to-eslint-rule.js';
5
- @import {UnicornContext} from './unicorn-context.js';
6
- @import {TSESTree as Estree} from '@typescript-eslint/types';
7
- */
8
-
9
- export {default as createRules} from './to-eslint-rules.js';