import React, { useEffect } from 'react'; import { defineMessages, FormattedMessage, useIntl } from 'react-intl'; import { directComposeById } from 'soapbox/actions/compose'; import { connectDirectStream } from 'soapbox/actions/streaming'; import { expandDirectTimeline } from 'soapbox/actions/timelines'; import AccountSearch from 'soapbox/components/account_search'; import ColumnHeader from 'soapbox/components/column_header'; import { Column } from 'soapbox/components/ui'; import { useAppDispatch, useAppSelector } from 'soapbox/hooks'; import Timeline from '../ui/components/timeline'; const messages = defineMessages({ title: { id: 'column.direct', defaultMessage: 'Direct messages' }, searchPlaceholder: { id: 'direct.search_placeholder', defaultMessage: 'Send a message to…' }, }); const DirectTimeline = () => { const intl = useIntl(); const dispatch = useAppDispatch(); const hasUnread = useAppSelector((state) => state.timelines.getIn(['direct', 'unread']) > 0); useEffect(() => { dispatch(expandDirectTimeline()); const disconnect = dispatch(connectDirectStream()); return (() => { disconnect(); }); }, []); const handleSuggestion = (accountId: string) => { dispatch(directComposeById(accountId)); }; const handleLoadMore = (maxId: string) => { dispatch(expandDirectTimeline({ maxId })); }; return ( } divideType='space' /> ); }; export default DirectTimeline;