/** * Copyright (c) 2015-present, Facebook, Inc. * All rights reserved. * * This source code is licensed under the BSD-style license found in the * LICENSE file in the root directory of this source tree. An additional grant * of patent rights can be found in the PATENTS file in the same directory. * * @providesModule RNTesterPage * @flow */ 'use strict'; var PropTypes = require('prop-types'); var React = require('react'); var ReactNative = require('react-native'); var { ScrollView, StyleSheet, View, } = ReactNative; var RNTesterTitle = require('./RNTesterTitle'); class RNTesterPage extends React.Component { props: { noScroll?: boolean, noSpacer?: boolean, }; static propTypes = { noScroll: PropTypes.bool, noSpacer: PropTypes.bool, }; render() { var ContentWrapper; var wrapperProps = {}; if (this.props.noScroll) { ContentWrapper = ((View: any): ReactClass); } else { ContentWrapper = (ScrollView: ReactClass); // $FlowFixMe found when converting React.createClass to ES6 wrapperProps.automaticallyAdjustContentInsets = !this.props.title; wrapperProps.keyboardShouldPersistTaps = 'handled'; wrapperProps.keyboardDismissMode = 'interactive'; } var title = this.props.title ? : null; var spacer = this.props.noSpacer ? null : ; return ( {title} { // $FlowFixMe found when converting React.createClass to ES6 this.props.children} {spacer} ); } } var styles = StyleSheet.create({ container: { backgroundColor: '#e9eaed', flex: 1, }, spacer: { height: 270, }, wrapper: { flex: 1, paddingTop: 10, }, }); module.exports = RNTesterPage;