diff --git a/src/utils/SearchField.js b/src/utils/SearchField.js index bb3f6026..2b460fa8 100644 --- a/src/utils/SearchField.js +++ b/src/utils/SearchField.js @@ -1,4 +1,4 @@ -import React from 'react'; +import React, { useState } from 'react'; import { FontAwesomeIcon } from '@fortawesome/react-fontawesome'; import { faSearch as searchIcon } from '@fortawesome/free-solid-svg-icons'; import PropTypes from 'prop-types'; @@ -6,69 +6,59 @@ import classNames from 'classnames'; import './SearchField.scss'; const DEFAULT_SEARCH_INTERVAL = 500; +let timer; -export default class SearchField extends React.Component { - static propTypes = { - onChange: PropTypes.func.isRequired, - className: PropTypes.string, - placeholder: PropTypes.string, - large: PropTypes.bool, - noBorder: PropTypes.bool, +const propTypes = { + onChange: PropTypes.func.isRequired, + className: PropTypes.string, + placeholder: PropTypes.string, + large: PropTypes.bool, + noBorder: PropTypes.bool, +}; + +const SearchField = ({ onChange, className, placeholder = 'Search...', large = true, noBorder = false }) => { + const [ searchTerm, setSearchTerm ] = useState(''); + + const resetTimer = () => { + clearTimeout(timer); + timer = null; }; - static defaultProps = { - className: '', - placeholder: 'Search...', - large: true, - noBorder: false, - }; - - state = { showClearBtn: false, searchTerm: '' }; - timer = null; - - searchTermChanged(searchTerm, timeout = DEFAULT_SEARCH_INTERVAL) { - this.setState({ - showClearBtn: searchTerm !== '', - searchTerm, - }); - - const resetTimer = () => { - clearTimeout(this.timer); - this.timer = null; - }; + const searchTermChanged = (newSearchTerm, timeout = DEFAULT_SEARCH_INTERVAL) => { + setSearchTerm(newSearchTerm); resetTimer(); - this.timer = setTimeout(() => { - this.props.onChange(searchTerm); + timer = setTimeout(() => { + onChange(newSearchTerm); resetTimer(); }, timeout); - } + }; - render() { - const { className, placeholder, large, noBorder } = this.props; - - return ( -