rsnext/examples/with-eslint
Houssein Djirdeh e783b0a2e8
Adds ESLint with default rule-set (#23702)
This PR re-includes ESLint with some notable changes, namely a guided setup similar to how TypeScript is instantiated in a Next.js application.

To add ESLint to a project, developers will have to create an `.eslintrc` file in the root of their project or add an empty `eslintConfig` object to their `package.json` file.

```js
touch .eslintrc
```

Then running `next build` will show instructions to install the required packages needed:

<img width="862" alt="Screen Shot 2021-04-19 at 7 38 27 PM" src="https://user-images.githubusercontent.com/12476932/115316182-dfd51b00-a146-11eb-830c-90bad20ed151.png">

Once installed and `next build` is run again, `.eslintrc` will be automatically configured to include the default config:

```json
{
  "extends": "next"
}
```

In addition to this change:

- The feature is now under the experimental flag and requires opt-in. After testing and feedback, it will be switched to the top-level namespace and turned on by default.
- A new ESLint shareable configuration package is included that can be extended in any application with `{ extends: 'next' }`
  - This default config extends recommended rule sets from [`eslint-plugin-react`](https://www.npmjs.com/package/eslint-plugin-react), [`eslint-plugin-react-hooks`](https://www.npmjs.com/package/eslint-plugin-react-hooks), and [`eslint-plugin-next`](https://www.npmjs.com/package/@next/eslint-plugin-next)
- All rules in [`eslint-plugin-next`](https://www.npmjs.com/package/@next/eslint-plugin-next) have been modified to include actionable links that show more information to help resolve each issue
2021-04-30 11:09:07 +00:00
..
pages Adds ESLint with default rule-set (#23702) 2021-04-30 11:09:07 +00:00
.eslintrc Adds ESLint with default rule-set (#23702) 2021-04-30 11:09:07 +00:00
.gitignore Adds ESLint with default rule-set (#23702) 2021-04-30 11:09:07 +00:00
next.config.js Adds ESLint with default rule-set (#23702) 2021-04-30 11:09:07 +00:00
package.json Adds ESLint with default rule-set (#23702) 2021-04-30 11:09:07 +00:00
README.md Adds ESLint with default rule-set (#23702) 2021-04-30 11:09:07 +00:00

ESLint Example

This example shows a Next.js application using the built-in ESLint setup with the next shareable configuration enabled in .eslintrc.

Note: ESLint running during build (next build) is still experimental and needs to be enabled via an { experimental: eslint } flag in next.config.js.

Deploy your own

Deploy the example using Vercel:

Deploy with Vercel

How to use

Execute create-next-app with npm or Yarn to bootstrap the example:

npx create-next-app --example with-eslint with-eslint
# or
yarn create next-app --example with-eslint with-eslint

Deploy it to the cloud with Vercel (Documentation).