/** * Copyright (c) 2015-present, Facebook, Inc. * * This source code is licensed under the MIT license found in the * LICENSE file in the root directory of this source tree. * * @flow * @providesModule TabBarIOSExample */ 'use strict'; var React = require('react'); var ReactNative = require('react-native'); var { StyleSheet, TabBarIOS, Text, View, } = ReactNative; var base64Icon = ''; class TabBarExample extends React.Component<{}, $FlowFixMeState> { static title = ''; static description = 'Tab-based navigation.'; static displayName = 'TabBarExample'; state = { selectedTab: 'redTab', notifCount: 0, presses: 0, }; _renderContent = (color: string, pageText: string, num?: number) => { return ( {pageText} {num} re-renders of the {pageText} ); }; render() { return ( { this.setState({ selectedTab: 'blueTab', }); }}> {this._renderContent('#414A8C', 'Blue Tab')} 0 ? this.state.notifCount : undefined} badgeColor="black" selected={this.state.selectedTab === 'redTab'} onPress={() => { this.setState({ selectedTab: 'redTab', notifCount: this.state.notifCount + 1, }); }}> {this._renderContent('#783E33', 'Red Tab', this.state.notifCount)} { this.setState({ selectedTab: 'greenTab', presses: this.state.presses + 1 }); }}> {this._renderContent('#21551C', 'Green Tab', this.state.presses)} ); } } var styles = StyleSheet.create({ tabContent: { flex: 1, alignItems: 'center', }, tabText: { color: 'white', margin: 50, }, }); module.exports = TabBarExample;