Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/beefe/react-native-popup

popup for react-native
https://github.com/beefe/react-native-popup

Last synced: about 1 month ago
JSON representation

popup for react-native

Awesome Lists containing this project

README

        

# react-native-popup
[![npm version](https://img.shields.io/npm/v/react-native-popup.svg?style=flat-square)](https://www.npmjs.com/package/react-native-popup)

This is a custom component for React Native, a simple popup, compatible with ios and android.

###Demo
![ui](./doc/ui.gif)

###Props
- isOverlay *bool* - *`default true`*
- isOverlayClickClose *bool* - *`default true`*

###~~*`static`*~~ Methods
- alert(`message`: *string*|*number*, [...])
```javascript
e.g.

this.popup.alert(1);

this.popup.alert(1, 'two', '10 messages at most');
```
- tip({ `title`: *string*, `content`: *string*|*number*|*array*<*string*|*number*> *`isRequired`*, `btn`: {`title`: *string* *`default 'OK'`*, `callback`: *function*}, })
```javascript
e.g.

this.popup.tip({
content: 'come on!',
});

this.popup.tip({
title: 'TipTip',
content: 'come on!',
});

this.popup.tip({
content: ['come on!', 'go!'],
btn: {
text: 'OKOK',
style: {
color: 'red'
},
callback: () => {
this.popup.alert('over!');
},
},
});
```
- confirm({ `title`: *string*, `content`: *string*|*number*|*array*<*string*|*number*> *`isRequired`*, `ok`: {`title`: *string* *`default 'OK'`*, `callback`: *function*}, `cancel`: {`title`: *string* *`default 'Cancel'`*, `callback`: *function*}, })
```javascript
e.g.

this.popup.confirm({
content: 'Are you ready?',
});

this.popup.confirm({
content: 'Are you ready?',
ok: {
callback: () => {
this.popup.alert('Very good!');
},
},
});

this.popup.confirm({
title: 'title',
content: ['come on!', 'go!'],
ok: {
text: 'Y',
style: {
color: 'red'
},
callback: () => {
this.popup.alert('Good!');
},
},
cancel: {
text: 'N',
style: {
color: 'blue'
},
callback: () => {
this.popup.alert('Hurry up!');
},
},
});
```

###Usage
####Step 1 - install

```
npm install react-native-popup --save
```

####Step 2 - import and use in project

```javascript
import Popup from 'react-native-popup';

class App extends React.Component{

onPressHandle() {
// alert
this.popup.alert(1);
},

render() {
return (

click me !

{/** Popup component */}
this.popup = popup }/>
{/** or this.popup = popup } isOverlay={false} isOverlayClickClose={false}/> */}


);
},

};
```