2022-06-16 12:32:17 -07:00
import debounce from 'lodash/debounce' ;
2022-05-30 11:23:55 -07:00
import React , { useRef } from 'react' ;
2022-05-30 09:18:31 -07:00
import { FormattedMessage } from 'react-intl' ;
import { expandConversations } from 'soapbox/actions/conversations' ;
2022-11-15 08:00:49 -08:00
import ScrollableList from 'soapbox/components/scrollable-list' ;
2022-05-30 09:18:31 -07:00
import { useAppDispatch , useAppSelector } from 'soapbox/hooks' ;
import Conversation from '../components/conversation' ;
import type { VirtuosoHandle } from 'react-virtuoso' ;
const ConversationsList : React.FC = ( ) = > {
const dispatch = useAppDispatch ( ) ;
const ref = useRef < VirtuosoHandle > ( null ) ;
2022-06-21 15:29:17 -07:00
const conversations = useAppSelector ( ( state ) = > state . conversations . items ) ;
const isLoading = useAppSelector ( ( state ) = > state . conversations . isLoading ) ;
2022-05-30 09:18:31 -07:00
2022-06-21 15:29:17 -07:00
const getCurrentIndex = ( id : string ) = > conversations . findIndex ( x = > x . id === id ) ;
2022-05-30 09:18:31 -07:00
const handleMoveUp = ( id : string ) = > {
const elementIndex = getCurrentIndex ( id ) - 1 ;
selectChild ( elementIndex ) ;
} ;
const handleMoveDown = ( id : string ) = > {
const elementIndex = getCurrentIndex ( id ) + 1 ;
selectChild ( elementIndex ) ;
} ;
const selectChild = ( index : number ) = > {
ref . current ? . scrollIntoView ( {
index ,
behavior : 'smooth' ,
done : ( ) = > {
const element = document . querySelector < HTMLDivElement > ( ` #direct-list [data-index=" ${ index } "] .focusable ` ) ;
if ( element ) {
element . focus ( ) ;
}
} ,
} ) ;
} ;
const handleLoadOlder = debounce ( ( ) = > {
const maxId = conversations . getIn ( [ - 1 , 'id' ] ) ;
if ( maxId ) dispatch ( expandConversations ( { maxId } ) ) ;
} , 300 , { leading : true } ) ;
return (
< ScrollableList
onLoadMore = { handleLoadOlder }
id = 'direct-list'
scrollKey = 'direct'
ref = { ref }
isLoading = { isLoading }
showLoading = { isLoading && conversations . size === 0 }
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." / > }
>
{ conversations . map ( ( item : any ) = > (
< Conversation
2022-06-21 15:29:17 -07:00
key = { item . id }
conversationId = { item . id }
2022-05-30 09:18:31 -07:00
onMoveUp = { handleMoveUp }
onMoveDown = { handleMoveDown }
/ >
) ) }
< / ScrollableList >
) ;
} ;
export default ConversationsList ;