SearchSuggest.js 1.4 KB

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