Template Node is a Node.js project scaffolding tool designed to speed up the initial setup of Node.js applications. This repository provides a solid foundation for building scalable and maintainable Node.js projects, with built-in best practices and commonly used configurations.
- TypeScript: Use TypeScript for a better development experience and improved code quality.
- ESLint: Lint your code with ESLint to maintain consistent coding standards.
- Prettier: Format your code with Prettier to keep it clean and consistent.
- Jest: Test your code with Jest to ensure its correctness and reliability.
- Husky: Use Husky to run tasks on Git hooks and enforce code quality.
- Lint-Staged: Run ESLint and Prettier on staged files to catch errors before committing.
- GitHub Actions: Use GitHub Actions for continuous integration and automated testing.
Make sure you have Node.js and pNPM installed on your machine before running the project.
-
Clone the repository:
git clone --depth 1 https://github.com/jdevelop-io/template-node.git cd template-node
-
Remove the
.git
directory to start with a clean git history:rm -rf .git
-
Initialize a new git repository:
git init
-
Install the dependencies:
pnpm install
pnpm build
: Build the project.pnpm buid:watch
: Build the project in watch mode.pnpm test
: Run the tests.pnpm test:watch
: Run the tests in watch mode.pnpm test:coverage
: Run the tests with coverage.pnpm test:coverage:watch
: Run the tests with coverage in watch mode.pnpm format
: Format the code and fix formatting errors.pnpm format:check
: Check the code for formatting errors.pnpm lint
: Lint the code and fix linting errors.pnpm lint:check
: Check the code for linting errors.
template-node
├── .github
│ ├── workflows
│ │ ├── build.yml
│ │ ├── code_quality.yml
│ │ └── tests.yml
├── .husky
│ └── pre-commit
├── coverage
├── dist
├── node_modules
├── src
├── test
│ └── unit
├── .editorconfig
├── .gitignore
├── .prettierignore
├── eslint.config.mjs
├── jest.config.ts
├── LICENSE
├── lint-staged.config.mjs
├── package.json
├── pnpm-lock.yaml
├── prettier.config.mjs
├── README.md
└── tsconfig.json
Contributions are welcome! If you have any ideas, suggestions, or issues, feel free to open an issue or submit a pull request.
This project is licensed under the MIT License. See the LICENSE file for details.