/** * The examples provided by Facebook are for non-commercial testing and * evaluation purposes only. * * Facebook reserves all rights not expressly granted. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NON INFRINGEMENT. IN NO EVENT SHALL * FACEBOOK BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN * AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. * * @providesModule SearchBar * @flow */ 'use strict'; var React = require('react'); var ReactNative = require('react-native'); var { Image, Platform, ProgressBarAndroid, TextInput, StyleSheet, TouchableNativeFeedback, View, } = ReactNative; var IS_RIPPLE_EFFECT_SUPPORTED = Platform.Version >= 21; var SearchBar = React.createClass({ render: function() { var loadingView; if (this.props.isLoading) { loadingView = ( ); } else { loadingView = ; } var background = IS_RIPPLE_EFFECT_SUPPORTED ? TouchableNativeFeedback.SelectableBackgroundBorderless() : TouchableNativeFeedback.SelectableBackground(); return ( this.refs.input && this.refs.input.focus()}> {loadingView} ); } }); var styles = StyleSheet.create({ searchBar: { flexDirection: 'row', alignItems: 'center', backgroundColor: '#a9a9a9', height: 56, }, searchBarInput: { flex: 1, fontSize: 20, fontWeight: 'bold', color: 'white', height: 50, padding: 0, backgroundColor: 'transparent' }, spinner: { width: 30, height: 30, }, icon: { width: 24, height: 24, marginHorizontal: 8, }, }); module.exports = SearchBar;