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'
2020-11-25 15:22:37 -06:00
import debounce from 'lodash.debounce'
import { fetchReposts , expandReposts } from '../actions/interactions'
2020-03-04 17:50:15 -05:00
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'
2020-11-25 15:22:37 -06:00
import AccountPlaceholder from '../components/placeholder/account_placeholder'
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 ) )
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 ) )
2019-08-07 01:02:36 -04:00
}
}
2020-11-25 15:22:37 -06:00
handleLoadMore = debounce ( ( ) => {
this . props . dispatch ( expandReposts ( this . props . statusId ) )
} , 300 , { leading : true } )
2019-08-07 01:02:36 -04:00
render ( ) {
2020-11-25 15:22:37 -06:00
const {
accountIds ,
isLoading ,
hasMore ,
list ,
statusId ,
} = this . props
2019-08-07 01:02:36 -04:00
2020-11-25 15:22:37 -06:00
if ( ! statusId ) {
2020-03-04 17:26:01 -05:00
return < ColumnIndicator type = 'missing' / >
2019-08-07 01:02:36 -04:00
}
2020-11-25 15:22:37 -06:00
const accountIdCount = ! ! accountIds ? accountIds . count ( ) : 0
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-11-25 15:22:37 -06:00
onLoadMore = { this . handleLoadMore }
hasMore = { hasMore }
isLoading = { isLoading && accountIdCount === 0 }
showLoading = { isLoading && accountIdCount === 0 }
placeholderComponent = { AccountPlaceholder }
placeholderCount = { 3 }
2020-02-24 18:25:55 -05:00
>
2020-03-04 17:26:01 -05:00
{
2020-11-25 15:22:37 -06:00
accountIdCount > 0 && accountIds . map ( ( id ) => (
< Account
compact
key = { ` reposted-by- ${ 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
return {
2020-11-25 15:22:37 -06:00
accountIds : state . getIn ( [ 'user_lists' , 'reblogged_by' , statusId , 'items' ] ) ,
hasMore : ! ! state . getIn ( [ 'user_lists' , 'reblogged_by' , statusId , 'next' ] ) ,
isLoading : state . getIn ( [ 'user_lists' , 'reblogged_by' , statusId , 'isLoading' ] ) ,
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 ,
statusId : PropTypes . string . isRequired ,
2020-08-18 19:22:15 -05:00
}
2020-11-25 15:22:37 -06:00
export default connect ( mapStateToProps ) ( StatusReposts )