<Drawer />

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.

Basic Usage

_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>
)
}
The GestureHandlerRootView wrapper is required for gesture handling to work properly on native platforms.

With Screen Options

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>
)
}

Programmatic Control

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" />
)
}

Drawer Types

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)

Common Options

OptionTypeDefaultDescription
drawerType'front' | 'back' | 'slide' | 'permanent''front'How the drawer animates
swipeEdgeWidthnumber32Width of the swipe area from screen edge
swipeMinDistancenumber60Minimum swipe distance to open drawer
swipeEnabledbooleantrueEnable/disable swipe gestures
drawerPosition'left' | 'right''left'Which side the drawer appears
headerShownbooleantrueShow/hide the header

Dependencies

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.