47 lines
1.4 KiB
JavaScript
47 lines
1.4 KiB
JavaScript
import React, { Component } from 'react';
|
|
import { Text, Modal } from 'react-native';
|
|
import Menu, {
|
|
MenuProvider,
|
|
MenuOptions,
|
|
MenuOption,
|
|
MenuTrigger,
|
|
} from 'react-native-popup-menu';
|
|
|
|
class ModalExample extends Component {
|
|
|
|
constructor(props, ctx) {
|
|
super(props, ctx);
|
|
this.state = { visible: false };
|
|
}
|
|
|
|
render() {
|
|
return (
|
|
<MenuProvider style={{flexDirection: 'column', padding: 30}}>
|
|
<Text>Main window:</Text>
|
|
<Menu>
|
|
<MenuTrigger text='Select option' />
|
|
<MenuOptions>
|
|
<MenuOption onSelect={() => this.setState({ visible: true })} text='Open modal' />
|
|
</MenuOptions>
|
|
</Menu>
|
|
<Modal visible={this.state.visible} onRequestClose={() => this.setState({ visible: false })}>
|
|
<MenuProvider style={{flexDirection: 'column', padding: 30, backgroundColor: 'white'}}>
|
|
<Text>Modal window:</Text>
|
|
<Menu onSelect={value => alert(`Selected number: ${value}`)}>
|
|
<MenuTrigger text='Select option' />
|
|
<MenuOptions>
|
|
<MenuOption value={1} text='One' />
|
|
<MenuOption value={2} text='Two' />
|
|
<MenuOption onSelect={() => this.setState({ visible: false })} text='Close modal' />
|
|
</MenuOptions>
|
|
</Menu>
|
|
</MenuProvider>
|
|
</Modal>
|
|
</MenuProvider>
|
|
);
|
|
}
|
|
|
|
}
|
|
|
|
export default ModalExample;
|