autosuggest_hashtag.js 1.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. import React from 'react';
  2. import PropTypes from 'prop-types';
  3. import ShortNumber from 'mastodon/components/short_number';
  4. import { FormattedMessage } from 'react-intl';
  5. export default class AutosuggestHashtag extends React.PureComponent {
  6. static propTypes = {
  7. tag: PropTypes.shape({
  8. name: PropTypes.string.isRequired,
  9. url: PropTypes.string,
  10. history: PropTypes.array,
  11. }).isRequired,
  12. };
  13. render() {
  14. const { tag } = this.props;
  15. const weeklyUses = tag.history && (
  16. <ShortNumber
  17. value={tag.history.reduce((total, day) => total + day.uses * 1, 0)}
  18. />
  19. );
  20. return (
  21. <div className='autosuggest-hashtag'>
  22. <div className='autosuggest-hashtag__name'>
  23. #<strong>{tag.name}</strong>
  24. </div>
  25. {tag.history !== undefined && (
  26. <div className='autosuggest-hashtag__uses'>
  27. <FormattedMessage
  28. id='autosuggest_hashtag.per_week'
  29. defaultMessage='{count} per week'
  30. values={{ count: weeklyUses }}
  31. />
  32. </div>
  33. )}
  34. </div>
  35. );
  36. }
  37. }