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
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
You can open and close the drawer programmatically using navigation:
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:
yarn
npm
bun
pnpm
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.