A powerful and flexible boilerplate for starting React projects, leveraging Vite for fast builds, TypeScript for type safety, and built-in support for internationalization, SVG handling, and code quality tools like ESLint, Husky, and Prettier.
- React Boilerplate Template
- Table of Contents
- Features
- Version used for Major Dependencies
- Project Folder Structure
- Naming Conventions
- Getting Started
- Contributing
- License
- Husky: Pre-commit hooks to enforce linting and testing rules before pushing code.
- ESLint: Configured with plugins for React, JSX accessibility, and Prettier integration.
- Prettier: Consistent code formatting across the project.
- Path Aliases: Simplified imports with custom path aliases.
- PR Template: Standardized pull request template to maintain code review consistency.
- direnv: Environment management for project-specific settings.
- EditorConfig: Editor configuration to maintain consistent coding styles across IDEs.
- Folder Structure: Organized project structure for scalable and maintainable code.
- Internationalization (i18n): Integrated
i18next
andreact-i18next
for handling multiple languages, enabling easy localization of content. The setup includes automatic language detection via thei18next-browser-languagedetector
package, making the user experience seamless and adaptive based on browser settings. - SVGR Integration: SVGs are handled using
@svgr/cli
, which converts SVG files into React components. This enables easy embedding and manipulation of SVG icons and graphics directly within the React codebase, keeping assets clean and code efficient. - VSCode Configuration: The
.vscode
folder includes custom workspace settings, extensions, and code snippets to streamline development.- Extensions: Recommended VSCode extensions to ensure a consistent development environment across the team.
- Settings: Predefined settings for formatting, linting, and other preferences to ensure uniformity in coding style.
- Code Snippets: Custom snippets for commonly used code patterns, reducing boilerplate code and improving productivity.
Package | Version |
---|---|
node | 22.8.0 |
react | 18.3.1 |
vite | 5.4.1 |
typescript | 5.5.3 |
eslint | 9.10.0 |
husky | 8.0.0 |
prettier | 3.3.3 |
typescript-eslint | 8.5.0 |
@eslint/js | 9.10.0 |
vite-tsconfig-paths | 5.0.1 |
i18next | 23.15.1 |
i18next-browser-languagedetector | 8.0.0 |
react-dom | 18.3.1 |
react-i18next | 15.0.2 |
@svgr/cli | 8.1.0 |
npm | 10.8.3 |
lint-staged | 15.2.10 |
This template serves as a solid foundation to kickstart new React projects, ensuring consistency, efficiency, and adherence to best practices across the team.
.
├── .github # GitHub-specific workflows and templates
├── .husky # Husky pre-commit hooks (e.g., linting, testing)
├── .vscode # VSCode workspace settings and recommended extensions
├── src # Source files for the project
│ ├── assets # Static resources (images, fonts, etc.)
│ ├── components # Reusable React components
│ ├── constants # Application-wide constants
│ ├── https # HTTPS utility functions (API calls, etc.)
│ ├── pages # Page-level components
│ ├── routes # Application routes
│ ├── svgr # SVG to React components configuration
│ │ ├── index-template.cjs # Template for exporting SVG components
│ │ ├── svgr-config.json # SVGR configuration file
│ │ └── svgr-template.cjs # Template for converting individual SVGs into React components
│ ├── theme # Theming files for typography, colors, spacing, etc.
│ └── types # TypeScript types
├── .editorconfig # EditorConfig for consistent coding styles across IDEs
├── .envrc # Environment configuration using direnv
├── .gitignore # Git ignore file
├── .nvmrc # Node.js version configuration
├── .prettierignore # Ignore file for Prettier
├── .prettierrc # Prettier configuration
├── .validate-branch-namerc.json # Configuration for validating branch names
├── commitlint.config.cjs # Commit message linting configuration
├── eslint.config.js # ESLint configuration
├── index.html # Main HTML file for the project
├── package.json # Project dependencies and scripts
├── package-lock.json # Lockfile for package dependencies
├── README.md # Project readme
├── tsconfig.app.json # TypeScript configuration for application code
├── tsconfig.json # General TypeScript configuration
├── tsconfig.node.json # TypeScript configuration for Node.js
└── vite.config.ts # Vite configuration file
- Files/Folders
- Component File: PascalCase.tsx
- All other files/folders: kebab-case
- Variables
- Global constants: SCREAMING_SNAKE_CASE
- Component: PascalCase
- Boolean variable or props: camelCase with prefix
does
,has
,is
andshould
- e.g. isLoading, doesContain, hasElement
- Others: camelCase
- Types
- Interfaces: PascalCase with
I
as prefix- e.g. IUser, IResponse
- Enumerations: PascalCase
- Types: PascalCase
- Interfaces: PascalCase with
- Methods/Functions
- Methods/Functions: camelCase
- Hooks: camelCase with
use
as prefix- e.g. useList, useDetails
- Higher Order Components: camelCase with
with
as prefix- e.g. withTimer
Follow these steps to clone, set up, and start working with the project:
Use degit
to clone the boilerplate template:
npx degit Aubergine-FE/react-basic-template <your-project-name>
For macOS (Homebrew):
brew install direnv
For Ubuntu:
sudo apt install direnv
Setup the terminal for the default environment using the official website.
cd your-project-name
# give permissions to direnv
direnv allow
npm install
Initialize the git repository
git init
Install the husky to setup the hooks.
npx [email protected] install
# now, you have running hooks setup in place.
Hooks can be disabled with:
npm run disable-hooks
Changed your mind? Enable hooks with:
npm run enable-hooks
- You can configure the branch and commit message prefix in
.validate-branch-namerc.json
andcommitlint.config.cjs
files respectively.
- You can go through
i18n.ts
and configure the localization settings accordingly. Also see the translations inassets/locales
folder.
- Change the color
#1C202A
insvgr-config.json
to your default icon color. This will replace that color with the appropriate props. - To generate the icon components
- Put your icons in
assets/icons
- Now, Run
npm run icons:create
- Put your icons in
- Change the file name from the
README.template.md
toREADME.md
. - Update the
Project Name
. - Update the URLs for cloning the project.
- Add any more steps you have for onboarding in
Getting Started
- see CONTRIBUTING.md
- This project is licensed under the MIT License - see the LICENSE file for details.