2022-06-09 11:56:14 -07:00
import React , { useEffect } from 'react' ;
import { defineMessages , FormattedMessage , useIntl } from 'react-intl' ;
import { connectCommunityStream } from 'soapbox/actions/streaming' ;
import { expandCommunityTimeline } from 'soapbox/actions/timelines' ;
2022-07-13 18:13:37 -07:00
import PullToRefresh from 'soapbox/components/pull-to-refresh' ;
2022-06-09 11:56:14 -07:00
import SubNavigation from 'soapbox/components/sub_navigation' ;
import { Column } from 'soapbox/components/ui' ;
import { useAppDispatch , useSettings } from 'soapbox/hooks' ;
import Timeline from '../ui/components/timeline' ;
const messages = defineMessages ( {
title : { id : 'column.community' , defaultMessage : 'Local timeline' } ,
} ) ;
const CommunityTimeline = ( ) = > {
const intl = useIntl ( ) ;
const dispatch = useAppDispatch ( ) ;
const settings = useSettings ( ) ;
const onlyMedia = settings . getIn ( [ 'community' , 'other' , 'onlyMedia' ] ) ;
const timelineId = 'community' ;
const handleLoadMore = ( maxId : string ) = > {
dispatch ( expandCommunityTimeline ( { maxId , onlyMedia } ) ) ;
} ;
const handleRefresh = ( ) = > {
return dispatch ( expandCommunityTimeline ( { onlyMedia } as any ) ) ;
} ;
useEffect ( ( ) = > {
dispatch ( expandCommunityTimeline ( { onlyMedia } as any ) ) ;
const disconnect = dispatch ( connectCommunityStream ( { onlyMedia } as any ) ) ;
return ( ) = > {
disconnect ( ) ;
} ;
} , [ onlyMedia ] ) ;
return (
2022-07-15 15:03:21 -07:00
< Column label = { intl . formatMessage ( messages . title ) } transparent withHeader = { false } >
2022-11-03 17:56:03 -07:00
< div className = 'px-4 sm:p-0' >
< SubNavigation message = { intl . formatMessage ( messages . title ) } / >
< / div >
2022-07-13 18:13:37 -07:00
< PullToRefresh onRefresh = { handleRefresh } >
< Timeline
scrollKey = { ` ${ timelineId } _timeline ` }
timelineId = { ` ${ timelineId } ${ onlyMedia ? ':media' : '' } ` }
onLoadMore = { handleLoadMore }
emptyMessage = { < FormattedMessage id = 'empty_column.community' defaultMessage = 'The local timeline is empty. Write something publicly to get the ball rolling!' / > }
divideType = 'space'
/ >
< / PullToRefresh >
2022-06-09 11:56:14 -07:00
< / Column >
) ;
} ;
export default CommunityTimeline ;