This is from an official Docker starter Turborepo.
To start a particular application go to its readme in /apps/[app of interest].
web: a Next.js appapi: an Express serverb18-csv-generator: a config generator for a beamlinebluegui: a test client for blueapiTEMPLATE-nextjs-app: a template for making NEXTjs appsTEMPLATE-vite-app: a template for making vite appstest-next-safe-action: a test of the next safe action setuptrpc-test: a test of trpc (next safe action won)@repo/ui: a React component library@repo/logger: Isomorphic logger (a small wrapper around console.log)@repo/eslint-config: ESLint presets@repo/typescript-config: tsconfig.json's used throughout the monorepo@repo/jest-presets: Jest configurations
Each package/app is 100% TypeScript.
This repo is configured to be built with Docker, and Docker compose. To build all apps in this repo:
# Create a network, which allows containers to communicate
# with each other, by using their container name as a hostname
docker network create app_network
# Build prod using new BuildKit engine
COMPOSE_DOCKER_CLI_BUILD=1 DOCKER_BUILDKIT=1 docker-compose -f docker-compose.yml build
# Start prod in detached mode
docker-compose -f docker-compose.yml up -d
Open http://localhost:3000.
To shutdown all running containers:
# Stop all running containers
docker kill $(docker ps -q) && docker rm $(docker ps -a -q)
This Turborepo has some additional tools already setup for you:
- TypeScript for static type checking
- ESLint for code linting
- Jest test runner for all things JavaScript
- Prettier for code formatting