2022-05-30 09:18:31 -07:00
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' ;
2022-11-15 06:10:14 -08:00
import AccountSearch from 'soapbox/components/account-search' ;
2022-05-30 09:18:31 -07:00
import { Column } from 'soapbox/components/ui' ;
2023-06-15 11:57:58 -07:00
import { useAppSelector , useAppDispatch } from 'soapbox/hooks' ;
2022-05-30 09:18:31 -07:00
2022-06-03 10:31:23 -07:00
import Timeline from '../ui/components/timeline' ;
2022-05-30 09:18:31 -07:00
const messages = defineMessages ( {
2022-11-26 10:42:55 -08:00
heading : { id : 'column.direct' , defaultMessage : 'Direct messages' } ,
2022-05-30 09:18:31 -07:00
searchPlaceholder : { id : 'direct.search_placeholder' , defaultMessage : 'Send a message to…' } ,
} ) ;
const DirectTimeline = ( ) = > {
const intl = useIntl ( ) ;
const dispatch = useAppDispatch ( ) ;
2023-06-15 11:57:58 -07:00
const next = useAppSelector ( state = > state . timelines . get ( 'direct' ) ? . next ) ;
2022-05-30 09:18:31 -07:00
useEffect ( ( ) = > {
dispatch ( expandDirectTimeline ( ) ) ;
const disconnect = dispatch ( connectDirectStream ( ) ) ;
return ( ( ) = > {
disconnect ( ) ;
} ) ;
} , [ ] ) ;
const handleSuggestion = ( accountId : string ) = > {
dispatch ( directComposeById ( accountId ) ) ;
} ;
const handleLoadMore = ( maxId : string ) = > {
2023-06-15 11:57:58 -07:00
dispatch ( expandDirectTimeline ( { url : next , maxId } ) ) ;
2022-05-30 09:18:31 -07:00
} ;
return (
2022-11-26 10:42:55 -08:00
< Column label = { intl . formatMessage ( messages . heading ) } >
2022-05-30 09:18:31 -07:00
< AccountSearch
placeholder = { intl . formatMessage ( messages . searchPlaceholder ) }
onSelected = { handleSuggestion }
/ >
2022-06-03 10:31:23 -07:00
< Timeline
2022-05-30 09:18:31 -07:00
scrollKey = 'direct_timeline'
timelineId = 'direct'
onLoadMore = { handleLoadMore }
emptyMessage = { < FormattedMessage id = 'empty_column.direct' defaultMessage = "You don't have any direct messages yet. When you send or receive one, it will show up here." / > }
2022-11-26 10:42:55 -08:00
divideType = 'border'
2022-05-30 09:18:31 -07:00
/ >
< / Column >
) ;
} ;
export default DirectTimeline ;