code/tamagui.dev/data/docs/guides/one.mdx
One is a React framework for web, iOS, and Android built on Vite. It offers seamless cross-platform development and integrates well with Tamagui.
First, create a new One project:
npx one
Add Tamagui and its dependencies:
yarn add tamagui @tamagui/config
Create a tamagui.config.ts file in your project root:
import { defaultConfig } from '@tamagui/config/v5'
import { createTamagui } from 'tamagui'
const tamaguiConfig = createTamagui(defaultConfig)
export default tamaguiConfig
// this is important!
export type Conf = typeof tamaguiConfig
declare module 'tamagui' {
interface TamaguiCustomConfig extends Conf {}
}
Update your vite.config.ts:
import { one } from 'one/vite'
import { tamaguiPlugin } from '@tamagui/vite-plugin'
import type { UserConfig } from 'vite'
export default {
plugins: [
one({
web: {
defaultRenderMode: 'ssg',
},
}),
tamaguiPlugin({
config: './tamagui.config.ts',
components: ['tamagui'],
}),
],
// Vite 6 style configuration
ssr: {
noExternal: true,
},
optimizeDeps: {
include: ['@tamagui/core', '@tamagui/config'],
},
build: {
cssTarget: 'safari15',
},
} satisfies UserConfig
Update your root layout file (typically app/_layout.tsx):
import { TamaguiProvider } from 'tamagui'
import { Slot } from 'one'
import config from '../tamagui.config'
export default function Layout() {
return (
<TamaguiProvider config={config}>
<Slot />
</TamaguiProvider>
)
}
Now you can use Tamagui components in your One app:
import { Button, Text, YStack } from 'tamagui'
export default function Home() {
return (
<YStack f={1} jc="center" ai="center" p="$4" gap="$4">
<Text fontSize="$6">Welcome to Tamagui with One!</Text>
<Button>Click me</Button>
</YStack>
)
}
To support light and dark modes, use One's built-in color scheme support along with Tamagui's theming system. Update your root layout:
import { TamaguiProvider, Theme } from 'tamagui'
import { Slot } from 'one'
import { useColorScheme } from 'react-native'
import config from '../tamagui.config'
export default function Layout() {
const colorScheme = useColorScheme()
return (
<TamaguiProvider config={config} defaultTheme={colorScheme}>
<Theme name={colorScheme}>
<Slot />
</Theme>
</TamaguiProvider>
)
}
For better performance, use the outputCSS option in the Tamagui Vite plugin:
tamaguiPlugin({
config: './tamagui.config.ts',
components: ['tamagui'],
outputCSS: process.env.NODE_ENV === 'production' ? './public/tamagui.generated.css' : null,
})
Then import the CSS in your root layout:
import '../public/tamagui.generated.css'
// ... rest of your imports and component
You now have Tamagui set up with One. Start building your cross-platform app using Tamagui's styling system and One's seamless development experience.