import React, { useEffect } from 'react'; import { defineMessages, FormattedMessage, useIntl } from 'react-intl'; import { connectCommunityStream } from 'soapbox/actions/streaming'; import { expandCommunityTimeline } from 'soapbox/actions/timelines'; import PullToRefresh from 'soapbox/components/pull-to-refresh'; import { Column } from 'soapbox/components/ui'; import { useAppSelector, 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 next = useAppSelector(state => state.timelines.get('community')?.next); const timelineId = 'community'; const handleLoadMore = (maxId: string) => { dispatch(expandCommunityTimeline({ url: next, 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 ( } divideType='space' /> ); }; export default CommunityTimeline;