@nghinv/react-native-action-sheet
v1.0.9
Published
A custom action sheet component
Downloads
3
Maintainers
Readme
@nghinv/react-native-action-sheet
A custom alert component with react-native-reanimated
Installation
Installing the package
- Use yarn
yarn add @nghinv/react-native-action-sheet
- Use npm
npm install @nghinv/react-native-action-sheet
yarn add react-native-gesture-handler react-native-reanimated react-native-safe-area-context @nghinv/react-native-icons
- Peer dependencies
How to use
- Wrapper
ActionSheetService
in theRoot Component
import { ActionSheetService } from '@nghinv/react-native-action-sheet';
...
return (
<ActionSheetService>
<RootComponent />
</ActionSheetService>
);
...
- Use
ActionSheet.show()
andActionSheet.hide()
import React from 'react';
import { View, StyleSheet, Button } from 'react-native';
import { ActionSheet } from '@nghinv/react-native-action-sheet';
export default function Example() {
const onPress = () => {
ActionSheet.show({
title: 'React Native Debug Menu',
message: 'Running JSI (<JSCRuntime@0x6000003a3ad50>)',
bottomTitle: 'Cancel',
zIndex: 10,
options: [
{
title: 'Hello',
autoDismiss: false,
onPress: () => {},
},
{
title: 'Good morning',
leftIconName: 'photo',
checked: true,
renderRight: () => (
<View
style={{
width: 40, height: 40, backgroundColor: 'red'
}}
/>
),
},
{ title: 'Good afternoon', checked: true },
],
});
};
return (
<View style={styles.container}>
<Button title='Show action sheet' onPress={onPress} />
</View>
)
}
const styles = StyleSheet.create({
container: {
flex: 1,
justifyContent: 'center',
alignItems: 'center',
backgroundColor: 'skyblue'
}
});