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-02-29 10:42:47 -05:00
import ImmutablePureComponent from 'react-immutable-pure-component'
import ImmutablePropTypes from 'react-immutable-proptypes'
2020-09-10 15:07:01 -05:00
import { List as ImmutableList } from 'immutable'
2020-02-29 10:42:47 -05:00
import { injectIntl , defineMessages } from 'react-intl'
2020-07-21 23:16:39 -05:00
import { me } from '../initial_state'
2020-08-07 17:59:39 -05:00
import getSortBy from '../utils/group_sort_by'
2020-03-04 17:26:01 -05:00
import { connectGroupStream } from '../actions/streaming'
2020-08-07 17:59:39 -05:00
import {
clearTimeline ,
expandGroupTimeline ,
2020-09-10 15:07:01 -05:00
expandGroupFeaturedTimeline ,
2020-08-07 17:59:39 -05:00
} from '../actions/timelines'
import {
setGroupTimelineSort ,
} from '../actions/groups'
import {
GROUP _TIMELINE _SORTING _TYPE _NEWEST ,
} from '../constants'
2020-04-11 18:29:19 -04:00
import StatusList from '../components/status_list'
2020-03-04 17:26:01 -05:00
import ColumnIndicator from '../components/column_indicator'
2020-08-06 23:19:18 -05:00
import GroupSortBlock from '../components/group_sort_block'
2020-02-20 19:57:29 -05:00
2020-02-29 10:42:47 -05:00
class GroupTimeline extends ImmutablePureComponent {
2020-08-07 17:59:39 -05:00
state = {
//keep track of loads for if no user,
//only allow 2 loads before showing sign up msg
loadCount : 0 ,
}
2020-02-29 10:42:47 -05:00
componentDidMount ( ) {
2020-08-06 23:19:18 -05:00
const {
2020-08-07 17:59:39 -05:00
groupId ,
2020-08-06 23:19:18 -05:00
sortByValue ,
sortByTopValue ,
2020-08-07 17:59:39 -05:00
onlyMedia ,
2020-08-06 23:19:18 -05:00
} = this . props
2020-08-07 17:59:39 -05:00
if ( sortByValue !== GROUP _TIMELINE _SORTING _TYPE _NEWEST ) {
this . props . setMemberNewest ( )
} else {
const sortBy = getSortBy ( sortByValue , sortByTopValue , onlyMedia )
2020-09-10 15:07:01 -05:00
this . props . onExpandGroupFeaturedTimeline ( groupId )
2020-08-07 17:59:39 -05:00
this . props . onExpandGroupTimeline ( groupId , { sortBy , onlyMedia } )
2020-02-29 10:42:47 -05:00
2020-08-07 17:59:39 -05:00
if ( ! ! me ) {
this . disconnect = this . props . onConnectGroupStream ( groupId )
}
2020-07-21 23:16:39 -05:00
}
2020-02-20 19:57:29 -05:00
}
2020-08-06 23:19:18 -05:00
componentDidUpdate ( prevProps ) {
2020-08-07 17:59:39 -05:00
if ( ( prevProps . sortByValue !== this . props . sortByValue ||
prevProps . sortByTopValue !== this . props . sortByTopValue ||
prevProps . onlyMedia !== this . props . onlyMedia ) &&
prevProps . groupId === this . props . groupId ) {
2020-08-06 23:19:18 -05:00
this . handleLoadMore ( )
2020-08-07 17:59:39 -05:00
this . props . onClearTimeline ( ` group: ${ this . props . groupId } ` )
2020-08-06 23:19:18 -05:00
}
2020-09-10 15:07:01 -05:00
if ( prevProps . groupId !== this . props . groupId ) {
this . props . onExpandGroupFeaturedTimeline ( this . props . groupId )
}
2020-08-06 23:19:18 -05:00
}
2020-02-29 10:42:47 -05:00
componentWillUnmount ( ) {
2020-07-21 23:16:39 -05:00
if ( this . disconnect && ! ! me ) {
2020-02-29 10:42:47 -05:00
this . disconnect ( )
this . disconnect = null
}
}
2020-02-20 19:57:29 -05:00
2020-08-06 23:19:18 -05:00
handleLoadMore = ( maxId ) => {
const {
2020-08-07 17:59:39 -05:00
groupId ,
2020-08-06 23:19:18 -05:00
sortByValue ,
sortByTopValue ,
2020-08-07 17:59:39 -05:00
onlyMedia ,
2020-08-06 23:19:18 -05:00
} = this . props
2020-09-14 17:19:24 -05:00
const { loadCount } = this . state
2020-08-06 23:19:18 -05:00
2020-09-14 17:19:24 -05:00
if ( ! ! maxId && ! me ) {
this . setState ( { loadCount : this . state . loadCount + 1 } )
if ( loadCount >= 2 ) return false
} else if ( ! maxId && loadCount !== 0 ) {
this . setState ( { loadCount : 0 } )
}
2020-08-07 17:59:39 -05:00
const sortBy = getSortBy ( sortByValue , sortByTopValue )
this . props . onExpandGroupTimeline ( groupId , { sortBy , maxId , onlyMedia } )
2020-02-29 10:42:47 -05:00
}
2020-02-20 19:57:29 -05:00
2020-02-29 10:42:47 -05:00
render ( ) {
2020-08-07 17:59:39 -05:00
const {
group ,
groupId ,
intl ,
2020-09-10 15:07:01 -05:00
groupPinnedStatusIds ,
2020-08-07 17:59:39 -05:00
} = this . props
2020-09-14 17:19:24 -05:00
const { loadCount } = this . state
2020-02-29 10:42:47 -05:00
2020-07-21 23:05:54 -05:00
if ( typeof group === 'undefined' ) {
2020-02-29 10:42:47 -05:00
return < ColumnIndicator type = 'loading' / >
} else if ( group === false ) {
return < ColumnIndicator type = 'missing' / >
}
2020-02-20 19:57:29 -05:00
2020-09-14 17:19:24 -05:00
const canLoadMore = loadCount < 2 && ! me || ! ! me
2020-02-20 19:57:29 -05:00
return (
2020-08-17 15:07:16 -05:00
< React . Fragment >
2020-08-07 17:59:39 -05:00
< GroupSortBlock / >
2020-08-06 23:19:18 -05:00
< StatusList
2020-08-07 17:59:39 -05:00
scrollKey = { ` group-timeline- ${ groupId } ` }
timelineId = { ` group: ${ groupId } ` }
2020-09-10 15:07:01 -05:00
groupPinnedStatusIds = { groupPinnedStatusIds }
2020-09-14 17:19:24 -05:00
onLoadMore = { canLoadMore ? this . handleLoadMore : undefined }
2020-08-06 23:19:18 -05:00
emptyMessage = { intl . formatMessage ( messages . empty ) }
/ >
2020-08-17 15:07:16 -05:00
< / R e a c t . F r a g m e n t >
2020-02-29 10:42:47 -05:00
)
2020-02-20 19:57:29 -05:00
}
2020-02-29 10:42:47 -05:00
}
2020-08-18 19:22:15 -05:00
const messages = defineMessages ( {
empty : { id : 'empty_column.group' , defaultMessage : 'There is nothing in this group yet.\nWhen members of this group post new statuses, they will appear here.' } ,
} )
2020-09-10 15:07:01 -05:00
const emptyList = ImmutableList ( )
2020-08-18 19:22:15 -05:00
const mapStateToProps = ( state , props ) => ( {
groupId : props . params . id ,
group : state . getIn ( [ 'groups' , props . params . id ] ) ,
2020-09-10 15:07:01 -05:00
groupPinnedStatusIds : state . getIn ( [ 'timelines' , ` group: ${ props . params . id } :pinned ` , 'items' ] , emptyList ) ,
2020-08-18 19:22:15 -05:00
sortByValue : state . getIn ( [ 'group_lists' , 'sortByValue' ] ) ,
sortByTopValue : state . getIn ( [ 'group_lists' , 'sortByTopValue' ] ) ,
} )
const mapDispatchToProps = ( dispatch ) => ( {
onConnectGroupStream ( groupId ) {
dispatch ( connectGroupStream ( groupId ) )
} ,
onClearTimeline ( timelineId ) {
dispatch ( clearTimeline ( timelineId ) )
} ,
onExpandGroupTimeline ( groupId , options ) {
dispatch ( expandGroupTimeline ( groupId , options ) )
} ,
setMemberNewest ( ) {
dispatch ( setGroupTimelineSort ( GROUP _TIMELINE _SORTING _TYPE _NEWEST ) )
} ,
2020-09-10 15:07:01 -05:00
onExpandGroupFeaturedTimeline ( groupId ) {
dispatch ( expandGroupFeaturedTimeline ( groupId ) )
} ,
2020-08-18 19:22:15 -05:00
} )
GroupTimeline . propTypes = {
params : PropTypes . object . isRequired ,
group : PropTypes . oneOfType ( [
ImmutablePropTypes . map ,
PropTypes . bool ,
] ) ,
groupId : PropTypes . string ,
intl : PropTypes . object . isRequired ,
onConnectGroupStream : PropTypes . func . isRequired ,
onClearTimeline : PropTypes . func . isRequired ,
onExpandGroupTimeline : PropTypes . func . isRequired ,
2020-09-10 15:07:01 -05:00
onExpandGroupFeaturedTimeline : PropTypes . func . isRequired ,
2020-08-18 19:22:15 -05:00
setMemberNewest : PropTypes . func . isRequired ,
sortByValue : PropTypes . string . isRequired ,
sortByTopValue : PropTypes . string ,
onlyMedia : PropTypes . bool ,
}
export default injectIntl ( connect ( mapStateToProps , mapDispatchToProps ) ( GroupTimeline ) )