Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mjsolidarios/react-native-search-filter
Modified version of react-search-input (https://github.com/enkidevs/react-search-input) to work with react-native.
https://github.com/mjsolidarios/react-native-search-filter
react react-native search
Last synced: 2 months ago
JSON representation
Modified version of react-search-input (https://github.com/enkidevs/react-search-input) to work with react-native.
- Host: GitHub
- URL: https://github.com/mjsolidarios/react-native-search-filter
- Owner: mjsolidarios
- Created: 2017-07-21T09:32:06.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2023-11-27T01:00:11.000Z (about 1 year ago)
- Last Synced: 2024-04-15T08:10:27.726Z (9 months ago)
- Topics: react, react-native, search
- Language: JavaScript
- Homepage:
- Size: 2.73 MB
- Stars: 116
- Watchers: 4
- Forks: 41
- Open Issues: 30
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# React Native Search Filter
React Native search component with filter function.
![](https://media.giphy.com/media/Y4h9UMnbvmUAHdZ0gy/giphy.gif)
## Getting Started
### Installation
Using `npm`:
`$ npm install react-native-search-filter --save`
Using `yarn`:
`$ yarn add react-native-search-filter`
### Example Usage
Complete example available [here](/example).```js
import React, { Component } from 'react';
import { StyleSheet, Text, View, ScrollView, TouchableOpacity } from 'react-native';
import SearchInput, { createFilter } from 'react-native-search-filter';
import emails from './emails';
const KEYS_TO_FILTERS = ['user.name', 'subject'];export default class App extends Component<{}> {
constructor(props) {
super(props);
this.state = {
searchTerm: ''
}
}
searchUpdated(term) {
this.setState({ searchTerm: term })
}
render() {
const filteredEmails = emails.filter(createFilter(this.state.searchTerm, KEYS_TO_FILTERS))
return (
{ this.searchUpdated(term) }}
style={styles.searchInput}
placeholder="Type a message to search"
/>
{filteredEmails.map(email => {
return (
alert(email.user.name)} key={email.id} style={styles.emailItem}>
{email.user.name}
{email.subject}
)
})}
);
}
}const styles = StyleSheet.create({
container: {
flex: 1,
backgroundColor: '#fff',
justifyContent: 'flex-start'
},
emailItem:{
borderBottomWidth: 0.5,
borderColor: 'rgba(0,0,0,0.3)',
padding: 10
},
emailSubject: {
color: 'rgba(0,0,0,0.5)'
},
searchInput:{
padding: 10,
borderColor: '#CCC',
borderWidth: 1
}
});
```## API and Configuration
| Property | Type | Default | Description |
|-------------|----------|--------------|----------------------------------------------------------------|
|```caseSensitive```|```boolean```|```false```|Define if the search should be case sensitive.|
|```clearIcon```|```Node```|```null```|Optional clear icon. |
|```clearIconViewStyles```|```Style```|```{position:absolute',top: 18,right: 22}```|Optional styles for the clear icon view.|
|```filterKeys```|```string``` or ```[string]```||Will be use by the filter method if no argument is passed there.|
|```fuzzy```|```boolean```|```false```|Define if the search should be fuzzy.|
|```inputViewStyles```| ```Style``` | |Optional styles for the input container. |
| ```onChangeText``` | ```Function``` | Required| Function called when the search term is changed (will be passed as an argument).
|```sortResults```|```boolean```|```false```|Define if search results should be sorted by relevance (only works with fuzzy search).|
|```throttle```|```number```|```200```|Reduce call frequency to the onChange function (in ms).|
|```onSubmitEditing```|```function```|```() => {}```|Defines a function for the keyboard search button onPress.|
|```inputFocus```|```boolean```|```false```|Defines whether the field receives focus.|
|```returnKeyType```|```string```|```done```|Determines how the return key should look. The following values work across platforms: ```done```, ```go```, ```next```, ```search```, ```send```|### Methods
#### ```filter([keys])```
Return a function which can be used to filter an array. keys can be ```string```, ```[string]``` or ```null```.
If an array keys is an array, the function will return true if at least one of the keys of the item matches the search term.
## Static Methods
```js
filter(searchTerm, [keys], [{caseSensitive, fuzzy, sortResults}])
```Return a function which can be used to filter an array. searchTerm can be a regex or a String. keys can be ```string```, ```[string]``` or ```null```.
If an array keys is an array, the function will return true if at least one of the keys of the item matches the search term.
## Known Issues
### Hide ```clearIcon``` if search input is empty.
Provided you have a custom icon package, a short toggle method for the property will do: ```clearIcon={this.state.searchTerm!==''&&}```.
### Fuse.js: Unknown plugin "babel-plugin-add-module-exports"
Add ```babel-plugin-add-module-exports``` as a dev dependency. Fuse.js [#154](https://github.com/krisk/Fuse/issues/154).```npm i babel-plugin-add-module-exports babel-preset-es2015 babel-preset-stage-2 --save-dev```
## Acknowledgement
enkidevs - [Simple react.js component for a search input, providing a filter function ](https://github.com/enkidevs/react-search-input).