The Drawer component provides a slide-out navigation panel, commonly used for app-wide navigation menus. Import it from one/drawer to keep the bundle size minimal when not using the drawer.
This component should only be rendered inside a _layout.tsx file, where it will serve as the location that children will render for routes below the layout.
Drawer wraps React Navigation’s Drawer Navigator and accepts the same props.
_layout.tsx
import { GestureHandlerRootView } from 'react-native-gesture-handler'
import { Drawer } from 'one/drawer'
export default function Layout() {
return (
<GestureHandlerRootView style={{ flex: 1 }}>
<Drawer />
</GestureHandlerRootView>
)
}
GestureHandlerRootView wrapper is required for gesture handling to work properly on native platforms.You can customize the drawer appearance and behavior using screenOptions:
_layout.tsx
import { GestureHandlerRootView } from 'react-native-gesture-handler'
import { Drawer } from 'one/drawer'
export default function Layout() {
return (
<GestureHandlerRootView style={{ flex: 1 }}>
<Drawer
screenOptions={{
headerShown: true,
drawerType: 'front',
// improve swipe gesture feel
swipeEdgeWidth: 80,
swipeMinDistance: 20,
}}
>
<Drawer.Screen
name="index"
options={{
drawerLabel: 'Home',
title: 'Home',
}}
/>
<Drawer.Screen
name="settings"
options={{
drawerLabel: 'Settings',
title: 'Settings',
}}
/>
</Drawer>
</GestureHandlerRootView>
)
}
You can open and close the drawer programmatically using navigation:
import { useNavigation, DrawerActions } from '@react-navigation/native'
function MyScreen() {
const navigation = useNavigation()
return (
<Button
onPress={() => navigation.dispatch(DrawerActions.openDrawer())}
title="Open Drawer"
/>
)
}
The drawerType option controls how the drawer appears:
'front' (default) - Drawer slides over the content'back' - Content slides to reveal drawer behind'slide' - Both drawer and content slide together'permanent' - Drawer is always visible (good for tablets)| Option | Type | Default | Description |
|---|---|---|---|
drawerType | 'front' | 'back' | 'slide' | 'permanent' | 'front' | How the drawer animates |
swipeEdgeWidth | number | 32 | Width of the swipe area from screen edge |
swipeMinDistance | number | 60 | Minimum swipe distance to open drawer |
swipeEnabled | boolean | true | Enable/disable swipe gestures |
drawerPosition | 'left' | 'right' | 'left' | Which side the drawer appears |
headerShown | boolean | true | Show/hide the header |
The Drawer requires these optional peer dependencies to be installed:
npm install @react-navigation/drawer react-native-gesture-handler react-native-reanimated
These are marked as optional peer dependencies in one, so they won’t be installed automatically. This keeps bundle sizes smaller for apps that don’t use the Drawer.
For more configuration options, see the React Navigation Drawer documentation.
Edit this page on GitHub.