Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

neostandard

neostandard118.7kMIT0.12.0TypeScript support: included

A modern successor to standard

readme

neostandard

npm version npm downloads neostandard javascript style

A spiritual successor to the standard javascript style guide

Initial development sponsored by:

platformatic

Table of Contents

Quick Start

Migrate from standard

  1. npm install -D neostandard eslint
  2. npx neostandard --migrate > eslint.config.js (uses our config helper)
  3. Replace standard with eslint in all places where you run standard, eg. "scripts" and .github/workflows/ (neostandard CLI tracked in #2)
  4. (Add ESLint editor integration, eg. VS Code ESLint extension)
  5. Cleanup:
    • npm uninstall standard
    • Remove unused "standard" top level key from your package.json
    • Deactivate standard specific integrations if you no longer use them (eg. vscode-standard))

Add to new project

  1. npm install -D neostandard eslint
  2. Add an eslint.config.js:

    Using config helper:

    npx neostandard --esm > eslint.config.js

    Or to get CommonJS:

    npx neostandard > eslint.config.js

    Or manually create the file as ESM:

    import neostandard from 'neostandard'
    
    export default neostandard({
      // options
    })

    Or as CommonJS:

    module.exports = require('neostandard')({
      // options
    })
  3. Run neostandard by running ESLint, eg. using npx eslint, npx eslint --fix or similar

Configuration options

  • env - string[] - adds additional globals by importing them from the globals npm module
  • files - string[] - additional file patterns to match. Uses the same shape as ESLint files
  • filesTs - string[] - additional file patterns for the TypeScript configs to match. Uses the same shape as ESLint files
  • globals - string[] | object - an array of names of globals or an object of the same shape as ESLint languageOptions.globals
  • ignores - string[] - an array of glob patterns for files that the config should not apply to, see ESLint documentation for details
  • noJsx - boolean - if set, no jsx rules will be added. Useful if for some reason its clashing with your use of JSX-style syntax
  • noStyle - boolean - if set, no style rules will be added. Especially useful when combined with Prettier, dprint or similar
  • semi - boolean - if set, enforce rather than forbid semicolons (same as semistandard did)
  • ts - boolean - if set, TypeScript syntax will be supported and *.ts (including *.d.ts) will be checked. To add additional file patterns to the TypeScript checks, use filesTs

Extending

The neostandard() function returns an ESLint config array which is intended to be exported directly or, if you want to modify or extend the config, can be combined with other configs like any other ESLint config array:

import neostandard from 'neostandard'
import jsdoc from 'eslint-plugin-jsdoc';

export default [
  ...neostandard(),
  jsdoc.configs['flat/recommended-typescript-flavor'],
]

Do note that neostandard() is intended to be a complete linting config in itself, only extend it if you have needs that goes beyond what neostandard provides, and open an issue if you believe neostandard itself should be extended or changed in that direction.

It's recommended to stay compatible with the plain config when extending and only make your config stricter, not relax any of the rules, as your project would then still pass when using just the plain neostandard-config, which helps people know what baseline to expect from your project.

Additional exports

resolveIgnoresFromGitignore()

Finds a .gitignore file that resides in the same directory as the ESLint config file and returns an array of ESLint ignores that matches the same files.

ESM:

import neostandard, { resolveIgnoresFromGitignore } from 'neostandard'

export default neostandard({
  ignores: resolveIgnoresFromGitignore(),
})

CommonJS:

module.exports = require('neostandard')({
  ignores: require('neostandard').resolveIgnoresFromGitignore(),
})

Exported plugins

neostandard exports all the ESLint plugins that it uses. This to ensure that users who need to reference the plugin themselves will use the exact same instance of the plugin, which is a necessity when a plugin prefix is defined in multiple places.

List of exported plugins

Usage of exported plugin

If one eg. wants to add the eslint-plugin-n recommended config, then one can do:

import neostandard, { plugins } from 'neostandard'

export default [
  ...neostandard(),
  plugins.n.configs['flat/recommended'],
]

Missing for 1.0.0 release

  • Investigate a dedicated neostandard runner: #33 / #2

Full list in 1.0.0 milestone

Differences to standard / eslint-config-standard 17.x

Relaxed rules

Config helper

You can use the provided CLI tool to generate a config for you:

neostandard --semi --ts > eslint.config.js

To see all available flags, run:

neostandard --help

Config migration

The CLI tool can also migrate an existing "standard" configuration from package.json:

neostandard --migrate > eslint.config.js

Migrations can also be extended, so to eg. migrate a semistandard setup, do:

neostandard --semi --migrate > eslint.config.js

Readme badges

Yes! If you use neostandard in your project, you can include one of these badges in your readme to let people know that your code is using the neostandard style.

neostandard javascript style

[![neostandard javascript style](https://img.shields.io/badge/neo-standard-7fffff?style=flat&labelColor=ff80ff)](https://github.com/neostandard/neostandard)

neostandard javascript style

[![neostandard javascript style](https://img.shields.io/badge/code_style-neostandard-7fffff?style=flat&labelColor=ff80ff)](https://github.com/neostandard/neostandard)

neostandard javascript style

[![neostandard javascript style](https://img.shields.io/badge/code_style-neostandard-brightgreen?style=flat)](https://github.com/neostandard/neostandard)

Mission statement

Prior to the 1.0.0 release we are still rapidly evolving with fixes and improvements to reach rule parity with standard, hence more breaking changes will be experienced until then, as well as evolution of this statement

neostandard intends to set an expectable baseline for project linting that's descriptive of best practices rather than prescriptive of any opinionated approach.

Rule guidelines

  1. neostandard rules describes current best practices in the community and help align developers, contributors and maintainers along those
  2. neostandard rules are not a tool to promote changed practices within the community by prescribing new such practices
  3. neostandard rule changes and additions should be aligned with projects prior to being released, by eg. sending PR:s to them to align them ahead of time. When new best practices are incompatible with current best practices, rules should first be relaxed to allow for both approaches, then be made stricter when the community has moved to the new approach
  4. neostandard rule changes and additions should improve the description of project best practices, not prescribe new practices
  5. neostandard should, when faced with no clear best practice, avoid adding such a rule as it risks becoming prescriptive rather than descriptive. If leaving out such a rule would make neostandard an incomplete baseline config, and the community is split between a few clear alternatives (such as semi), then making it configurable can enable it to still be added, but that should only be done in exceptional cases

Governance

neostandard is a community project with open governance.

See GOVERNANCE.md for specifics.

Used by

A subset of some of the projects that rely on neostandard:

changelog

Changelog

0.12.0 (2024-12-09)

⚠ BREAKING CHANGES

  • re-enabled import rules are breaking change

🌟 Features

  • deps: update dependency eslint-plugin-promise to ^7.2.1 (#223) (33184e8)
  • deps: update dependency eslint-plugin-react to ^7.37.2 (#179) (11380cb)
  • deps: update dependency typescript-eslint to ^8.17.0 (#224) (a2d3577)
  • re-enabled import rules are breaking change (dcf46c8)
  • reenabled import checking rules (eslint-plugin-import) (#197) (629e936)

🩹 Fixes

  • deps: update dependency globals to ^15.13.0 (#225) (cb93f15)
  • pin @stylistic/eslint-plugin to 2.11.0 (#230) (5828bac)
  • swap to import-x/ to improve TS resolver (#231) (10bf1ab)

0.11.9 (2024-11-25)

🌟 Features

  • deps: update dependency @stylistic/eslint-plugin to ^2.11.0 (#216) (50254ae)
  • deps: update dependency eslint-plugin-n to ^17.14.0 (#215) (b86e638)
  • deps: update dependency typescript-eslint to ^8.15.0 (#213) (23d362b)

🩹 Fixes

0.11.8 (2024-11-12)

🌟 Features

  • deps: update dependency @stylistic/eslint-plugin to ^2.10.1 (#204) (04a4d2a)
  • deps: update dependency eslint-plugin-n to ^17.13.1 (#202) (503d0cd)
  • deps: update dependency typescript-eslint to ^8.13.0 (#199) (c470424)

🩹 Fixes

  • deps: update dependency globals to ^15.12.0 (#206) (1be2d6b)

0.11.7 (2024-10-23)

🌟 Features

  • deps: update dependency @stylistic/eslint-plugin to ^2.9.0 (#186) (a5008be)
  • deps: update dependency eslint-plugin-n to ^17.11.1 (#187) (3315b41)
  • deps: update dependency typescript-eslint to ^8.10.0 (#177) (fbf36ef)

🩹 Fixes

  • deps: update dependency globals to ^15.11.0 (#182) (4e25750)

0.11.6 (2024-09-24)

🌟 Features

  • deps: update dependency @stylistic/eslint-plugin to ^2.8.0 (#160) (ff8cfd9)
  • deps: update dependency eslint-plugin-react to ^7.36.1 (#162) (2044fa9)
  • deps: update dependency typescript-eslint to ^8.6.0 (#106) (565f02a)

🩹 Fixes

  • deps: update dependency eslint-plugin-n to ^17.10.3 (#174) (4668aab)

0.11.5 (2024-09-12)

🩹 Fixes

  • deps: types are bundled with ESLint >=9.10 (#164) (13af181)
  • deps: update dependency @stylistic/eslint-plugin to ^2.6.4 (#154) (40d8445)
  • ignore jsx-rules in non-jsx files (#169) (c9cef42)

🤖 Automation

  • ci: only run release-please workflow on upstream repo (#157) (08dd476)

0.11.4 (2024-08-25)

🩹 Fixes

📚 Documentation

0.11.3 (2024-08-20)

🌟 Features

  • deps: update dependency eslint-plugin-promise to ^7.1.0 (#135) (34074ac)
  • partly disable @stylistic/comma-dangle (#139) (09339ec)

🩹 Fixes

  • deps: add eslint-plugin-react to eslint deps handling (#127) (3f65825)
  • deps: update dependency @stylistic/eslint-plugin to ^2.6.2 (#133) (f53dd67)
  • deps: update dependency @stylistic/eslint-plugin to ^2.6.3 (#137) (afe1387)
  • deps: update dependency eslint-plugin-n to ^17.10.2 (#134) (e23e413)

🧹 Chores

0.11.2 (2024-08-01)

🌟 Features

🩹 Fixes

  • deps: move all dependencies to @types/eslint@^9 (#116) (7047941)
  • deps: update dependencies (#125) (a678003)
  • deps: update dependency @stylistic/eslint-plugin to ^2.6.0 (#123) (366bf51)
  • lazy load typescript and style options (#126) (78d9ff8), closes #124

0.11.1 (2024-07-15)

🌟 Features

  • autodetect ESM at configuration migration (#98) (d51787f)

🩹 Fixes

  • deps: update dependency globals to ^15.7.0 (#99) (a5df311)
  • deps: update dependency globals to ^15.8.0 (#104) (7b21e44)
  • deps: update dependency peowly to ^1.3.2 (#100) (aa85713)
  • deps: update dependency typescript-eslint to ^8.0.0-alpha.41 (#82) (b6bac9c)

📚 Documentation

  • add mission statement + notes on extending (#94) (7835e15)
  • improve list of differences (#102) (ca82086)

🧹 Chores

  • remove direct dependency on @typescript-eslint/utils (#93) (f224088)

0.11.0 (2024-07-01)

⚠ BREAKING CHANGES

  • export typescript-eslint instead of `@typescript-eslint/eslint-… (#88)

🩹 Fixes

  • export typescript-eslint instead of `@typescript-eslint/eslint-… (#88) (9502724)

0.10.0 (2024-07-01)

⚠ BREAKING CHANGES

  • add eslint-plugin-promise support (#86)

🌟 Features

  • add eslint-plugin-promise support (#86) (8f141ae)
  • export plugins for others to use (26b472b)

0.9.0 (2024-06-27)

⚠ BREAKING CHANGES

  • reactivate stylistic rules for TypeScript (#80)

🌟 Features

  • reactivate stylistic rules for TypeScript (#80) (e2b0daa)

0.8.0 (2024-06-24)

⚠ BREAKING CHANGES

  • adopt ignore findings from fastify/fastify (#67)

🩹 Fixes

  • adopt ignore findings from fastify/fastify (#67) (7ef49ce)
  • deps: update dependency @stylistic/eslint-plugin-js to ^2.2.2 (#73) (6086d51)
  • deps: update dependency eslint-plugin-n to ^17.9.0 (#74) (4bc272e)
  • deps: update dependency globals to ^15.6.0 (#75) (9ed8b21)
  • deps: update dependency peowly to ^1.3.1 (#72) (d71eb65)
  • deps: update typescript-eslint monorepo to ^8.0.0-alpha.30 (#61) (8856d07)

0.7.2 (2024-06-14)

🩹 Fixes

  • make config names conform to name convention (#64) (2077be0)

0.7.1 (2024-06-11)

🩹 Fixes

  • deps: update dependency eslint-plugin-n to ^17.8.1 (#58) (050d894)
  • deps: update dependency globals to ^15.4.0 (#59) (9af005d)
  • deps: update typescript-eslint monorepo to ^8.0.0-alpha.28 (#56) (ffce1c5)

📚 Documentation

  • add names to the configs (9841180)
  • fix config inspector publish (9417a88)

🧹 Chores

  • fix an accidental gitignore (4651eda)

0.7.0 (2024-06-09)

⚠ BREAKING CHANGES

  • remove built in ignores + fix ignores for ts (#40)

🩹 Fixes

  • remove built in ignores + fix ignores for ts (#40) (86ac8ea)

0.6.1 (2024-06-09)

🩹 Fixes

  • add --no-default-ignore to CLI (6443327)
  • peer errors by removing stylistic-ts (#36) (8805546), closes #35

📚 Documentation

  • add noDefaultIgnore to readme (d63916e)

🧹 Chores

  • validate strict peer dependency installation (#37) (277f17f)