Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/tjw-lint/eslint-config-tjw-base

The Jared Wilcurt's base ESLint rules
https://github.com/tjw-lint/eslint-config-tjw-base

eslint rules ruleset tjw

Last synced: 2 months ago
JSON representation

The Jared Wilcurt's base ESLint rules

Awesome Lists containing this project

README

        

# eslint-config-tjw-base

The Jared Wilcurt's base ESLint 9+ rules for ESM projects.

For CJS and ESLint < v9, use v2.x releases.

## Using this

1. If you don't have a `package.json` do `npm init -y` first
1. Run `npm pkg set type=module`
1. Run `npm install --save-dev eslint eslint-config-tjw-base @stylistic/eslint-plugin-js`
1. In your `eslint.config.js` add `tjwBase` to your config like so:
```js
import js from '@eslint/js';
import tjwBase from 'eslint-config-tjw-base';

export default [
js.configs.recommended,
tjwBase,
{
// project specific settings
}
];
```
1. Run `npm pkg set scripts.lint="eslint *.js src"`
* Change `*.js src` to your files and folders you want to be linted
1. Run `npm run lint`

If you already have a `no-restricted-syntax` rule, you can merge the ones that come with this config with your own, like so:

```js
// eslint.config.js
import js from '@eslint/js';
import baseRestrictedSyntax from 'eslint-config-tjw-base/no-restricted-syntax.js';
import tjwBase from 'eslint-config-tjw-base';

export default [
js.configs.recommended,
tjwBase,
{
rules: {
'no-restricted-syntax': [
'error',
...baseRestrictedSyntax,
// your custom rules
]
}
}
];
```

* * *

**See also:**

* [eslint-config-tjw-base](https://github.com/tjw-lint/eslint-config-tjw-base)
* [eslint-config-tjw-import](https://github.com/tjw-lint/eslint-config-tjw-import)
* [eslint-config-tjw-jest](https://github.com/tjw-lint/eslint-config-tjw-jest)
* [eslint-config-tjw-jsdoc](https://github.com/tjw-lint/eslint-config-tjw-jsdoc)
* [eslint-config-tjw-vue](https://github.com/tjw-lint/eslint-config-tjw-vue)