This is a Next.js template project with TypeScript, ESLint, Prettier, EditorConfig, Styled-Components, Next-Images, Commitlint and Commitizen.
- About the dependencies in this template
- How to use
- ESLint, Prettier and EditorConfig setup
- Customize ESLint, Prettier and EditorConfig rules
- Using Commitlint and Commitizen
- References
- TypeScript: Is an open-source language which builds on JavaScript, one of the world’s most used tools, by adding static type definitions. The advantage of using TypeScript is that it provides a way to describe the shape of an object, providing better documentation, and allowing TypeScript to validate that your code is working correctly;
- ESLint: Is an open source JavaScript linting utility originally created by Nicholas C. Zakas in June 2013. Code linting is a type of static analysis that is frequently used to find problematic patterns or code that doesn't adhere to certain style guidelines. The advantage of using ESLint is that it forces you to follow best practices when writing code;
- Prettier: Is an opinionated code formatter with support for many languages and integration with most editors. The advantage of using Prettier is that it removes all original styling and ensures that all outputted code conforms to a consistent style;
- EditorConfig: The EditorConfig project consists of a file format for defining coding styles and a collection of text editor plugins that enable editors to read the file format and adhere to defined styles. The advantage of using EditorConfig is that it helps maintain consistent coding styles for multiple developers working on the same project across various editors and IDEs;
- Styled-Components: It's a React library focused on making writing css easier. Among the main advantages of using Styled-Components are: generation of unique class names for your styles, easy maintenance, fast rendering and much more;
- Next-Images: It's a library made to make it easy to import images of various types into Next.js. Supports jpg, jpeg, png, svg, fig, ico, webp, jp2 and avif images by default;
- Commitlint: Commitlint checks if your commit messages meet the conventional commit format. The advantages of using this are: automatically generating CHANGELOGs, automatically determining a semantic version bump (based on the types of commits landed), communicating the nature of changes to teammates, the public, and other stakeholders and etc;
- Commitizen: Is an open source project that helps contributors be good open source citizens. It accomplishes this by prompting them to follow commit message conventions at commit time. The advantage of using Commitizen is that it helps at commit time by displaying the options to be filled in the terminal.
- 
Press the Use this templatebutton;
- 
In the next screen, choose your Repository name and press the Create repository from templatebutton;
- 
The next step is to clone the newly created Repository to your computer. 
- 
With the project open, run: 
npm install
# or
yarn installThis will install all project dependencies.
- Now, to view the project in your browser, run:
npm run dev
# or
yarn devIf all goes well, you should see a screen like this:
For ESLint, Prettier and EditorConfig to work in your development environment, you need to install their extensions and do some settings.
- In Visual Studio Code, install the extentions below:
- https://marketplace.visualstudio.com/items?itemName=dbaeumer.vscode-eslint
- https://marketplace.visualstudio.com/items?itemName=esbenp.prettier-vscode
- https://marketplace.visualstudio.com/items?itemName=EditorConfig.EditorConfig
If you get some errors in the files after installing the extensions, don't worry, just go to the next step to fix it.
- Now, to automatically fix your code whenever you save a file, add the following lines to your settings.json file and save it:
{
  //...
  "editor.codeActionsOnSave": {
    "source.fixAll.eslint": true
  },
  "editor.formatOnSave": true,
  "editor.defaultFormatter": "esbenp.prettier-vscode"
}To make sure the extensions and settings we've added will work, it's recommended that you restart your Visual Studio Code.
Now, if you have errors, save the files to fix them automatically. If you haven't received any errors, let's manually test if it's working. To do that, let's edit the index.tsx file in the src/pages folder.
- Comment the React import in the first line:
- ESLint should display the following error within the return:
- To test Prettier, let's add a comma after Wrapper import in the eighth line, like this:
- When saving the file, Prettier must remove the comma:
Remember, this happens because it is defined in the rules. If you want to customize them, see how to do this in the next topic.
This project uses the ESLint recommended rules by default. So, to change them, follow the next step.
- To customize the ESLint rules, you can change them in the .eslintrc.json file;
Here is a list of the ESLint rules that you can use:
If you prefer to use a popular style guide instead of the recommended rules, go to the next step, otherwise, just ignore it.
- To override the ESLint default settings, just run the command below and choose the desired options:
npx eslint --init
# or
yarn eslint --init- To customize the Prettier rules, you can edit the prettier.config.js file.
Here is a list of the Prettier rules that you can use:
- To customize the EditorConfig rules, you can edit the .editorconfig file.
Both seem to do the same thing, but each has its importance. Commitlint (and Husky) will ensure that the commit message follows conventional commits rules. And with Commitizen, we have a set of commit message options that make our work easier. See the examples below to learn how to use them.
- A invalid commit message will display an error:
This is because Commitlint expects to receive a valid type and subject. The accepted types are: build, chore, ci, docs, feat, fix, perf, refactor, revert, style and test.
- Now, with a valid type and subject our commit is done:
To make this easier, we can use Commitizen.
- In your terminal, just run:
npm run commit
# or
yarn commitWith that, Commitizen will ask you to fill in some fields. And your commit will be done following the conventional commits rules:
- https://www.typescriptlang.org/
- https://eslint.org/docs
- https://prettier.io/docs/en
- https://editorconfig.org/#overview
- https://styled-components.com/docs/basics#motivation
- https://github.com/twopluszero/next-images
- https://github.com/conventional-changelog/commitlint
- https://www.conventionalcommits.org/en/v1.0.0/#why-use-conventional-commits
- https://github.com/commitizen/cz-cli







