import React from 'react'; import PropTypes from 'prop-types'; import { FormattedMessage, injectIntl } from 'react-intl'; import { connect } from 'react-redux'; import ImmutablePureComponent from 'react-immutable-pure-component'; import ImmutablePropTypes from 'react-immutable-proptypes'; import Icon from 'soapbox/components/icon'; import { fetchTrends } from '../../../actions/trends'; import Hashtag from '../../../components/hashtag'; class TrendsPanel extends ImmutablePureComponent { static propTypes = { intl: PropTypes.object.isRequired, trends: ImmutablePropTypes.list.isRequired, fetchTrends: PropTypes.func.isRequired, limit: PropTypes.number, }; componentDidMount() { this.props.fetchTrends(); } render() { const trends = this.props.trends.sort((a, b) => { const num_a = Number(a.getIn(['history', 0, 'accounts'])); const num_b = Number(b.getIn(['history', 0, 'accounts'])); return num_b - num_a; }).slice(0, this.props.limit); if (trends.isEmpty()) { return null; } return (