eslint-plugin-sort-properties

1.1.13 • Public • Published

eslint-plugin-sort-properties

This plugin provides rules that enforce the sorting of properties in object expressions, object destructuring for JavaScript, and type literals, interface members for TypeScript.
Inspired by eslint-plugin-sort-keys-fix and eslint-plugin-sort-destructure-keys, it is designed to be auto-fixable. But with optimization, it is up to 11x faster to fix, 6x to parse, 60x to apply rule than these plugins.benchmark
And this plugin can be configured to include leading/trailing comments as part of the property, so there's less chance of breaking the placement of comments.
Additionally, inspired by the eslint-plugin-react/jsx-sort-props rule, it supports giving higher priority to function properties when sorting.

Demo GIF

Table of Contents

Rules

⚠️ Configurations set to warn in.
🌐 Set in the all configuration.
JavaScript Set in the js configuration.
TypeScript Set in the ts configuration.
🔧 Automatically fixable by the --fix CLI option.
💡 Manually fixable by editor suggestions.

Name Description ⚠️ 🔧 💡
sort-interface Enforce interface members to be sorted. 🌐 TypeScript 🔧 💡
sort-object-destructing Enforce properties in object destructuring to be sorted. 🌐 JavaScript 🔧 💡
sort-object-expression Enforce properties in object expressions to be sorted. 🌐 JavaScript 🔧 💡
sort-type-literal Enforce properties in type literals to be sorted. 🌐 TypeScript 🔧 💡

Installation

You'll first need to install ESLint:

npm install eslint --save-dev

Next, install eslint-plugin-sort-properties:

npm install eslint-plugin-sort-properties --save-dev

Available configurations

Name Description
🌐 all Apply all rules in the sort-properties plugin. Use flat/all in eslint>=9
JavaScript js Apply JavaScript rules in the sort-properties plugin. Use flat/js in eslint>=9
TypeScript ts Apply TypeScript rules in the sort-properties plugin. Use flat/ts in eslint>=9

Configuration (legacy: .eslintrc*)

⚠️ Important note
To use rules for typescript(sort-interface, sort-type-literal), you must specify the parser as @typescript-eslint/parser.

module.exports = {
  // ...
  overrides: [
    {
      files: ["**/*.{ts,tsx}"],
      parser: "@typescript-eslint/parser",
    },
  ],
};

Use all to enable all rules. Here's an example configuration in your .eslintrc:

module.exports = {
  extends: ["plugin:sort-properties/all"],
};

or you can enable specific rules:

module.exports = {
  plugins: ["sort-properties"],
  rules: {
    "sort-properties/sort-interface": "warn",
    "sort-properties/sort-object-destructing": "warn",
    "sort-properties/sort-object-expression": [
      "warn",
      // See the options section below for more information
      {
        allowLineSeparatedGroups: false,
        caseSensitive: true,
        functionOrder: "higher",
        includeComments: "leading",
        minKeys: 2,
        natural: true,
        order: "asc",
      },
    ],
    "sort-properties/sort-type-literal": "warn",
  },
};

Configuration (new: eslint.config.js)

⚠️ Important note
To use rules for typescript(sort-interface, sort-type-literal), you must specify the parser as @typescript-eslint/parser.

const tseslint = require("typescript-eslint");

// Use utility function for typescript-eslint
module.exports = tseslint.config(
  { ... }
);

// Or manually specify the parser
module.exports = [
  {
    files: ["**/*.{ts,tsx}"],
    languageOptions: {
      parser: tseslint.parser,
    },
  },
];

Use flat/all to enable all rules. Here's an example configuration in your eslint.config.js:

const sortPropertiesPlugin = require("eslint-plugin-sort-properties");

module.exports = [
  // ...
  sortPropertiesPlugin.configs["flat/all"],
];

or you can enable specific rules:

module.exports = [
  // ...
  {
    plugins: {
      "sort-properties": require("eslint-plugin-sort-properties"),
    },
    rules: {
      "sort-properties/sort-interface": "warn",
      "sort-properties/sort-object-destructing": "warn",
      "sort-properties/sort-object-expression": [
        "warn",
        // See the options section below for more information
        {
          allowLineSeparatedGroups: false,
          caseSensitive: true,
          functionOrder: "higher",
          includeComments: "leading",
          minKeys: 2,
          natural: true,
          order: "asc",
        },
      ],
      "sort-properties/sort-type-literal": "warn",
    },
  },
];

Options

All four rules shares most of the options below:

Name Description Type Choices Default
allowLineSeparatedGroups If true, properties are separated independently by line breaks. Works same as eslint sort-keys rule. Boolean true
caseSensitive Whether the comparison is case sensitive. Boolean true
functionOrder The priority of properties which values are either method or arrow function. For example, if order is 'asc' and functionOrder is 'higher', function properties will be placed at the end. this option is not available for sort-object-destructing rule. higher, lower, equal higher
includeComments Position of comments to consider as part of the property. leading, trailing leading
minKeys Minimum number of keys to check order. Integer 2
natural Whether the comparison is using a natural order. See natural-compare Boolean true
order The order of properties. String asc, desc asc

Package Sidebar

Install

npm i eslint-plugin-sort-properties

Weekly Downloads

34

Version

1.1.13

License

MIT

Unpacked Size

29.4 kB

Total Files

11

Last publish

Collaborators

  • haenah