@putstack/eslint-config-typescript
TypeScript icon, indicating that this package has built-in type declarations

3.10.0 • Public • Published

An ESLint configuration by Putro

This ESLint setup should let any new (or existing) projects adhere to best practices within TypeScript and write fewer bugs as a result! The default version is quite strict, so an existing project might opt for using the base version, see more under Usage.

The latest version (v3 and up) is using the new flat configuration from eslint and eslint v9. If you are not ready for this change, please stick with 2.6.1 or below.

Installation

To install this package run the following command in the terminal in the root directory of your application.

pnpm install -D @putstack/eslint-config-typescript

OR

npm install --save-dev @putstack/eslint-config-typescript

OR

yarn add -D @putstack/eslint-config-typescript

Usage

Ensure that your ESLint configuration is setup to utilize TypeScript's type checking API by following this guide. Note that if you're using this in a monorepo, you SHOULD keep "project":"true" despite that the guide says otherwise in my experience.

Add this to your config by editing your eslint.config.js file or equivalent.

import putstack from '@putstack/eslint-config-typescript';

export default [...putstack.configs.recommended];

If the default is too strict on an existing project, you can also use the base configuration to exclude some of the more strict rules. To see what is dincluded in which package, please view this section.

import putstack from '@putstack/eslint-config-typescript';

export default [...putstack.configs.base];

Example

This project uses the configuration on itself, as seen in the root eslint.config.js file.

ESLint rules

ESLint PLugins and Configurations

This is a list of the plugins and configurations that are extended from.

Base

Plugins

  • eslint-plugin-depend - An ESLint plugin for suggesting optimisations in choice of dependency, native equivalents, etc.
  • eslint-plugin-perfectionist - ESLint plugin for sorting various data such as objects, imports, types, enums, JSX props, etc.
  • eslint-plugin-progress - Report progress when running ESLint. Useful for large projects with thousands of files, so it's obvious that something is running!
  • eslint-plugin-sonarjs - Code smell, bug detection, cognitive complexity and more.
  • typescript-eslint - A large amount of TypeScript related ESLint rules, using the recommended type checking rules.

Configurations

Recommended

Recommended extends the base setup further to add additional rules, therefore it also includes all the rules above.

Plugins

  • eslint-plugin-unicorn - This plugin provides more than 100 powerful ESLint rules of which many are auto-fixable making it easy to fix any issues that arise!

Configurations

Dependencies (7)

Dev Dependencies (0)

    Package Sidebar

    Install

    npm i @putstack/eslint-config-typescript

    Weekly Downloads

    19

    Version

    3.10.0

    License

    MIT

    Unpacked Size

    43.6 kB

    Total Files

    8

    Last publish

    Collaborators

    • laustsf