Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ijsto/eslint-config
ESLint + Prettier setup for VS Code by iJS
https://github.com/ijsto/eslint-config
eslint ijs prettier-configs vscode
Last synced: about 1 month ago
JSON representation
ESLint + Prettier setup for VS Code by iJS
- Host: GitHub
- URL: https://github.com/ijsto/eslint-config
- Owner: ijsto
- Created: 2020-03-16T01:07:42.000Z (almost 5 years ago)
- Default Branch: main
- Last Pushed: 2023-09-24T03:27:18.000Z (over 1 year ago)
- Last Synced: 2024-10-14T01:47:19.848Z (2 months ago)
- Topics: eslint, ijs, prettier-configs, vscode
- Language: JavaScript
- Homepage:
- Size: 681 KB
- Stars: 51
- Watchers: 2
- Forks: 2
- Open Issues: 4
-
Metadata Files:
- Readme: readme.md
- Changelog: CHANGELOG.md
Awesome Lists containing this project
README
# **ESLint and Prettier setup for VS Code**
- A set of awesome ESLint + Prettier configs.
- Makes it easier to work with React, Next.js, Node apps.
- This package is intended for use with VS Code, however, can be easily used with any text editors.> This package will automatically detect if you're using React, Next.js, Node (and other in near future), and apply appropriate linting rules. ๐๐ผ
# **Installation**
> ### **You may need to restart VSCode once installed.**
First installation will take you only a couple of minute, every subsequent should not take more than a minute.
You can install the package 2.a) in repo of the project which will apply the linting only to the project and not other files on your computer or 2.b) on your computer which will apply the linting to all files with the included file extensions on your computer.
Below are the steps to install (click on the step to open the instructions).
1 ยท VS Code Setup
1. Install [ESLint extension](https://marketplace.visualstudio.com/items?itemName=dbaeumer.vscode-eslint)
2. Add below snippet to your User settings:
> First try (`โCmd + ,` or `Ctrl + ,`) โ type in `settings.json` file โ click on `Edit in settings.json`. If that doesn't work the file is located in `$/Code/User/settings.json````js
{
// ...
// Run formatter when you save code changes
"editor.codeActionsOnSave": {
"source.fixAll.eslint": true
},
// Disable default formatting (ESLint formatting will be used instead)
"[javascript]": {
"editor.formatOnSave": false
},
"[javascriptreact]": {
"editor.formatOnSave": false
},
}
```
2.a ยท RECOMMENDED: Per Project Setup (Local setup)
## Install
1. Install @ijsto/eslint-config:
> this command will auto-detect if you are using yarn by default and prompt you to confirm before proceeding.```
npx install-peerdeps --dev @ijsto/eslint-config
```2. Create an `.eslintrc` file in the root of your project's directory. Paste in the following:
```json
{
"extends": "@ijsto"
}
```3. You're done!
4. ESLint will now run and format your code each time you save your file.
2.b ยท Computer-wide (Global setup)
If you would like to install the config computer-wide (globally) and not on each project, follow the below steps.
## Install
1. Install @ijsto/eslint-config:
> this command will auto-detect if you are using yarn by default and prompt you to confirm before proceeding.```
npx install-peerdeps --global @ijsto/eslint-config
```2. Create a global `.eslintrc` file on your computer:
- MacOS location: `~/.eslintrc`
- Windows location: `C:\Users\you\.eslintrc`Paste in the follow to newly created `.eslintrc`:
```json
{
"extends": "@ijsto"
}
```
# Typescript
> ### โ ๏ธ **Currently `eslint v8` will break the TypeScript support.**
> Some-what relevant: https://github.com/eslint/eslint/issues/15149If you would like to use this config with TypeScript, all you need to do is:
1. Install TypeScript dependencies:
```bash
yarn add --dev @typescript-eslint/eslint-plugin @typescript-eslint/parser eslint prettier
```2. Add the following to `.eslintrc` file
```json
{
// ...other configs
"parser": "@typescript-eslint/parser", // <-- Add this
"plugins": ["@typescript-eslint", /* ...otherPlugins */], // <-- Add this
"extends": [ // <-- `extends` is now an array and not an object
"@ijsto",
"plugin:@typescript-eslint/eslint-recommended", // <-- Add this
"plugin:@typescript-eslint/recommended" // <-- Add this
]
// ...other configs
}```
## **How to Uninstall**
If something doesn't work or you should try manually deleting your `node_modules` folder. This usually helps resolving any issues with this config not working.
If you would like to uninstall this `eslint-config`, run the below commands:
### **Local uninstall (per project)**
```
yarn remove eslint @ijsto/eslint-config
```or global (computer-wise)
```
npm remove eslint @ijsto/eslint-config
```### **Global uninstall**
```
yarn global remove eslint @ijsto/eslint-config
```or
```
npm remove --global eslint @ijsto/eslint-config
```## That's all.
Did this package help you? Give it a โ and share with your friends! ๐
PRs, feature requests or suggestions are most welcome!
[iJS.to](https://ijs.to)
# Troubleshooting
If you followed the steps, yet still cannot get ESLint to work, you can try deleting `/node_modules` and running `yarn` or `npm i` depending on which one you use.
## `Insert '..' eslint(prettier/prettier)`
- This eslint error can sometimes occur when you have clashing formatters. The easiest solution if to change the default formatter in your VS Code settings to ESLint (tutorial coming soon).
- If this doesn't work for your use-case, feel freet to tweet at [@scottagirs](http://twitter.com/scottagirs) or reach out on [ijs.to/scottagirs](https://ijs.to/scottagirs)## **Contributing ๐ช๐ผ**
Thank you for considering to contribute to this project.
We are working on improving the contributing guidelines, for now, here is current TODO list:
- [ ] Handle workspaces (see TODO:s in `index.js` file)
- [ ] Create `CONTRIBUTING.md` file with guidelines