2020-08-17 15:07:16 -05:00
import React from 'react'
2020-08-17 15:59:29 -05:00
import PropTypes from 'prop-types'
2020-08-17 15:39:25 -05:00
import { connect } from 'react-redux'
2020-03-04 17:50:15 -05:00
import ImmutablePureComponent from 'react-immutable-pure-component'
import ImmutablePropTypes from 'react-immutable-proptypes'
import { FormattedMessage } from 'react-intl'
import { fetchReposts } from '../actions/interactions'
import { fetchStatus } from '../actions/statuses'
import { makeGetStatus } from '../selectors'
2020-04-11 18:29:19 -04:00
import Account from '../components/account'
2020-03-04 17:50:15 -05:00
import ColumnIndicator from '../components/column_indicator'
import ScrollableList from '../components/scrollable_list'
2019-08-07 01:02:36 -04:00
2020-04-28 01:33:58 -04:00
class StatusReposts extends ImmutablePureComponent {
2019-08-07 01:02:36 -04:00
componentWillMount ( ) {
2020-08-20 15:11:39 -05:00
this . props . dispatch ( fetchReposts ( this . props . statusId ) )
this . props . dispatch ( fetchStatus ( this . props . statusId ) )
2019-08-07 01:02:36 -04:00
}
componentWillReceiveProps ( nextProps ) {
2020-08-20 15:11:39 -05:00
if ( nextProps . statusId !== this . props . statusId && nextProps . statusId ) {
this . props . dispatch ( fetchReposts ( nextProps . statusId ) )
this . props . dispatch ( fetchStatus ( nextProps . statusId ) )
2019-08-07 01:02:36 -04:00
}
}
render ( ) {
2020-03-04 17:50:15 -05:00
const { accountIds , status } = this . props
2019-08-07 01:02:36 -04:00
if ( ! accountIds ) {
2020-03-04 17:26:01 -05:00
return < ColumnIndicator type = 'loading' / >
2019-08-07 01:02:36 -04:00
} else if ( ! status ) {
2020-03-04 17:26:01 -05:00
return < ColumnIndicator type = 'missing' / >
2019-08-07 01:02:36 -04:00
}
return (
2020-02-24 18:25:55 -05:00
< ScrollableList
2020-03-04 17:26:01 -05:00
scrollKey = 'reposts'
2020-03-04 17:50:15 -05:00
emptyMessage = { < FormattedMessage id = 'status.reposts.empty' defaultMessage = 'No one has reposted this gab yet. When someone does, they will show up here.' / > }
2020-02-24 18:25:55 -05:00
>
2020-03-04 17:26:01 -05:00
{
accountIds . map ( id =>
2020-04-11 18:29:19 -04:00
< Account key = { id } id = { id } / >
2020-03-04 17:26:01 -05:00
)
}
2020-02-24 18:25:55 -05:00
< / S c r o l l a b l e L i s t >
2020-03-04 17:50:15 -05:00
)
2019-08-07 01:02:36 -04:00
}
}
2020-08-18 19:22:15 -05:00
const mapStateToProps = ( state , props ) => {
2020-08-20 15:11:39 -05:00
const statusId = props . params ? props . params . statusId : props . statusId
2020-08-18 19:22:15 -05:00
const getStatus = makeGetStatus ( )
const status = getStatus ( state , {
2020-08-20 15:11:39 -05:00
id : statusId ,
// username: props.params.username,
2020-08-18 19:22:15 -05:00
} )
return {
status ,
2020-08-20 15:11:39 -05:00
statusId ,
accountIds : state . getIn ( [ 'user_lists' , 'reblogged_by' , statusId ] ) ,
2020-08-18 19:22:15 -05:00
}
}
StatusReposts . propTypes = {
accountIds : ImmutablePropTypes . list ,
2020-08-20 15:11:39 -05:00
dispatch : PropTypes . func . isRequired ,
2020-08-18 19:22:15 -05:00
status : ImmutablePropTypes . map ,
2020-08-20 15:11:39 -05:00
statusId : PropTypes . string . isRequired ,
2020-08-18 19:22:15 -05:00
}
export default connect ( mapStateToProps ) ( StatusReposts )