SearchSuggest.js 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. import React from 'react';
  2. import PropTypes from 'prop-types';
  3. import ListView from '../PageList/ListView';
  4. export default class SearchSuggest extends React.Component {
  5. render() {
  6. if (!this.props.focused) {
  7. return <div></div>;
  8. }
  9. if (this.props.searching) {
  10. return (
  11. <div className="search-suggest" id="search-suggest">
  12. <i className="searcing fa fa-circle-o-notch fa-spin fa-fw"></i> Searching ...
  13. </div>
  14. );
  15. }
  16. if (this.props.searchError !== null) {
  17. return (
  18. <div className="search-suggest" id="search-suggest">
  19. <i className="searcing fa fa-warning"></i> Error on searching.
  20. </div>
  21. );
  22. }
  23. if (this.props.searchedPages.length < 1) {
  24. if (this.props.searchingKeyword !== '') {
  25. return (
  26. <div className="search-suggest" id="search-suggest">
  27. No results for "{this.props.searchingKeyword}".
  28. </div>
  29. );
  30. }
  31. return <div></div>;
  32. }
  33. return (
  34. <div className="search-suggest" id="search-suggest">
  35. <ListView pages={this.props.searchedPages} />
  36. </div>
  37. );
  38. }
  39. }
  40. SearchSuggest.propTypes = {
  41. searchedPages: PropTypes.array.isRequired,
  42. searchingKeyword: PropTypes.string.isRequired,
  43. searching: PropTypes.bool.isRequired,
  44. };
  45. SearchSuggest.defaultProps = {
  46. searchedPages: [],
  47. searchingKeyword: '',
  48. searchError: null,
  49. searching: false,
  50. focused: false,
  51. };