diff options
Diffstat (limited to 'src/client/react/components/presentational')
-rw-r--r-- | src/client/react/components/presentational/Search.jsx | 61 |
1 files changed, 0 insertions, 61 deletions
diff --git a/src/client/react/components/presentational/Search.jsx b/src/client/react/components/presentational/Search.jsx deleted file mode 100644 index 096cdf3..0000000 --- a/src/client/react/components/presentational/Search.jsx +++ /dev/null @@ -1,61 +0,0 @@ -import React from 'react'; -import PropTypes from 'prop-types'; -import classnames from 'classnames'; -import SearchIcon from 'react-icons/lib/md/search'; - -import IconFromUserType from './IconFromUserType'; -import Result from './Result'; - -const userShape = { - value: PropTypes.string.isRequired, - type: PropTypes.string.isRequired, -}; - -const Search = ({ - onInputChange, - onFocus, - onBlur, - hasFocus, - value, - results, - exactMatch, -}) => ( - <div className={classnames('search', { 'search--has-focus': hasFocus, 'search--has-results': results.length > 0 })}> - <div className="search__input-wrapper"> - {/* Show the icon from the exact match if there is an exact match, otherwise show the search icon. */} - <div className="search__icon-wrapper"> - <IconFromUserType - userType={exactMatch ? exactMatch.type : null} - default={<SearchIcon />} - /> - </div> - <input - id="search__input" - onChange={onInputChange} - value={value} - placeholder="Zoeken" - onFocus={onFocus} - onBlur={onBlur} - /> - </div> - {results.map(user => ( - <Result key={user.value} user={user} /> - ))} - </div> -); - -Search.propTypes = { - onInputChange: PropTypes.func.isRequired, - onFocus: PropTypes.func.isRequired, - onBlur: PropTypes.func.isRequired, - hasFocus: PropTypes.bool.isRequired, - value: PropTypes.string.isRequired, - results: PropTypes.arrayOf(PropTypes.shape(userShape)).isRequired, - exactMatch: PropTypes.shape(userShape), -}; - -Search.defaultProps = { - exactMatch: null, -}; - -export default Search; |