JSPM

  • ESM via JSPM
  • ES Module Entrypoint
  • Export Map
  • Keywords
  • License
  • Repository URL
  • TypeScript Types
  • README
  • Created
  • Published
  • Downloads 3793
  • Score
    100M100P100Q123559F
  • License MIT

Springernature shareable config for ESLint

Package Exports

  • @springernature/eslint-config
  • @springernature/eslint-config/index.js

This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (@springernature/eslint-config) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.

Readme

Springer Nature ESLint Configuration

MIT licensed

Shareable ESLint config used at Springer Nature for enforcing consistent code style across JavaScript files.

ESLint statically analyzes your code to quickly find problems. It is built into most text editors and you can run ESLint as part of your continuous integration pipeline.

[!IMPORTANT]
As of version 7.0.0 of this configuration all code format rules have been removed, and you should be using this in conjunction with our prettier configuration.

Requirements

This package requires:

  • Node version 22 or greater
  • eslint@^9.32.0
  • @eslint/js@^9.32.0
  • eslint-plugin-import@^2.32.0
  • eslint-plugin-no-use-extend-native@^0.7.2
  • eslint-plugin-promise@^7.2.1
  • eslint-plugin-unicorn@^59.0.1
  • globals@^16.3.0
  • eslint-plugin-jest@^28.11.0 (jest config only)
  • eslint-plugin-n@^17.21.3 (node config only)
  • eslint-plugin-security@^3.0.1 (node config only)

Installation

Our default export contains all of our ESLint rules.

eslint is defined in peerDependencies, which means that you will need to add these to your own project's devDependencies.

Install our config and all it's required dependencies to your devDependencies with the following command:

npm install -D eslint@^9.32.0 @eslint/js@^9.32.0 eslint-plugin-import@^2.32.0 eslint-plugin-no-use-extend-native@^0.7.2 eslint-plugin-promise@^7.2.1 eslint-plugin-unicorn@^59.0.1 globals@^16.3.0 @springernature/eslint-config

If configuring for jest, you can add the additional dependency to your devDependencies with the following command:

npm install -D eslint-plugin-jest@^28.11.0

If configuring for node, you can add the additional dependencies to your devDependencies with the following command:

npm install -D eslint-plugin-n@^17.21.3 eslint-plugin-security@^3.0.1

Usage

You then need to setup the configuration so it can be used in your project.

  1. Create an eslint.config.js file in the root of your project.
  2. Configure the core configuration as in the example below. All implementations must use this as a minimum.
  3. Configure one or more of the additional configurations as per your requirements.

Core Configuration

import {coreConfig} from '@springernature/eslint-config';
import {defineConfig} from "eslint/config";

export default defineConfig([
  {
    files: ["**/*.js"],
    extends: [coreConfig],
    rules: {
      // custom rules
    },
  },
]);

Additional Configurations

Import the configuration(s) your need for your project, and then add the configuration map(s) to the exported array.

import {coreConfig, nodeConfig, browserConfig, jestConfig} from '@springernature/eslint-config';
import {defineConfig} from "eslint/config";
import globals from 'globals';

export default defineConfig([
  {
    files: ["**/*.js"],
    languageOptions: {
      globals: {...globals.node, ...globals.browser}
    },
    extends: [coreConfig],
    rules: {
      // custom rules
    },
  },
  {
    files: ["server/**/*.js", "cli/**/*.js"],
    extends: [nodeConfig],
    rules: {
      // custom rules
    },
  },
  {
    files: ["lib/frontend/**/*.js"],
    extends: [browserConfig],
    rules: {
      // custom rules
    },
  },
  {
    files: ["**/*(spec|test).js"],
    extends: [jestConfig]
  }
]);

Different versions of Jest

The behaviour of some rules (specifically no-deprecated-functions) change depending on the version of Jest being used.

By default, this plugin will attempt to locate Jest using require.resolve, meaning it will start looking in the closest node_modules folder to the file being linted and work its way up.

Since we cache the automatically determined version, if you're linting sub-folders that have different versions of Jest, you may find that the wrong version of Jest is considered when linting. You can work around this by providing the Jest version explicitly in nested ESLint configs:

{
  "settings": {
    "jest": {
      "version": 27
    }
  }
}

To avoid hard-coding a number, you can also fetch it from the installed version of Jest in your eslint.config.js file:

module.exports = {
  settings: {
    jest: {
      version: require('jest/package.json').version,
    },
  },
};

Linting your project

There are several ways that ESLint can be used, however, it is recommended to run it from within your code editor.

Visual code, for example, has an eslint-vscode plugin.

If you don't already use ESLint, it is likely that you will want to run it against your whole project, and then use the editor to maintain it's usage as you make code changes.

To do this, you can run:

npx eslint 

This will format all matching files according to the ESLint configuration. This could result in a large number of stylistic changes to the code, mostly from changing quote style, adding spaces around braces, etc. If you want to start using ESLint more incrementally, you can instruct it to ignore code.

Ignore code

Often you will want to ignore certain files or folders from being formatted. For example, compiled code or test coverage folders.

You can do this by adding an ignores property in your eslint.config.js file.

// eslint.config.js
export default [
  {
    ignores: [".config/*"]
  }
];

Contributing

This package is used by many active Springer Nature projects. We always welcome issues and pull requests, but we may not always be able to merge your suggestions.

If we decide that we can't merge your PR or act on your issue, it's nothing personal! We love to see new contributors, and we strive to provide a welcoming and inclusive environment.

License

The eslint-config-springernature repository is licensed under the MIT License.
All packages within this repository are licensed under the MIT License.
Copyright © 2025, Springer Nature