import React, { useEffect, useRef } from 'react'; import { defineMessages, useIntl, FormattedMessage } from 'react-intl'; import { Link } from 'react-router-dom'; import { expandHomeTimeline } from 'soapbox/actions/timelines'; import PullToRefresh from 'soapbox/components/pull-to-refresh'; import { Column, Stack, Text } from 'soapbox/components/ui'; import Timeline from 'soapbox/features/ui/components/timeline'; import { useAppSelector, useAppDispatch, useFeatures } from 'soapbox/hooks'; const messages = defineMessages({ title: { id: 'column.home', defaultMessage: 'Home' }, }); const HomeTimeline: React.FC = () => { const intl = useIntl(); const dispatch = useAppDispatch(); const features = useFeatures(); const polling = useRef(null); const isPartial = useAppSelector(state => state.timelines.get('home')?.isPartial === true); const currentAccountId = useAppSelector(state => state.timelines.get('home')?.feedAccountId); const siteTitle = useAppSelector(state => state.instance.title); const handleLoadMore = (maxId: string) => { dispatch(expandHomeTimeline({ maxId, accountId: currentAccountId })); }; // Mastodon generates the feed in Redis, and can return a partial timeline // (HTTP 206) for new users. Poll until we get a full page of results. const checkIfReloadNeeded = () => { if (isPartial) { polling.current = setInterval(() => { dispatch(expandHomeTimeline()); }, 3000); } else { stopPolling(); } }; const stopPolling = () => { if (polling.current) { clearInterval(polling.current); polling.current = null; } }; const handleRefresh = () => { return dispatch(expandHomeTimeline({ maxId: null, accountId: currentAccountId })); }; useEffect(() => { checkIfReloadNeeded(); return () => { stopPolling(); }; }, [isPartial]); return ( {features.federating && ( ), }} /> )} } /> ); }; export default HomeTimeline;