eslint-config-favoritemedium-typescript v2.10.0
FavoriteMedium JavaScript/TypeScript Style Guide
Super charged with @typescript-eslint
There are two styles configurations:
if you are using React configurations then there is no need to import base configurations.
Installation & Usage Guide
Following procedures will guide you through setting up eslint-config-favoritemedium-typescript into your projects.
1. Vanilla Js/Ts setup
Assuming eslint and typescript are already installed as development dependencies.
npm i -D eslint-config-favoritemedium-typescript \
eslint-plugin-import@^2.22.1 \
@typescript-eslint/eslint-plugin@^4.3.0 \
eslint \
typescriptWithin ESLint config file at project root add following configurations:
module.exports = {
extends: ['favoritemedium-typescript'],
};in package.json file:
{
//...
"scripts": {
"lint": "eslint ./<source_directory>/**/*",
"lint:fix": "eslint --fix ./<source_directory>/**/*"
}
//...
}*Note: lint:fix is optional command; it will try to fix semicolons, spacing, quotes related formatting automatically.
2. React setup
There are two possible ways that eslint-config-favoritemedium-typescript plugin can added to project.
- Adding to project created with
npx create-react-app <cool-app> --template typescript - Manually configuring to existing project
2.1 Adding to new/existing project created with create-react-app v3.x and higher
Generate react application with following command mentioned here:
npx create-react-app my-app --template typescript
# or
yarn create react-app my-app --template typescriptinstall following dependency:
yarn add -D eslint-config-favoritemedium-typescript
# or
npm i -D eslint-config-favoritemedium-typescriptcreate .eslintrc file in project root directory
// .eslintrc
module.exports = {
extends: ['favoritemedium-typescript/config/react'],
};create .eslintignore file in project root directory:
// .eslintignore
node_modules
*.svg
*.css
*.scssin package.json file add following script.
{
//...
"scripts": {
"lint": "eslint ./<source_directory>/**/*",
}
//...
}2.2 Manual configurations
For setting up eslint for react project you need to install three additional dependencies to vanilla js/ts setup
npm i -D eslint-config-favoritemedium-typescript \
eslint-plugin-import@^2.22.1 \
@typescript-eslint/eslint-plugin@^4.3.0 \
eslint-plugin-jsx-a11y@^6.3.1 \
eslint-plugin-react@^7.21.2 \
eslint-plugin-react-hooks@^4.1.2 \
eslint \
typescriptcreate .eslintrc file in project root directory
// .eslintrc
module.exports = {
extends: ['favoritemedium-typescript/config/react'],
};create .eslintignore file in project root directory:
// .eslintignore
node_modules
*.svg
*.css
*.scssin package.json file:
{
//...
"scripts": {
"lint": "eslint ./<source_directory>/**/*"
}
//...
}After above setup completion you may add npm run lint command to your pre-commit setup like configured in .huskyrc.js