hallvardlh-react-native-drawer
v1.0.3
Published
A customizable side drawer component for React Native. The drawer has no boilerplate, just functionality. It's animated, and can be dismissed by outside click, user swipe or function call.
Downloads
3
Readme
react-native-side-drawer
A customizable side drawer component for React Native. The drawer has no boilerplate, just functionality. It's animated, and can be dismissed by outside click, user swipe or function call.
Table of Contents
Installation
npm install hallvardlh-react-native-drawer
Usage
Basic component with a drawer using default settings.
import { View, Text, TouchableOpacity } from 'react-native';
import { useRef } from 'react';
import { Drawer } from 'hallvardlh-react-native-drawer';
export default function MyComponent() {
const drawerRef1 = useRef(null);
return (
<View>
<TouchableOpacity onPress={() => drawerRef1.current?.openDrawer()}>
<Text>Open Drawer 1</Text>
</TouchableOpacity>
<Drawer ref={drawerRef1}>
<TouchableOpacity onPress={() => drawerRef1.current?.closeDrawer()}>
<Text>Close drawer</Text>
</TouchableOpacity>
<Text>Drawer 1 content</Text>
</Drawer>
</View>
);
}
Props
| Prop | Type | Default | Description | ------------ | -------------- | ------------- | - | children | ReactNode | null | The content of the drawer. | onStateChange | function| - | Callback function that gets triggered when the drawer state changes. It receives a boolean (isOpen) indicating the drawer's state. | | side | string | 'right' | The side to which the drawer will be aligned, which side it will come from. Accepts: 'left' or 'right'. | width | string | '85%' | Specifies the width of the drawer. Accepts strings ending in either 'px' or '%'. Percentage values represent percentage of the screen's width. | maxWidth | string | '500px' | Specifies the maxium width of the drawer. This is inteded to avoid ridiculously long drawers on wider screens. Accepts strings ending in either 'px' or '%'. Value can also be 'none' to remove maxWidth. | containerStyle | StyleProp | null | Allows setting custom styles on the view that containing the children. | backgroundColor | string | 'white' | The background color of the view containing children. Accepts any CSS color value as a string.
ScrollView
Warning: The default ScrollViews and FlatLists from React Native cannot be used within the drawer.
The ScrollView and FlatList from React Native Gesture Handler must be used instead. This is due to default ScrollViews not working properly within gesture handlers on Android.
Simply import the ScrollView as such:
import { ScrollView } from "react-native-gesture-handler";
Or in case ScrollView is already being used within the file:
import { ScrollView as DrawerScrollView } from "react-native-gesture-handler";
These ScrollViews and FlatLists are used just like default.
Callbacks
onStateChange
The Drawer component has one callback, onStateChange, which returns a boolean upon completing an opening or closing animation.
Usage example:
<Drawer
onStateChange={(isOpen) => {
if (isOpen) {
console.log('Drawer opened!');
} else {
console.log('Drawer closed!');
}
}}
>
Contribution
Pull requests are welcome! For major changes, please open an issue first to discuss what you would like to change.