Skip to content

skifab/fbtee-create-react-router-app

Repository files navigation

Adding fbtee to create-react-router-app

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=xx query param.
  • Not using createLocaleContext from 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.

Welcome to React Router!

A modern, production-ready template for building full-stack React applications using React Router.

Open in StackBlitz

Features

  • 🚀 Server-side rendering
  • ⚡️ Hot Module Replacement (HMR)
  • 📦 Asset bundling and optimization
  • 🔄 Data loading and mutations
  • 🔒 TypeScript by default
  • 🎉 TailwindCSS for styling
  • 📖 React Router docs

Getting Started

Installation

Install the dependencies:

npm install

Development

Start the development server with HMR:

npm run dev

Your application will be available at http://localhost:5173.

Building for Production

Create a production build:

npm run build

Deployment

Docker Deployment

To build and run using Docker:

docker build -t my-app .

# Run the container
docker run -p 3000:3000 my-app

The 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

DIY Deployment

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

Styling

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.