/** * Copyright (c) Facebook, Inc. and its affiliates. * * This source code is licensed under the MIT license found in the * LICENSE file in the root directory of this source tree. * * @format * @flow strict-local */ 'use strict'; var React = require('react'); var ReactNative = require('react-native'); var { Modal, Picker, Platform, StyleSheet, Switch, Text, TouchableHighlight, View, } = ReactNative; const Item = Picker.Item; exports.displayName = (undefined: ?string); exports.framework = 'React'; exports.title = ''; exports.description = 'Component for presenting modal views.'; class Button extends React.Component<$FlowFixMeProps, $FlowFixMeState> { state = { active: false, }; _onHighlight = () => { this.setState({active: true}); }; _onUnhighlight = () => { this.setState({active: false}); }; render() { var colorStyle = { color: this.state.active ? '#fff' : '#000', }; return ( {this.props.children} ); } } const supportedOrientationsPickerValues = [ ['portrait'], ['landscape'], ['landscape-left'], ['portrait', 'landscape-right'], ['portrait', 'landscape'], [], ]; class ModalExample extends React.Component<{}, $FlowFixMeState> { state = { animationType: 'none', modalVisible: false, transparent: false, presentationStyle: 'fullScreen', selectedSupportedOrientation: 0, currentOrientation: 'unknown', }; _setModalVisible = visible => { this.setState({modalVisible: visible}); }; _setAnimationType = type => { this.setState({animationType: type}); }; _toggleTransparent = () => { this.setState({transparent: !this.state.transparent}); }; renderSwitch() { if (Platform.isTV) { return null; } return ( ); } render() { var modalBackgroundStyle = { backgroundColor: this.state.transparent ? 'rgba(0, 0, 0, 0.5)' : '#f5fcff', }; var innerContainerTransparentStyle = this.state.transparent ? {backgroundColor: '#fff', padding: 20} : null; var activeButtonStyle = { backgroundColor: '#ddd', }; return ( this._setModalVisible(false)} supportedOrientations={ supportedOrientationsPickerValues[ this.state.selectedSupportedOrientation ] } onOrientationChange={evt => this.setState({currentOrientation: evt.nativeEvent.orientation}) }> This modal was presented{' '} {this.state.animationType === 'none' ? 'without' : 'with'}{' '} animation. It is currently displayed in {this.state.currentOrientation}{' '} mode. Animation Type Transparent {this.renderSwitch()} {this.renderPickers()} ); } renderPickers() { if (Platform.isTV) { return null; } return ( Presentation style this.setState({presentationStyle}) } itemStyle={styles.pickerItem}> Supported orientations this.setState({selectedSupportedOrientation: i}) } itemStyle={styles.pickerItem}> ); } } exports.examples = [ { title: 'Modal Presentation', description: 'Modals can be presented with or without animation', render: () => , }, ]; var styles = StyleSheet.create({ container: { flex: 1, justifyContent: 'center', padding: 20, }, innerContainer: { borderRadius: 10, alignItems: 'center', }, row: { alignItems: 'center', flex: 1, flexDirection: 'row', marginBottom: 20, }, rowTitle: { flex: 1, fontWeight: 'bold', }, button: { borderRadius: 5, flexGrow: 1, height: 44, alignSelf: 'stretch', justifyContent: 'center', overflow: 'hidden', }, buttonText: { fontSize: 18, margin: 5, textAlign: 'center', }, modalButton: { marginTop: 10, }, pickerItem: { fontSize: 16, }, });