react-native-global-modal-2
v1.3.0
Published
๐ Global modal and callable from anywhere on the app for React Native
Downloads
302
Maintainers
Readme
Installation
Add the dependency:
npm i react-native-global-modal-2
Peer dependencies
"react-native-modal": "^13.0.1"
Usage
Import
import GlobalModal, { ModalController } from "react-native-global-modal-2"
Fundamental Usage
In App.tsx
or wherever your root is, simply put the GlobalModal
to root
You can open it with custom ModalData
with ModalController
Note: This is just an example of the usage
<NavigationContainer>
<MainStack/>
<GlobalModal/>
</NavigationContainer>
Call/control the animated modal with ModalController
import { ModalController, ModalData } from "react-native-global-modal-2"
// Example of ModalData
// You can customize the modal as you want with this format
// **Custom layout** option is also available!
const data: ModalData = {
title: 'Update available',
description: 'A new software version is available for download',
primaryButtonText: 'Update',
outlineButtonText: 'Not now',
titleProps: {
imageSource: require('./assets/cross.png'),
},
onPrimaryButtonPress: () => {},
onOutlineButtonPress: () => {},
};
// Show
ModalController.show(data);
// Hide
ModalController.hide()
Custom Layout Usage
You can completely use your own layout with customLayout
import { ModalController, ModalData } from "react-native-global-modal-2"
const data: ModalData = {
customLayout: (
<View
style={{
borderRadius: 16,
paddingTop: 24,
paddingLeft: 24,
paddingRight: 24,
paddingBottom: 16,
backgroundColor: '#fff',
}}>
<Text>Hello</Text>
</View>
),
};
ModalController.show(data);
Customized Example
You can use any props from react-native-modal
with prop drilling
<GlobalModal
animationIn="fadeIn"
animationOut="fadeOut"
onBackdropPress={ModalController.hide}
/>
Example Project ๐
You can check out the example project ๐ฅฐ
Simply run
npm i
react-native run-ios/android
should work of the example project.
Configuration - Props
Fundamentals
| Property | Type | Default | Description | |----------------------|:--------:| :-------: |-------------------------------------------------| | title | string | undefined | change the title | | description | string | undefined | change the descrition | | primaryButtonText | string | undefined | change the primary button's text | | onPrimaryButtonPress | function | undefined | set function when the primary button is pressed | | onOutlineButtonPress | function | undefined | set function when the primary button is pressed |
Customization (Optionals)
| Property | Type | Default | Description |
| -------------- |:-----------:|:---------:|-------------------------------------------------------------------|
| style | ViewStyle | default | set or override the style object for the main container |
| buttonsContainerStyle | ViewStyle | default | set or override the style object for the buttons' container style |
| TouchableComponent | component | Pressable | set your own component instead of default Pressable
component |
| buttonProps | ButtonProps | default | change button's props (primary button) |
| outlineButtonProps | OutlineButtonProps | default | change button's props (outline button) |
Customization [Button] Component
| Property | Type | Default | Description | |--------------------|:---------:|:---------:|--------------------------------------------------------| | title | string | undefined | change the title | | onPress | function | undefined | set your function | | style | ViewStyle | default | set or override the style object for the main container | | textStyle | TextStyle | default | set or override the style object for the text style |
Customization [OutlineButton] Component
| Property | Type | Default | Description | |--------------------|:---------:|:---------:|--------------------------------------------------------| | title | string | undefined | change the title | | onPress | function | undefined | set your function | | style | ViewStyle | default | set or override the style object for the main container | | textStyle | TextStyle | default | set or override the style object for the text style |
Future Plans
- [x] ~~LICENSE~~
- [ ] More built-in modal types
- [ ] Notification Type
- [ ] One Button
- [ ] One Outline Button
- [x] ~~Custom Layout Feature~~
- [ ] More and better screenshots
- [ ] Write an article about the lib on Medium
Credits
I inspired from Roycechua's global modal example Thank you so much Roycechua ๐
I heavily inspired the design by Patrick Marx Thank you so much sir ๐ฅณ
Author
FreakyCoder, [email protected]
License
React Native Global Modal is available under the MIT license. See the LICENSE file for more info.