UNPKG

eslint-plugin-unicorn-x

Version:
260 lines (223 loc) • 48.5 kB
# eslint-plugin-unicorn-x > More than 100 powerful ESLint rules A modern, faster and lighter fork of [`eslint-plugin-unicorn`](https://github.com/sindresorhus/eslint-plugin-unicorn). ## Install ```sh npm install --save-dev eslint eslint-plugin-unicorn-x ``` **Requires ESLint `>=9.29.0` and [flat config](https://eslint.org/docs/latest/use/configure/configuration-files).** ## Usage Use a [preset config](#preset-configs) or configure each rule in `eslint.config.js`. If you don't use the preset, ensure you use the same `languageOptions` config as below. ```js import eslintPluginUnicorn from 'eslint-plugin-unicorn-x'; import globals from 'globals'; export default [ { languageOptions: { globals: globals.builtin, }, plugins: { unicorn: eslintPluginUnicorn, }, rules: { 'unicorn-x/better-regex': 'error', 'unicorn-x/…': 'error', }, }, // … ]; ``` ## Why this fork exists This fork exists to provide various performance improvements and a reduced install footprint. Much of this cannot be contributed upstream due to differences in opinion on dependency selection, backwards compatibility requirements, and so on. We will contribute what we can upstream, and continue to track the original, allowing this plugin to exist as a mostly drop-in replacement to get an easy bump in lint performance. ## Migration from `eslint-plugin-unicorn` If you are migrating from `eslint-plugin-unicorn`, simply replace `unicorn` with `unicorn-x` in your rules and update the plugin import path: ```json5 { "rules": { // before "unicorn/better-regex": "error", // after "unicorn-x/better-regex": "error", } } ``` ## Rules <!-- Do not manually modify this list. Run: `npm run fix:eslint-docs` --> <!-- begin auto-generated rules list --> šŸ’¼ [Configurations](https://github.com/es-tooling/eslint-plugin-unicorn-x#recommended-config) enabled in.\ āœ… Set in the `recommended` [configuration](https://github.com/es-tooling/eslint-plugin-unicorn-x#recommended-config).\ šŸ”§ Automatically fixable by the [`--fix` CLI option](https://eslint.org/docs/user-guide/command-line-interface#--fix).\ šŸ’” Manually fixable by [editor suggestions](https://eslint.org/docs/latest/use/core-concepts#rule-suggestions). | NameĀ Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā Ā  | Description | šŸ’¼ | šŸ”§ | šŸ’” | | :----------------------------------------------------------------------------------------------- | :---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | :- | :- | :- | | [better-regex](docs/rules/better-regex.md) | Improve regexes by making them shorter, consistent, and safer. | | šŸ”§ | | | [catch-error-name](docs/rules/catch-error-name.md) | Enforce a specific parameter name in catch clauses. | āœ… | šŸ”§ | | | [consistent-assert](docs/rules/consistent-assert.md) | Enforce consistent assertion style with `node:assert`. | āœ… | šŸ”§ | | | [consistent-date-clone](docs/rules/consistent-date-clone.md) | Prefer passing `Date` directly to the constructor when cloning. | āœ… | šŸ”§ | | | [consistent-destructuring](docs/rules/consistent-destructuring.md) | Use destructured variables over properties. | | | šŸ’” | | [consistent-empty-array-spread](docs/rules/consistent-empty-array-spread.md) | Prefer consistent types when spreading a ternary in an array literal. | āœ… | šŸ”§ | | | [consistent-existence-index-check](docs/rules/consistent-existence-index-check.md) | Enforce consistent style for element existence checks with `indexOf()`, `lastIndexOf()`, `findIndex()`, and `findLastIndex()`. | āœ… | šŸ”§ | | | [consistent-function-scoping](docs/rules/consistent-function-scoping.md) | Move function definitions to the highest possible scope. | āœ… | | | | [custom-error-definition](docs/rules/custom-error-definition.md) | Enforce correct `Error` subclassing. | | šŸ”§ | | | [empty-brace-spaces](docs/rules/empty-brace-spaces.md) | Enforce no spaces between braces. | āœ… | šŸ”§ | | | [error-message](docs/rules/error-message.md) | Enforce passing a `message` value when creating a built-in error. | āœ… | | | | [escape-case](docs/rules/escape-case.md) | Require escape sequences to use uppercase or lowercase values. | āœ… | šŸ”§ | | | [expiring-todo-comments](docs/rules/expiring-todo-comments.md) | Add expiration conditions to TODO comments. | āœ… | | | | [explicit-length-check](docs/rules/explicit-length-check.md) | Enforce explicitly comparing the `length` or `size` property of a value. | āœ… | šŸ”§ | šŸ’” | | [filename-case](docs/rules/filename-case.md) | Enforce a case style for filenames. | āœ… | | | | [import-style](docs/rules/import-style.md) | Enforce specific import styles per module. | āœ… | | | | [new-for-builtins](docs/rules/new-for-builtins.md) | Enforce the use of `new` for all builtins, except `String`, `Number`, `Boolean`, `Symbol` and `BigInt`. | āœ… | šŸ”§ | šŸ’” | | [no-abusive-eslint-disable](docs/rules/no-abusive-eslint-disable.md) | Enforce specifying rules to disable in `eslint-disable` comments. | āœ… | | | | [no-accessor-recursion](docs/rules/no-accessor-recursion.md) | Disallow recursive access to `this` within getters and setters. | āœ… | | | | [no-anonymous-default-export](docs/rules/no-anonymous-default-export.md) | Disallow anonymous functions and classes as the default export. | āœ… | | šŸ’” | | [no-array-callback-reference](docs/rules/no-array-callback-reference.md) | Prevent passing a function reference directly to iterator methods. | āœ… | | šŸ’” | | [no-array-for-each](docs/rules/no-array-for-each.md) | Prefer `for…of` over the `forEach` method. | āœ… | šŸ”§ | šŸ’” | | [no-array-method-this-argument](docs/rules/no-array-method-this-argument.md) | Disallow using the `this` argument in array methods. | āœ… | šŸ”§ | šŸ’” | | [no-array-reduce](docs/rules/no-array-reduce.md) | Disallow `Array#reduce()` and `Array#reduceRight()`. | āœ… | | | | [no-array-reverse](docs/rules/no-array-reverse.md) | Prefer `Array#toReversed()` over `Array#reverse()`. | āœ… | | šŸ’” | | [no-await-expression-member](docs/rules/no-await-expression-member.md) | Disallow member access from await expression. | āœ… | šŸ”§ | | | [no-await-in-promise-methods](docs/rules/no-await-in-promise-methods.md) | Disallow using `await` in `Promise` method parameters. | āœ… | | šŸ’” | | [no-console-spaces](docs/rules/no-console-spaces.md) | Do not use leading/trailing space between `console.log` parameters. | āœ… | šŸ”§ | | | [no-document-cookie](docs/rules/no-document-cookie.md) | Do not use `document.cookie` directly. | āœ… | | | | [no-empty-file](docs/rules/no-empty-file.md) | Disallow empty files. | āœ… | | | | [no-for-loop](docs/rules/no-for-loop.md) | Do not use a `for` loop that can be replaced with a `for-of` loop. | āœ… | šŸ”§ | šŸ’” | | [no-hex-escape](docs/rules/no-hex-escape.md) | Enforce the use of Unicode escapes instead of hexadecimal escapes. | āœ… | šŸ”§ | | | [no-instanceof-builtins](docs/rules/no-instanceof-builtins.md) | Disallow `instanceof` with built-in objects | āœ… | šŸ”§ | šŸ’” | | [no-invalid-fetch-options](docs/rules/no-invalid-fetch-options.md) | Disallow invalid options in `fetch()` and `new Request()`. | āœ… | | | | [no-invalid-remove-event-listener](docs/rules/no-invalid-remove-event-listener.md) | Prevent calling `EventTarget#removeEventListener()` with the result of an expression. | āœ… | | | | [no-keyword-prefix](docs/rules/no-keyword-prefix.md) | Disallow identifiers starting with `new` or `class`. | | | | | [no-lonely-if](docs/rules/no-lonely-if.md) | Disallow `if` statements as the only statement in `if` blocks without `else`. | āœ… | šŸ”§ | | | [no-magic-array-flat-depth](docs/rules/no-magic-array-flat-depth.md) | Disallow a magic number as the `depth` argument in `Array#flat(…).` | āœ… | | | | [no-named-default](docs/rules/no-named-default.md) | Disallow named usage of default import and export. | āœ… | šŸ”§ | | | [no-negated-condition](docs/rules/no-negated-condition.md) | Disallow negated conditions. | āœ… | šŸ”§ | | | [no-negation-in-equality-check](docs/rules/no-negation-in-equality-check.md) | Disallow negated expression in equality check. | āœ… | | šŸ’” | | [no-nested-ternary](docs/rules/no-nested-ternary.md) | Disallow nested ternary expressions. | āœ… | šŸ”§ | | | [no-new-array](docs/rules/no-new-array.md) | Disallow `new Array()`. | āœ… | šŸ”§ | šŸ’” | | [no-new-buffer](docs/rules/no-new-buffer.md) | Enforce the use of `Buffer.from()` and `Buffer.alloc()` instead of the deprecated `new Buffer()`. | āœ… | šŸ”§ | šŸ’” | | [no-null](docs/rules/no-null.md) | Disallow the use of the `null` literal. | āœ… | šŸ”§ | šŸ’” | | [no-object-as-default-parameter](docs/rules/no-object-as-default-parameter.md) | Disallow the use of objects as default parameters. | āœ… | | | | [no-process-exit](docs/rules/no-process-exit.md) | Disallow `process.exit()`. | āœ… | | | | [no-single-promise-in-promise-methods](docs/rules/no-single-promise-in-promise-methods.md) | Disallow passing single-element arrays to `Promise` methods. | āœ… | šŸ”§ | šŸ’” | | [no-static-only-class](docs/rules/no-static-only-class.md) | Disallow classes that only have static members. | āœ… | šŸ”§ | | | [no-thenable](docs/rules/no-thenable.md) | Disallow `then` property. | āœ… | | | | [no-this-assignment](docs/rules/no-this-assignment.md) | Disallow assigning `this` to a variable. | āœ… | | | | [no-typeof-undefined](docs/rules/no-typeof-undefined.md) | Disallow comparing `undefined` using `typeof`. | āœ… | šŸ”§ | šŸ’” | | [no-unnecessary-array-flat-depth](docs/rules/no-unnecessary-array-flat-depth.md) | Disallow using `1` as the `depth` argument of `Array#flat()`. | āœ… | šŸ”§ | | | [no-unnecessary-array-splice-count](docs/rules/no-unnecessary-array-splice-count.md) | Disallow using `.length` or `Infinity` as the `deleteCount` or `skipCount` argument of `Array#{splice,toSpliced}()`. | āœ… | šŸ”§ | | | [no-unnecessary-await](docs/rules/no-unnecessary-await.md) | Disallow awaiting non-promise values. | āœ… | šŸ”§ | | | [no-unnecessary-polyfills](docs/rules/no-unnecessary-polyfills.md) | Enforce the use of built-in methods instead of unnecessary polyfills. | āœ… | | | | [no-unnecessary-slice-end](docs/rules/no-unnecessary-slice-end.md) | Disallow using `.length` or `Infinity` as the `end` argument of `{Array,String,TypedArray}#slice()`. | āœ… | šŸ”§ | | | [no-unreadable-array-destructuring](docs/rules/no-unreadable-array-destructuring.md) | Disallow unreadable array destructuring. | āœ… | šŸ”§ | | | [no-unreadable-iife](docs/rules/no-unreadable-iife.md) | Disallow unreadable IIFEs. | āœ… | | | | [no-unused-properties](docs/rules/no-unused-properties.md) | Disallow unused object properties. | | | | | [no-useless-error-capture-stack-trace](docs/rules/no-useless-error-capture-stack-trace.md) | Disallow unnecessary `Error.captureStackTrace(…)`. | āœ… | šŸ”§ | | | [no-useless-fallback-in-spread](docs/rules/no-useless-fallback-in-spread.md) | Disallow useless fallback when spreading in object literals. | āœ… | šŸ”§ | | | [no-useless-length-check](docs/rules/no-useless-length-check.md) | Disallow useless array length check. | āœ… | šŸ”§ | | | [no-useless-promise-resolve-reject](docs/rules/no-useless-promise-resolve-reject.md) | Disallow returning/yielding `Promise.resolve/reject()` in async functions or promise callbacks | āœ… | šŸ”§ | | | [no-useless-spread](docs/rules/no-useless-spread.md) | Disallow unnecessary spread. | āœ… | šŸ”§ | | | [no-useless-switch-case](docs/rules/no-useless-switch-case.md) | Disallow useless case in switch statements. | āœ… | | šŸ’” | | [no-useless-undefined](docs/rules/no-useless-undefined.md) | Disallow useless `undefined`. | āœ… | šŸ”§ | | | [no-zero-fractions](docs/rules/no-zero-fractions.md) | Disallow number literals with zero fractions or dangling dots. | āœ… | šŸ”§ | | | [number-literal-case](docs/rules/number-literal-case.md) | Enforce proper case for numeric literals. | āœ… | šŸ”§ | | | [numeric-separators-style](docs/rules/numeric-separators-style.md) | Enforce the style of numeric separators by correctly grouping digits. | āœ… | šŸ”§ | | | [prefer-add-event-listener](docs/rules/prefer-add-event-listener.md) | Prefer `.addEventListener()` and `.removeEventListener()` over `on`-functions. | āœ… | šŸ”§ | | | [prefer-array-find](docs/rules/prefer-array-find.md) | Prefer `.find(…)` and `.findLast(…)` over the first or last element from `.filter(…)`. | āœ… | šŸ”§ | šŸ’” | | [prefer-array-flat](docs/rules/prefer-array-flat.md) | Prefer `Array#flat()` over legacy techniques to flatten arrays. | āœ… | šŸ”§ | | | [prefer-array-flat-map](docs/rules/prefer-array-flat-map.md) | Prefer `.flatMap(…)` over `.map(…).flat()`. | āœ… | šŸ”§ | | | [prefer-array-index-of](docs/rules/prefer-array-index-of.md) | Prefer `Array#{indexOf,lastIndexOf}()` over `Array#{findIndex,findLastIndex}()` when looking for the index of an item. | āœ… | šŸ”§ | šŸ’” | | [prefer-array-some](docs/rules/prefer-array-some.md) | Prefer `.some(…)` over `.filter(…).length` check and `.{find,findLast,findIndex,findLastIndex}(…)`. | āœ… | šŸ”§ | šŸ’” | | [prefer-at](docs/rules/prefer-at.md) | Prefer `.at()` method for index access and `String#charAt()`. | āœ… | šŸ”§ | šŸ’” | | [prefer-blob-reading-methods](docs/rules/prefer-blob-reading-methods.md) | Prefer `Blob#arrayBuffer()` over `FileReader#readAsArrayBuffer(…)` and `Blob#text()` over `FileReader#readAsText(…)`. | āœ… | | | | [prefer-class-fields](docs/rules/prefer-class-fields.md) | Prefer class field declarations over `this` assignments in constructors. | āœ… | šŸ”§ | šŸ’” | | [prefer-code-point](docs/rules/prefer-code-point.md) | Prefer `String#codePointAt(…)` over `String#charCodeAt(…)` and `String.fromCodePoint(…)` over `String.fromCharCode(…)`. | āœ… | | šŸ’” | | [prefer-date-now](docs/rules/prefer-date-now.md) | Prefer `Date.now()` to get the number of milliseconds since the Unix Epoch. | āœ… | šŸ”§ | | | [prefer-default-parameters](docs/rules/prefer-default-parameters.md) | Prefer default parameters over reassignment. | āœ… | | šŸ’” | | [prefer-dom-node-append](docs/rules/prefer-dom-node-append.md) | Prefer `Node#append()` over `Node#appendChild()`. | āœ… | šŸ”§ | | | [prefer-dom-node-dataset](docs/rules/prefer-dom-node-dataset.md) | Prefer using `.dataset` on DOM elements over calling attribute methods. | āœ… | šŸ”§ | | | [prefer-dom-node-remove](docs/rules/prefer-dom-node-remove.md) | Prefer `childNode.remove()` over `parentNode.removeChild(childNode)`. | āœ… | šŸ”§ | šŸ’” | | [prefer-dom-node-text-content](docs/rules/prefer-dom-node-text-content.md) | Prefer `.textContent` over `.innerText`. | āœ… | | šŸ’” | | [prefer-event-target](docs/rules/prefer-event-target.md) | Prefer `EventTarget` over `EventEmitter`. | āœ… | | | | [prefer-export-from](docs/rules/prefer-export-from.md) | Prefer `export…from` when re-exporting. | āœ… | šŸ”§ | šŸ’” | | [prefer-global-this](docs/rules/prefer-global-this.md) | Prefer `globalThis` over `window`, `self`, and `global`. | āœ… | šŸ”§ | | | [prefer-import-meta-properties](docs/rules/prefer-import-meta-properties.md) | Prefer `import.meta.{dirname,filename}` over legacy techniques for getting file paths. | | šŸ”§ | | | [prefer-includes](docs/rules/prefer-includes.md) | Prefer `.includes()` over `.indexOf()`, `.lastIndexOf()`, and `Array#some()` when checking for existence or non-existence. | āœ… | šŸ”§ | šŸ’” | | [prefer-json-parse-buffer](docs/rules/prefer-json-parse-buffer.md) | Prefer reading a JSON file as a buffer. | | šŸ”§ | | | [prefer-keyboard-event-key](docs/rules/prefer-keyboard-event-key.md) | Prefer `KeyboardEvent#key` over `KeyboardEvent#keyCode`. | āœ… | šŸ”§ | | | [prefer-logical-operator-over-ternary](docs/rules/prefer-logical-operator-over-ternary.md) | Prefer using a logical operator over a ternary. | āœ… | | šŸ’” | | [prefer-math-min-max](docs/rules/prefer-math-min-max.md) | Prefer `Math.min()` and `Math.max()` over ternaries for simple comparisons. | āœ… | šŸ”§ | | | [prefer-math-trunc](docs/rules/prefer-math-trunc.md) | Enforce the use of `Math.trunc` instead of bitwise operators. | āœ… | šŸ”§ | šŸ’” | | [prefer-modern-dom-apis](docs/rules/prefer-modern-dom-apis.md) | Prefer `.before()` over `.insertBefore()`, `.replaceWith()` over `.replaceChild()`, prefer one of `.before()`, `.after()`, `.append()` or `.prepend()` over `insertAdjacentText()` and `insertAdjacentElement()`. | āœ… | šŸ”§ | | | [prefer-modern-math-apis](docs/rules/prefer-modern-math-apis.md) | Prefer modern `Math` APIs over legacy patterns. | āœ… | šŸ”§ | | | [prefer-module](docs/rules/prefer-module.md) | Prefer JavaScript modules (ESM) over CommonJS. | āœ… | šŸ”§ | šŸ’” | | [prefer-native-coercion-functions](docs/rules/prefer-native-coercion-functions.md) | Prefer using `String`, `Number`, `BigInt`, `Boolean`, and `Symbol` directly. | āœ… | šŸ”§ | | | [prefer-negative-index](docs/rules/prefer-negative-index.md) | Prefer negative index over `.length - index` when possible. | āœ… | šŸ”§ | | | [prefer-node-protocol](docs/rules/prefer-node-protocol.md) | Prefer using the `node:` protocol when importing Node.js builtin modules. | āœ… | šŸ”§ | | | [prefer-number-properties](docs/rules/prefer-number-properties.md) | Prefer `Number` static properties over global ones. | āœ… | šŸ”§ | šŸ’” | | [prefer-object-from-entries](docs/rules/prefer-object-from-entries.md) | Prefer using `Object.fromEntries(…)` to transform a list of key-value pairs into an object. | āœ… | šŸ”§ | | | [prefer-optional-catch-binding](docs/rules/prefer-optional-catch-binding.md) | Prefer omitting the `catch` binding parameter. | āœ… | šŸ”§ | | | [prefer-prototype-methods](docs/rules/prefer-prototype-methods.md) | Prefer borrowing methods from the prototype instead of the instance. | āœ… | šŸ”§ | | | [prefer-query-selector](docs/rules/prefer-query-selector.md) | Prefer `.querySelector()` over `.getElementById()`, `.querySelectorAll()` over `.getElementsByClassName()` and `.getElementsByTagName()` and `.getElementsByName()`. | āœ… | šŸ”§ | | | [prefer-reflect-apply](docs/rules/prefer-reflect-apply.md) | Prefer `Reflect.apply()` over `Function#apply()`. | āœ… | šŸ”§ | | | [prefer-regexp-test](docs/rules/prefer-regexp-test.md) | Prefer `RegExp#test()` over `String#match()` and `RegExp#exec()`. | āœ… | šŸ”§ | šŸ’” | | [prefer-set-has](docs/rules/prefer-set-has.md) | Prefer `Set#has()` over `Array#includes()` when checking for existence or non-existence. | āœ… | šŸ”§ | šŸ’” | | [prefer-set-size](docs/rules/prefer-set-size.md) | Prefer using `Set#size` instead of `Array#length`. | āœ… | šŸ”§ | | | [prefer-single-call](docs/rules/prefer-single-call.md) | Enforce combining multiple `Array#push()`, `Element#classList.{add,remove}()`, and `importScripts()` into one call. | āœ… | šŸ”§ | šŸ’” | | [prefer-spread](docs/rules/prefer-spread.md) | Prefer the spread operator over `Array.from(…)`, `Array#concat(…)`, `Array#{slice,toSpliced}()` and `String#split('')`. | āœ… | šŸ”§ | šŸ’” | | [prefer-string-raw](docs/rules/prefer-string-raw.md) | Prefer using the `String.raw` tag to avoid escaping `\`. | āœ… | šŸ”§ | | | [prefer-string-replace-all](docs/rules/prefer-string-replace-all.md) | Prefer `String#replaceAll()` over regex searches with the global flag. | āœ… | šŸ”§ | | | [prefer-string-slice](docs/rules/prefer-string-slice.md) | Prefer `String#slice()` over `String#substr()` and `String#substring()`. | āœ… | šŸ”§ | | | [prefer-string-starts-ends-with](docs/rules/prefer-string-starts-ends-with.md) | Prefer `String#startsWith()` & `String#endsWith()` over `RegExp#test()`. | āœ… | šŸ”§ | šŸ’” | | [prefer-string-trim-start-end](docs/rules/prefer-string-trim-start-end.md) | Prefer `String#trimStart()` / `String#trimEnd()` over `String#trimLeft()` / `String#trimRight()`. | āœ… | šŸ”§ | | | [prefer-structured-clone](docs/rules/prefer-structured-clone.md) | Prefer using `structuredClone` to create a deep clone. | āœ… | | šŸ’” | | [prefer-switch](docs/rules/prefer-switch.md) | Prefer `switch` over multiple `else-if`. | āœ… | šŸ”§ | | | [prefer-ternary](docs/rules/prefer-ternary.md) | Prefer ternary expressions over simple `if-else` statements. | āœ… | šŸ”§ | | | [prefer-top-level-await](docs/rules/prefer-top-level-await.md) | Prefer top-level await over top-level promises and async function calls. | āœ… | | šŸ’” | | [prefer-type-error](docs/rules/prefer-type-error.md) | Enforce throwing `TypeError` in type checking conditions. | āœ… | šŸ”§ | | | [prevent-abbreviations](docs/rules/prevent-abbreviations.md) | Prevent abbreviations. | āœ… | šŸ”§ | | | [relative-url-style](docs/rules/relative-url-style.md) | Enforce consistent relative URL style. | āœ… | šŸ”§ | šŸ’” | | [require-array-join-separator](docs/rules/require-array-join-separator.md) | Enforce using the separator argument with `Array#join()`. | āœ… | šŸ”§ | | | [require-module-specifiers](docs/rules/require-module-specifiers.md) | Require non-empty specifier list in import and export statements. | āœ… | šŸ”§ | šŸ’” | | [require-number-to-fixed-digits-argument](docs/rules/require-number-to-fixed-digits-argument.md) | Enforce using the digits argument with `Number#toFixed()`. | āœ… | šŸ”§ | | | [require-post-message-target-origin](docs/rules/require-post-message-target-origin.md) | Enforce using the `targetOrigin` argument with `window.postMessage()`. | | | šŸ’” | | [string-content](docs/rules/string-content.md) | Enforce better string content. | | šŸ”§ | šŸ’” | | [switch-case-braces](docs/rules/switch-case-braces.md) | Enforce consistent brace style for `case` clauses. | āœ… | šŸ”§ | | | [template-indent](docs/rules/template-indent.md) | Fix whitespace-insensitive template indentation. | āœ… | šŸ”§ | | | [text-encoding-identifier-case](docs/rules/text-encoding-identifier-case.md) | Enforce consistent case for text encoding identifiers. | āœ… | šŸ”§ | šŸ’” | | [throw-new-error](docs/rules/throw-new-error.md) | Require `new` when creating an error. | āœ… | šŸ”§ | | <!-- end auto-generated rules list --> ### Deleted and deprecated rules See [the list](docs/deleted-and-deprecated-rules.md). ## Preset configs See the [ESLint docs](https://eslint.org/docs/latest/use/configure/configuration-files) for more information about extending config files. **Note**: Preset configs will also enable the correct [language options](https://eslint.org/docs/latest/use/configure/language-options). ### Recommended config This plugin exports a `recommended` config that enforces good practices. ```js import eslintPluginUnicorn from 'eslint-plugin-unicorn-x'; export default [ // … eslintPluginUnicorn.configs.recommended, { rules: { 'unicorn-x/better-regex': 'warn', }, }, ]; ``` ### All config This plugin exports an `all` that makes use of all rules (except for deprecated ones). ```js import eslintPluginUnicorn from 'eslint-plugin-unicorn-x'; export default [ // … eslintPluginUnicorn.configs.all, { rules: { 'unicorn-x/better-regex': 'warn', }, }, ]; ```