A modern, production-ready template for building full-stack React applications using React Router.
- 🚀 Server-side rendering
- ⚡️ Hot Module Replacement (HMR)
- 📦 Asset bundling and optimization
- 🔄 Data loading and mutations
- 🔒 TypeScript by default
- 🎉 TailwindCSS for styling
- 📖 React Router docs
Install the dependencies:
npm installStart the development server with HMR:
npm run devYour application will be available at http://localhost:5173.
Create a production build:
npm run buildTo build and run using Docker:
docker build -t my-app .
# Run the container
docker run -p 3000:3000 my-appThe containerized application can be deployed to any platform that supports Docker, including:
- AWS ECS
- Google Cloud Run
- Azure Container Apps
- Digital Ocean App Platform
- Fly.io
- Railway
This project is configured for static Cloudflare Pages (SPA mode). See CLOUDFLARE.md for step-by-step setup.
- Build command:
npm run build - Build output directory:
build/client
The public/_redirects file is copied into the build so all routes serve index.html (no 404s on refresh or direct links).
If you're familiar with deploying Node applications, the built-in app server is production-ready (set ssr: true in react-router.config.ts and deploy the full build/ output).
Make sure to deploy the output of npm run build
├── package.json
├── package-lock.json (or pnpm-lock.yaml, or bun.lockb)
├── build/
│ └── client/ # Static assets (for Pages); use build/ + server for Node/Worker
This template comes with Tailwind CSS already configured for a simple default starting experience. You can use whatever CSS framework you prefer.
Built with ❤️ using React Router.