import React, { useEffect, useRef } from 'react'; import { defineMessages, useIntl, FormattedMessage } from 'react-intl'; import { useHistory } from 'react-router-dom'; import IconButton from 'soapbox/components/icon_button'; import Column from 'soapbox/features/ui/components/column'; import { useAppDispatch, useSettings } from 'soapbox/hooks'; import { connectRemoteStream } from '../../actions/streaming'; import { expandRemoteTimeline } from '../../actions/timelines'; import StatusListContainer from '../ui/containers/status_list_container'; import PinnedHostsPicker from './components/pinned_hosts_picker'; const messages = defineMessages({ title: { id: 'column.remote', defaultMessage: 'Federated timeline' }, }); interface IRemoteTimeline { params?: { instance?: string, } } /** View statuses from a remote instance. */ const RemoteTimeline: React.FC = ({ params }) => { const intl = useIntl(); const history = useHistory(); const dispatch = useAppDispatch(); const instance = params?.instance; const settings = useSettings(); const stream = useRef(null); const timelineId = 'remote'; const onlyMedia = !!settings.getIn(['remote', 'other', 'onlyMedia']); const pinned: boolean = (settings.getIn(['remote_timeline', 'pinnedHosts']) as any).includes(instance); const disconnect = () => { if (stream.current) { stream.current(); } }; useEffect(() => { disconnect(); dispatch(expandRemoteTimeline(instance, { onlyMedia, maxId: undefined })); stream.current = dispatch(connectRemoteStream(instance, { onlyMedia })); return () => { disconnect(); stream.current = null; }; }, [onlyMedia]); const handleCloseClick: React.MouseEventHandler = () => { history.push('/timeline/fediverse'); }; const handleLoadMore = (maxId: string) => { dispatch(expandRemoteTimeline(instance, { maxId, onlyMedia })); }; return ( {instance && } {!pinned &&
} } divideType='space' />
); }; export default RemoteTimeline;