This is an experiment using fbtee with react router (framework mode).
The fbtee-related changes are here: https://github.com/skifab/fbtee-create-react-router-app/commit/2b1c0bb109ee2f7d7368ccdd6e237c3c985c4435
See it running here: https://fbtee-create-react-router-app.vercel.app/
Some notes:
- Uses (unstable) middleware on the server to initialize and change the selcted locale
- Locale change on client-side only is not supported (can't see the reason to support this). The locale change happens through a redirect from middleware after detecting a
?lang=xxquery param. - Not using
createLocaleContextfrom fbtee as I couln't get this to play nice with react router. - This implementation might not be best practice, just a newbie trying to get it working.
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
If you're familiar with deploying Node applications, the built-in app server is production-ready.
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
│ └── server/ # Server-side code
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.