2020-02-29 10:42:47 -05:00
import ImmutablePureComponent from 'react-immutable-pure-component'
import ImmutablePropTypes from 'react-immutable-proptypes'
import { injectIntl , defineMessages } from 'react-intl'
import { Link } from 'react-router-dom'
import classNames from 'classnames'
2020-03-04 17:26:01 -05:00
import { connectGroupStream } from '../actions/streaming'
import { expandGroupTimeline } from '../actions/timelines'
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-02-20 19:57:29 -05:00
const messages = defineMessages ( {
2020-02-29 10:42:47 -05:00
tabLatest : { id : 'group.timeline.tab_latest' , defaultMessage : 'Latest' } ,
show : { id : 'group.timeline.show_settings' , defaultMessage : 'Show settings' } ,
hide : { id : 'group.timeline.hide_settings' , defaultMessage : 'Hide settings' } ,
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.' } ,
} )
const mapStateToProps = ( state , props ) => ( {
group : state . getIn ( [ 'groups' , props . params . id ] ) ,
relationships : state . getIn ( [ 'group_relationships' , props . params . id ] ) ,
hasUnread : state . getIn ( [ 'timelines' , ` group: ${ props . params . id } ` , 'unread' ] ) > 0 ,
} )
2020-02-20 19:57:29 -05:00
2020-02-25 11:04:44 -05:00
export default
@ connect ( mapStateToProps )
2020-02-20 19:57:29 -05:00
@ injectIntl
2020-02-29 10:42:47 -05:00
class GroupTimeline extends ImmutablePureComponent {
static contextTypes = {
router : PropTypes . object ,
}
2020-02-20 19:57:29 -05:00
static propTypes = {
params : PropTypes . object . isRequired ,
dispatch : PropTypes . func . isRequired ,
2020-02-29 10:42:47 -05:00
columnId : PropTypes . string ,
hasUnread : PropTypes . bool ,
2020-04-23 02:13:29 -04:00
group : PropTypes . oneOfType ( [
ImmutablePropTypes . map ,
PropTypes . bool ,
] ) ,
2020-02-29 10:42:47 -05:00
relationships : ImmutablePropTypes . map ,
2020-02-20 19:57:29 -05:00
intl : PropTypes . object . isRequired ,
}
2020-02-29 10:42:47 -05:00
state = {
collapsed : true ,
2020-02-20 19:57:29 -05:00
}
2020-02-29 10:42:47 -05:00
componentDidMount ( ) {
const { dispatch } = this . props
const { id } = this . props . params
dispatch ( expandGroupTimeline ( id ) )
this . disconnect = dispatch ( connectGroupStream ( id ) )
2020-02-20 19:57:29 -05:00
}
2020-02-29 10:42:47 -05:00
componentWillUnmount ( ) {
if ( this . disconnect ) {
this . disconnect ( )
this . disconnect = null
}
}
2020-02-20 19:57:29 -05:00
2020-02-29 10:42:47 -05:00
handleLoadMore = maxId => {
const { id } = this . props . params
this . props . dispatch ( expandGroupTimeline ( id , { maxId } ) )
}
2020-02-20 19:57:29 -05:00
2020-02-29 10:42:47 -05:00
handleToggleClick = ( e ) => {
e . stopPropagation ( )
this . setState ( { collapsed : ! this . state . collapsed } )
2020-02-20 19:57:29 -05:00
}
2020-02-29 10:42:47 -05:00
render ( ) {
const { columnId , group , relationships , account , intl } = this . props
const { collapsed } = this . state
const { id } = this . props . params
if ( typeof group === 'undefined' || ! relationships ) {
return < ColumnIndicator type = 'loading' / >
} else if ( group === false ) {
return < ColumnIndicator type = 'missing' / >
}
2020-02-20 19:57:29 -05:00
return (
2020-04-28 01:33:58 -04:00
< StatusList
2020-02-29 10:42:47 -05:00
alwaysPrepend
scrollKey = { ` group_timeline- ${ columnId } ` }
timelineId = { ` group: ${ id } ` }
onLoadMore = { this . handleLoadMore }
group = { group }
emptyMessage = { intl . formatMessage ( messages . empty ) }
/ >
)
2020-02-20 19:57:29 -05:00
}
2020-02-29 10:42:47 -05:00
}