Global modal and callable from anywhere on the app for React Native

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

  • LICENSE
  • More built-in modal types
    • Notification Type
    • One Button
    • One Outline Button
  • 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, kurayogun@gmail.com

License

React Native Global Modal is available under the MIT license. See the LICENSE file for more info.

GitHub

View Github