A simple search bar component for React Native

React-Native-Input-Search-Bar

A simple search bar component for React Native.

Installation

  • 1.Run npm i react-native-input-search-bar --save
    • or yarn add react-native-input-search-bar
  • 2.import ReactNativeInputSearchBar from 'react-native-input-search-bar'

Getting Started

Add react-native-input-search-bar to your js file.

import ReactNativeInputSearchBar from 'react-native-input-search-bar'

Inside your component’s render method, use ReactNativeInputSearchBar:

 render() {
     return (
         <View>
          <ReactNativeInputSearchBar
            onSubmitSearch={(_val) => {
              console.log(_val);
            }}
            ...
            buttonText="Search"
          />
         </View>
     );
 }

Basic usage

import ReactNativeInputSearchBar from 'react-native-input-search-bar'
import React, { useState } from 'react'

const SearchBar = () => {
  const [query, setQuery] = useState < string > defQuery
  const [activeSearch, setActiveSearch] = useState < boolean > false

  const onSubmitSearch = (val: string) => {
    setQuery(val)
  }

  return (
    <ReactNativeInputSearchBar
      onSubmitSearch={onSubmitSearch}
      onActiveSearch={setActiveSearch}
      inputTextStyle={{}}
      buttonStyle={{
        paddingHorizontal: 20
      }}
      buttonTextStyle={{}}
      searchToolContainerStyle={{ height: 40 }}
      inputContainerStyle={{
        backgroundColor: theme.colors.white,
        borderWidth: 0.3,
        borderRadius: 20
      }}
      inputProps={{
        placeholder: 'Please enter your search query'
      }}
      buttonText="Search"
    />
  )
}

export default SearchBar

Props

Props for ReactNativeInputSearchBar

Prop Type Default Description
onSubmitSearch function Callback function when the search button is pressed.
onActiveSearch function Callback function when the search bar is active.
inputTextStyle object Style for the input text.
buttonStyle object Style for the search button.
buttonTextStyle object Style for the search button text.
searchToolContainerStyle object Style for the search tool container.
inputContainerStyle object Style for the input container.
inputProps object Props for the input.
buttonText string Text for the search button.
clearButton boolean true Whether to show the clear button.
inputActiveColor string Color for the input when active.
inputInactiveColor string Color for the input when inactive.
iconStyle object Style for the search icon.
customIcon element Custom icon for the search input icon.

TypeDefine for ReactNativeInputSearchBar

interface RNInputSearchBarProps {
  searchToolContainerStyle?: StyleProp<ViewStyle>
  clearButton?: boolean
  onActiveSearch: (val: boolean) => void
  onSubmitSearch: (val: string) => void
  inputActiveColor?: ColorValue
  inputInactiveColor?: ColorValue
  inputContainerStyle?: StyleProp<ViewStyle>
  inputTextStyle?: StyleProp<TextStyle>
  inputProps?: TextInputProps
  customIcon?: ReactNode
  iconStyle?: StyleProp<ViewStyle>
  buttonStyle?: StyleProp<ViewStyle>
  buttonText?: string
  buttonTextStyle?: StyleProp<TextStyle>
}

Reference

  • React Native is a JavaScript framework for writing real, natively rendering mobile applications for iOS and Android.

Contribution

If you have any questions or suggestions, please feel free to open an issue or pull request.

License

MIT License © 2022 funnyzak

GitHub

View Github