115 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
			
		
		
	
	
			115 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
| import PropTypes from 'prop-types';
 | |
| import { PureComponent } from 'react';
 | |
| 
 | |
| import { defineMessages, injectIntl, FormattedMessage } from 'react-intl';
 | |
| 
 | |
| import { Helmet } from 'react-helmet';
 | |
| import { NavLink, Switch, Route } from 'react-router-dom';
 | |
| 
 | |
| import { connect } from 'react-redux';
 | |
| 
 | |
| import ExploreIcon from '@/material-icons/400-24px/explore.svg?react';
 | |
| import SearchIcon from '@/material-icons/400-24px/search.svg?react';
 | |
| import Column from 'flavours/glitch/components/column';
 | |
| import ColumnHeader from 'flavours/glitch/components/column_header';
 | |
| import Search from 'flavours/glitch/features/compose/containers/search_container';
 | |
| import { identityContextPropShape, withIdentity } from 'flavours/glitch/identity_context';
 | |
| import { trendsEnabled } from 'flavours/glitch/initial_state';
 | |
| 
 | |
| import Links from './links';
 | |
| import SearchResults from './results';
 | |
| import Statuses from './statuses';
 | |
| import Suggestions from './suggestions';
 | |
| import Tags from './tags';
 | |
| 
 | |
| const messages = defineMessages({
 | |
|   title: { id: 'explore.title', defaultMessage: 'Explore' },
 | |
|   searchResults: { id: 'explore.search_results', defaultMessage: 'Search results' },
 | |
| });
 | |
| 
 | |
| const mapStateToProps = state => ({
 | |
|   layout: state.getIn(['meta', 'layout']),
 | |
|   isSearching: state.getIn(['search', 'submitted']) || !trendsEnabled,
 | |
| });
 | |
| 
 | |
| class Explore extends PureComponent {
 | |
|   static propTypes = {
 | |
|     identity: identityContextPropShape,
 | |
|     intl: PropTypes.object.isRequired,
 | |
|     multiColumn: PropTypes.bool,
 | |
|     isSearching: PropTypes.bool,
 | |
|   };
 | |
| 
 | |
|   handleHeaderClick = () => {
 | |
|     this.column.scrollTop();
 | |
|   };
 | |
| 
 | |
|   setRef = c => {
 | |
|     this.column = c;
 | |
|   };
 | |
| 
 | |
|   render() {
 | |
|     const { intl, multiColumn, isSearching } = this.props;
 | |
|     const { signedIn } = this.props.identity;
 | |
| 
 | |
|     return (
 | |
|       <Column bindToDocument={!multiColumn} ref={this.setRef} label={intl.formatMessage(messages.title)}>
 | |
|         <ColumnHeader
 | |
|           icon={isSearching ? 'search' : 'explore'}
 | |
|           iconComponent={isSearching ? SearchIcon : ExploreIcon}
 | |
|           title={intl.formatMessage(isSearching ? messages.searchResults : messages.title)}
 | |
|           onClick={this.handleHeaderClick}
 | |
|           multiColumn={multiColumn}
 | |
|         />
 | |
| 
 | |
|         <div className='explore__search-header'>
 | |
|           <Search />
 | |
|         </div>
 | |
| 
 | |
|         {isSearching ? (
 | |
|           <SearchResults />
 | |
|         ) : (
 | |
|           <>
 | |
|             <div className='account__section-headline'>
 | |
|               <NavLink exact to='/explore'>
 | |
|                 <FormattedMessage tagName='div' id='explore.trending_statuses' defaultMessage='Posts' />
 | |
|               </NavLink>
 | |
| 
 | |
|               <NavLink exact to='/explore/tags'>
 | |
|                 <FormattedMessage tagName='div' id='explore.trending_tags' defaultMessage='Hashtags' />
 | |
|               </NavLink>
 | |
| 
 | |
|               {signedIn && (
 | |
|                 <NavLink exact to='/explore/suggestions'>
 | |
|                   <FormattedMessage tagName='div' id='explore.suggested_follows' defaultMessage='People' />
 | |
|                 </NavLink>
 | |
|               )}
 | |
| 
 | |
|               <NavLink exact to='/explore/links'>
 | |
|                 <FormattedMessage tagName='div' id='explore.trending_links' defaultMessage='News' />
 | |
|               </NavLink>
 | |
|             </div>
 | |
| 
 | |
|             <Switch>
 | |
|               <Route path='/explore/tags' component={Tags} />
 | |
|               <Route path='/explore/links' component={Links} />
 | |
|               <Route path='/explore/suggestions' component={Suggestions} />
 | |
|               <Route exact path={['/explore', '/explore/posts', '/search']}>
 | |
|                 <Statuses multiColumn={multiColumn} />
 | |
|               </Route>
 | |
|             </Switch>
 | |
| 
 | |
|             <Helmet>
 | |
|               <title>{intl.formatMessage(messages.title)}</title>
 | |
|               <meta name='robots' content={isSearching ? 'noindex' : 'all'} />
 | |
|             </Helmet>
 | |
|           </>
 | |
|         )}
 | |
|       </Column>
 | |
|     );
 | |
|   }
 | |
| 
 | |
| }
 | |
| 
 | |
| export default withIdentity(connect(mapStateToProps)(injectIntl(Explore)));
 |