Skip to content

✨ The best way to start a full-stack, typesafe NestJS & Next.js monorepo.

Notifications You must be signed in to change notification settings

mantaskaveckas/nestjs-turbo

Repository files navigation

NestJS / Next.js Turborepo starter

This is an unofficial starter Turborepo.

What's inside?

This Turborepo includes the following packages/apps:

Apps and Packages

  • api: a NestJS app
  • web: another Next.js app
  • ui: a stub React component library shared by both web and docs applications
  • eslint-config-custom: eslint configurations (includes eslint-config-next and eslint-config-prettier)
  • tsconfig: tsconfig.jsons used throughout the monorepo

Each package/app is 100% TypeScript.

Utilities

This Turborepo has some additional tools already setup for you:

Installation

git clone https://github.com/mantaskaveckas/nestjs-turbo
cd nestjs-turbo
pnpm install

Hint: If you'd like to clone the repository without the git history, you can use degit.

Build

To build all apps and packages, run the following command:

cd nestjs-turbo
pnpm build

Develop

To develop all apps and packages, run the following command:

cd nestjs-turbo
pnpm dev

Remote Caching

Turborepo can use a technique known as Remote Caching to share cache artifacts across machines, enabling you to share build caches with your team and CI/CD pipelines.

By default, Turborepo will cache locally. To enable Remote Caching you will need an account with Vercel. If you don't have an account you can create one, then enter the following commands:

cd my-turborepo
npx nestjs-turbo

This will authenticate the Turborepo CLI with your Vercel account.

Next, you can link your Turborepo to your Remote Cache by running the following command from the root of your Turborepo:

npx turbo link

Useful Links

Learn more about the power of Turborepo:

Learn more about NestJS & Next.js: