Expo Guide
How to set up Tamagui with Expo
We've created a new template repo for starting an Expo Router based app based on the Expo 3 starter repo.
There are also pre-made community Expo starters.
Install
To support dark mode, update your app.json to app.config.ts and set
userInterfaceStyle to "automatic".
Expo Router / Web
We have beta support via @tamagui/metro-plugin. Install:
If you want web support, adjust your metro.config.js:
Add your tamagui.config.ts:
Then update app/_layout.tsx:
Native
This guide assumes Expo is configured with TypeScript support.
The following steps are optional but useful for many apps, they enable the
optimizing compiler, reanimated, as well as using process.env.XYZ for
environment variables.
Update your babel.config.js to include the optional @tamagui/babel-plugin:
If you're using a monorepo you probably want to use this Metro configuration:
Setup Tamagui
From here on out you can follow the Installation and Configuration docs.
Loading fonts
You need to load your fonts for React Native to recognize them. Typically this looks something like if using Expo, (or you can follow a React Native guide here ):
First time starting Expo
The first time running your project with Tamagui, be sure to clear the cache:
Your package.json scripts should look something like this:
Previous
Next.js
Next
Vite