Drawer
Display overlay area at any side of the screen
Source
Docs
Package
Usage
Position
Drawer can be placed on left (default), top, right and bottom. Control drawer position with position prop,
for example <Drawer position="top" />.
Offset
Set offset prop to change drawer offset from the edge of the viewport:
Customize overlay
Drawer uses Overlay component, you can set any props that Overlay
supports with overlayProps:
Sizes
You can change drawer width/height (depends on position) by setting size prop to predefined size or any valid width,
for example, size="55%" or size={200}:
Remove header
To remove header set withCloseButton={false}
Drawer with scroll
Usage with ScrollArea
Change transition
Drawer is built with Transition component. Use transitionProps
prop to customize any Transition properties:
onExitTransitionEnd and onEnterTransitionEnd
onExitTransitionEnd and onEnterTransitionEnd props can be used to run code after
exit/enter transition is finished. For example, this is useful when you want to clear
data after drawer is closed:
Initial focus
Drawer uses FocusTrap to trap focus. Add data-autofocus
attribute to the element that should receive initial focus.
If you do not want to focus any elements when the drawer is opened, use FocusTrap.InitialFocus
component to create a visually hidden element that will receive initial focus:
If you do not add data-autofocus attribute and do not use FocusTrap.InitialFocus,
drawer will focus the first focusable element inside it which is usually the close button.
Control behavior
The following props can be used to control Drawer behavior.
In most cases it is not recommended to turn these features off –
it will make the component less accessible.
- trapFocus– determines whether focus should be trapped inside drawer
- closeOnEscape– determines whether the drawer should be closed when- Escapekey is pressed
- closeOnClickOutside– determines whether the drawer should be closed when user clicks on the overlay
- returnFocus– determines whether focus should be returned to the element that was focused before the drawer was opened
react-remove-scroll settings
Drawer uses react-remove-scroll
package to lock scroll. You can pass props down to the RemoveScroll component
with removeScrollProps:
Change close icon
Use closeButtonProps to customize close button:
Compound components
You can use the following compound components to have full control over the Drawer rendering:
- Drawer.Root– context provider
- Drawer.Overlay– render Overlay
- Drawer.Content– main drawer element, should include all drawer content
- Drawer.Header– sticky header, usually contains- Drawer.Titleand- Drawer.CloseButton
- Drawer.Title–- h2element,- aria-labelledbyof- Drawer.Contentis pointing to this element, usually is rendered inside- Drawer.Header
- Drawer.CloseButton– close button, usually rendered inside- Drawer.Header
- Drawer.Body– a place for main content,- aria-describedbyof- Drawer.Contentis pointing to this element
Drawer.Stack
Use Drawer.Stack component to render multiple drawers at the same time.
Drawer.Stack keeps track of opened drawers, manages z-index values, focus trapping
and closeOnEscape behavior. Drawer.Stack is designed to be used with useDrawersStack hook.
Differences from using multiple Drawer components:
- Drawer.Stackmanages z-index values – drawers that are opened later will always have higher z-index value disregarding their order in the DOM
- Drawer.Stackdisables focus trap and- Escapekey handling for all drawers except the one that is currently opened
- Drawers that are not currently opened are present in the DOM but are hidden with opacity: 0andpointer-events: none
- Only one overlay is rendered at a time
Note that Drawer.Stack can only be used with Drawer component. Components built with Drawer.Root
and other compound components are not compatible with Drawer.Stack.
useDrawersStack hook
useDrawersStack hook provides an easy way to control multiple drawers at the same time.
It accepts an array of unique drawers ids and returns an object with the following properties:
Example of using useDrawersStack with Drawer component:
Fixed elements offset
Drawer component uses react-remove-scroll
package to lock scroll. To properly size these elements add a className to them (documentation):
Accessibility
Drawer component follows WAI-ARIA recommendations on accessibility.
Set title props to make component accessible, will add aria-labelledby to the content element:
To set close button aria-label use closeButtonProps: