Sort interface and enum keys. Inspired by and sourced from eslint/sort-keys
This plugin is supported on Node 18+. You'll first need to install:
yarn add -D eslint typescript @typescript-eslint/parser
Next, install eslint-plugin-typescript-sort-keys
:
yarn add -D eslint-plugin-typescript-sort-keys
Note: If you installed ESLint globally then you must also install eslint-plugin-typescript-sort-keys
globally.
Specify the parser for typescript files in your .eslintrc
configuration file:
{
"parser": "@typescript-eslint/parser"
}
Add typescript-sort-keys
to the plugins section. You can omit the eslint-plugin-
prefix:
{
"plugins": ["typescript-sort-keys"]
}
Then configure the rules you want to use under the rules section.
{
"rules": {
"typescript-sort-keys/interface": "error",
"typescript-sort-keys/enum": "error"
}
}
Or alternatively to the individual rules, enable all rules with defaults:
{
"extends": ["plugin:typescript-sort-keys/recommended"]
}
If you'd like to enable the recommended config with interface required keys first:
{
"extends": ["plugin:typescript-sort-keys/requiredFirst"]
}
Key: ✔️ = recommended, 🔧 = fixable,
Name | Description | ||
---|---|---|---|
typescript-sort-keys/interface |
require interface keys to be sorted | ✔️ | 🔧 |
typescript-sort-keys/enum |
require enum members to be sorted | ✔️ | 🔧 |
typescript-sort-keys/string-enum |
(DEPRECATED) require string enum members to be sorted | 🔧 |