statuses.js 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. import React from 'react';
  2. import PropTypes from 'prop-types';
  3. import ImmutablePropTypes from 'react-immutable-proptypes';
  4. import { connect } from 'react-redux';
  5. import StatusCheckBox from 'mastodon/features/report/containers/status_check_box_container';
  6. import { OrderedSet } from 'immutable';
  7. import { FormattedMessage } from 'react-intl';
  8. import Button from 'mastodon/components/button';
  9. import LoadingIndicator from 'mastodon/components/loading_indicator';
  10. const mapStateToProps = (state, { accountId }) => ({
  11. availableStatusIds: OrderedSet(state.getIn(['timelines', `account:${accountId}:with_replies`, 'items'])),
  12. isLoading: state.getIn(['timelines', `account:${accountId}:with_replies`, 'isLoading']),
  13. });
  14. export default @connect(mapStateToProps)
  15. class Statuses extends React.PureComponent {
  16. static propTypes = {
  17. onNextStep: PropTypes.func.isRequired,
  18. accountId: PropTypes.string.isRequired,
  19. availableStatusIds: ImmutablePropTypes.set.isRequired,
  20. selectedStatusIds: ImmutablePropTypes.set.isRequired,
  21. isLoading: PropTypes.bool,
  22. onToggle: PropTypes.func.isRequired,
  23. };
  24. handleNextClick = () => {
  25. const { onNextStep } = this.props;
  26. onNextStep('comment');
  27. };
  28. render () {
  29. const { availableStatusIds, selectedStatusIds, onToggle, isLoading } = this.props;
  30. return (
  31. <React.Fragment>
  32. <h3 className='report-dialog-modal__title'><FormattedMessage id='report.statuses.title' defaultMessage='Are there any posts that back up this report?' /></h3>
  33. <p className='report-dialog-modal__lead'><FormattedMessage id='report.statuses.subtitle' defaultMessage='Select all that apply' /></p>
  34. <div className='report-dialog-modal__statuses'>
  35. {isLoading ? <LoadingIndicator /> : availableStatusIds.union(selectedStatusIds).map(statusId => (
  36. <StatusCheckBox
  37. id={statusId}
  38. key={statusId}
  39. checked={selectedStatusIds.includes(statusId)}
  40. onToggle={onToggle}
  41. />
  42. ))}
  43. </div>
  44. <div className='flex-spacer' />
  45. <div className='report-dialog-modal__actions'>
  46. <Button onClick={this.handleNextClick}><FormattedMessage id='report.next' defaultMessage='Next' /></Button>
  47. </div>
  48. </React.Fragment>
  49. );
  50. }
  51. }