BottomSheet
AMA Provides an accessible bottom sheet built on top of react-native-reanimated and react-native-gesture-handler.
Example
<BottomSheet
  visible={modalVisible}
  onRequestClose={() => {
    setModalVisible(!modalVisible);
  }}
  closeActionAccessibilityLabel="close bottomsheet"
  bottomSheetStyle={styles.modalView}
  headerComponent={
    <View style={{ paddingHorizontal: theme.padding.big }}>
      <Header title="This is the bottom sheet" />
    </View>
  }
  scrollViewStyle={styles.modalViewContent}>
  <Pressable
    onPress={() => setModalVisible(!modalVisible)}
    accessibilityRole="button">
    <Text>Close bottom sheet</Text>
  </Pressable>
</BottomSheet>
Accessibility
- Checks that the closeActionAccessibilityLabelis a valid accessibilityLabel
- Provides a way to close the bottom sheet when the user taps on the overlay
- Makes sure that the overlay is announced as "button"
- Uses slide-in and slide-out animation only if the [Reduce Motion] (https://reactnative.dev/docs/accessibilityinfo) preference is turned off
- Prevents the focus from escaping the bottom sheet
- Provides a draggable area respecting the minimum size
Props
animationDuration
The duration in milliseconds of the slide in/out animation.
| Type | Default | 
|---|---|
| number | 300 | 
autoCloseDelay
The duration in milliseconds before auto-closing the bottom sheet
| Type | Default | 
|---|---|
| number | undefined | 
The auto-close will respect the user Timed action preference.
bottomSheetStyle
The style to use for the bottom sheet panel
| Type | Default | 
|---|---|
| ViewStyle | { width: '100%', backgroundColor: '#fff' } | 
Required closeActionAccessibilityLabel
The accessibility label to use for the overlay button.
| Type | 
|---|
| string | 
footerComponent
The bottom sheet footer component.
| Type | 
|---|
| JSX.Element | 
handleComponent
It can be used to either disable the default handle "line" or replace it with a custom component.
| Type | 
|---|
| JSX.Element | 'none' | 
handleStyle
The style for the draggable line
| Type | Default | 
|---|---|
| ViewStyle | { width: 48, height: 4, backgroundColor: 'grey', alignSelf: 'center', marginBottom: 24, borderRadius: 2, marginTop: 12 } | 
headerComponent
The bottom sheet header component.
| Type | 
|---|
| JSX.Element | 
maxHeight
The maximum height of the bottom sheet.
| Type | Default | 
|---|---|
| number | 90% of the screen height | 
minVelocityToClose
The minimum velocity needed by quickly swiping down to close the bottom sheet.
| Type | Default | 
|---|---|
| number | 90% of the screen height | 
Required onClose
The callback to trigger when the BottomSheet is dismissed
| Type | 
|---|
| () => void | 
overlayOpacity
The opacity of the overlay.
| Type | Default | 
|---|---|
| number | 1 | 
overlayStyle
The style to use for the overlay
| Type | Default | 
|---|---|
| ViewStyle | { backgroundColor: 'rgba(0, 0, 0, 0.5)', flex: 1 } | 
panGestureEnabled
Enable or disable the dragging gesture.
| Type | Default | 
|---|---|
| boolean | true | 
persistent
If true, the bottom sheet will not be closed when the user taps on the overlay; the dragging gesture is also disabled.
| Type | Default | 
|---|---|
| boolean | true | 
scrollEnabled
Enabled/disables the scrolling of the <ScrollView /> that wraps the BottomSheet content
| Type | Default | 
|---|---|
| boolean | false | 
scrollViewProps
The props to use for the <ScrollView /> that wraps the BottomSheet content
| Type | Default | 
|---|---|
| scrollViewProps | undefined | 
Required topInset
The value is used to calculate the correct max ScrollView height.
| Type | Default | 
|---|---|
| number | 0 | 
Required visible
The BottomSheet visibility
| Type | 
|---|
| boolean | 
Known issues
If the app crashes with the following error:
Unsupported top level event type "onGestureHandlerStateChange" dispatched
Add the following import at the top of your App.tsx|jsx file:
// https://github.com/software-mansion/react-native-gesture-handler/issues/320
import 'react-native-gesture-handler';