Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/wrathchaos/react-native-global-modal-2
🌍 Global modal and callable from anywhere on the app for React Native
https://github.com/wrathchaos/react-native-global-modal-2
android app app-development apple application development front-end global global-modal ios modal programming react-native reactjs ui
Last synced: 3 months ago
JSON representation
🌍 Global modal and callable from anywhere on the app for React Native
- Host: GitHub
- URL: https://github.com/wrathchaos/react-native-global-modal-2
- Owner: WrathChaos
- License: mit
- Created: 2022-12-03T16:40:12.000Z (about 2 years ago)
- Default Branch: master
- Last Pushed: 2023-07-10T20:01:30.000Z (over 1 year ago)
- Last Synced: 2024-11-02T14:51:38.529Z (3 months ago)
- Topics: android, app, app-development, apple, application, development, front-end, global, global-modal, ios, modal, programming, react-native, reactjs, ui
- Language: TypeScript
- Homepage: https://freakycoder.com
- Size: 2.38 MB
- Stars: 12
- Watchers: 2
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
[![React Native Global Modal](https://img.shields.io/badge/-%F0%9F%8C%8D%20Global%20modal%20and%20callable%20from%20anywhere%20on%20the%20app%20for%20React%20Native-orange?style=for-the-badge)](https://github.com/WrathChaos/react-native-global-modal-2)
[![npm version](https://img.shields.io/npm/v/react-native-global-modal-2.svg?style=for-the-badge)](https://www.npmjs.com/package/react-native-global-modal-2)
[![npm](https://img.shields.io/npm/dt/react-native-global-modal-2.svg?style=for-the-badge)](https://www.npmjs.com/package/react-native-global-modal-2)
![Platform - Android and iOS](https://img.shields.io/badge/platform-Android%20%7C%20iOS-blue.svg?style=for-the-badge)
[![License: MIT](https://img.shields.io/badge/License-MIT-green.svg?style=for-the-badge)](https://opensource.org/licenses/MIT)
[![styled with prettier](https://img.shields.io/badge/styled_with-prettier-ff69b4.svg?style=for-the-badge)](https://github.com/prettier/prettier)
# Installation
Add the dependency:
```bash
npm i react-native-global-modal-2
```## Peer dependencies
```json
"react-native-modal": "^13.0.1"
```# Usage
## Import
```jsx
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
```jsx
```
Call/control the animated modal with `ModalController`
```js
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`
```jsx
import { ModalController, ModalData } from "react-native-global-modal-2"const data: ModalData = {
customLayout: (
Hello
),
};
ModalController.show(data);
```### Customized Example
You can use any props from `react-native-modal` with prop drilling
```jsx
```
## 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](https://github.com/roycechua/rn-global-modal-control-example)
Thank you so much [Roycechua](https://github.com/roycechua) 😍I heavily inspired the design by [Patrick Marx](https://dribbble.com/shots/10762430/attachments/2430949?mode=media)
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.