index.js 3.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. import React from 'react';
  2. import { defineMessages, injectIntl, FormattedMessage } from 'react-intl';
  3. import { connect } from 'react-redux';
  4. import PropTypes from 'prop-types';
  5. import Column from 'mastodon/components/column';
  6. import ColumnHeader from 'mastodon/components/column_header';
  7. import { NavLink, Switch, Route } from 'react-router-dom';
  8. import Links from './links';
  9. import Tags from './tags';
  10. import Statuses from './statuses';
  11. import Suggestions from './suggestions';
  12. import Search from 'mastodon/features/compose/containers/search_container';
  13. import SearchResults from './results';
  14. const messages = defineMessages({
  15. title: { id: 'explore.title', defaultMessage: 'Explore' },
  16. searchResults: { id: 'explore.search_results', defaultMessage: 'Search results' },
  17. });
  18. const mapStateToProps = state => ({
  19. layout: state.getIn(['meta', 'layout']),
  20. isSearching: state.getIn(['search', 'submitted']),
  21. });
  22. export default @connect(mapStateToProps)
  23. @injectIntl
  24. class Explore extends React.PureComponent {
  25. static contextTypes = {
  26. router: PropTypes.object,
  27. };
  28. static propTypes = {
  29. intl: PropTypes.object.isRequired,
  30. multiColumn: PropTypes.bool,
  31. isSearching: PropTypes.bool,
  32. layout: PropTypes.string,
  33. };
  34. handleHeaderClick = () => {
  35. this.column.scrollTop();
  36. }
  37. setRef = c => {
  38. this.column = c;
  39. }
  40. render () {
  41. const { intl, multiColumn, isSearching, layout } = this.props;
  42. return (
  43. <Column bindToDocument={!multiColumn} ref={this.setRef} label={intl.formatMessage(messages.title)}>
  44. {layout === 'mobile' ? (
  45. <div className='explore__search-header'>
  46. <Search />
  47. </div>
  48. ) : (
  49. <ColumnHeader
  50. icon={isSearching ? 'search' : 'hashtag'}
  51. title={intl.formatMessage(isSearching ? messages.searchResults : messages.title)}
  52. onClick={this.handleHeaderClick}
  53. multiColumn={multiColumn}
  54. />
  55. )}
  56. <div className='scrollable scrollable--flex'>
  57. {isSearching ? (
  58. <SearchResults />
  59. ) : (
  60. <React.Fragment>
  61. <div className='account__section-headline'>
  62. <NavLink exact to='/explore'><FormattedMessage id='explore.trending_statuses' defaultMessage='Posts' /></NavLink>
  63. <NavLink exact to='/explore/tags'><FormattedMessage id='explore.trending_tags' defaultMessage='Hashtags' /></NavLink>
  64. <NavLink exact to='/explore/links'><FormattedMessage id='explore.trending_links' defaultMessage='News' /></NavLink>
  65. <NavLink exact to='/explore/suggestions'><FormattedMessage id='explore.suggested_follows' defaultMessage='For you' /></NavLink>
  66. </div>
  67. <Switch>
  68. <Route path='/explore/tags' component={Tags} />
  69. <Route path='/explore/links' component={Links} />
  70. <Route path='/explore/suggestions' component={Suggestions} />
  71. <Route exact path={['/explore', '/explore/posts', '/search']} component={Statuses} componentParams={{ multiColumn }} />
  72. </Switch>
  73. </React.Fragment>
  74. )}
  75. </div>
  76. </Column>
  77. );
  78. }
  79. }