A highly opinionated, sharable config of ESLint rules to produce beautiful, readable JavaScript.
As developers, we spend more time reading code than writing it. These rules aim to make reading JavaScript a priority.
That means some rules will feel oppressive or "over the top" for many developers, which is fine. If you don't like it, you can get off my lawn! ... Or extend the rules and override them with the ones that bother you. Either way. 😊
This config also comes with the following plugins, and corresponding rules, baked in.
- eslint
- eslint-plugin-eslint-comments
- eslint-plugin-get-off-my-lawn
- eslint-plugin-import
- eslint-plugin-jest
- eslint-plugin-jest-formatting
- eslint-plugin-jsonc
- eslint-plugin-jsx-a11y
- eslint-plugin-next
- eslint-plugin-node
- eslint-plugin-objects
- eslint-plugin-react
- eslint-plugin-react-hooks
- eslint-plugin-react-native
- eslint-plugin-security
- eslint-plugin-unicorn
- @typescript-eslint/eslint-plugin
Each and every single rule has been meticulously poured over and purposefully hand picked or excluded.
eslint-config-get-off-my-lawn will automatically enable and disable plugins (and thus rules) based on your package.json
dependencies. Not using React? Cool. eslint-plugin-jsx-a11y, eslint-plugin-react, eslint-plugin-react-hooks, and eslint-plugin-react-native won't be included. Not using a React version that supports hooks? eslint-plugin-react-hooks will be disabled. Not a React Native project? No problem. Those rules won't be included. I think you get the idea... 😉
$ npm i eslint eslint-config-get-off-my-lawn --save-dev
$ yarn add eslint eslint-config-get-off-my-lawn --dev
Create an ESLint config in your package.json
or .eslintrc.js
file.
{
"name": "my-awesome-project",
"eslintConfig": {
"extends": "get-off-my-lawn",
"rules": {
// enable additional rules, override rule options, or disable rules
}
}
}
module.exports = {
extends: 'get-off-my-lawn',
rules: {
// enable additional rules, override rule options, or disable rules
},
};
Once your rules are configured, we recommend running the following command in your package.json
as an npm script.
eslint . --ext .js,.json
Supported extensions:
.js
.jsx
.json
.json5
.jsonc
.ts
.tsx
Love eslint-config-get-off-my-lawn? Love prettier? Well you're in luck!
eslint-config-get-off-my-lawn will automatically detect if your project is using prettier and it will apply eslint-config-prettier to turn off all rules that are unnecessary or might conflict with prettier.
But what about TypeScript? Don't worry, we got you!
eslint-config-get-off-my-lawn will automatically detect if your project is using TypeScript and it will configure and enable @typescript-eslint/eslint-plugin for you. How's that for handy?
- prettier-config-get-off-my-lawn - A highly opinionated, sharable config of Prettier rules to produce beautiful, readable code.
- stylelint-config-get-off-my-lawn - A highly opinionated, sharable config of stylelint rules to produce beautiful, readable CSS and Sass.
MIT © Michael Novotny