eslint-config-favoritemedium-typescript
v2.10.0
Published
FavoriteMedium's ESLint config, following our styleguide
Downloads
5
Maintainers
Readme
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 \
typescript
Within 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 typescript
install following dependency:
yarn add -D eslint-config-favoritemedium-typescript
# or
npm i -D eslint-config-favoritemedium-typescript
create .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
*.scss
in 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 \
typescript
create .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
*.scss
in 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