2022-04-11 12:58:48 -07:00
import { debounce } from 'lodash' ;
import React from 'react' ;
import { defineMessages , FormattedMessage , useIntl } from 'react-intl' ;
2022-05-30 11:23:55 -07:00
import { fetchBookmarkedStatuses , expandBookmarkedStatuses } from 'soapbox/actions/bookmarks' ;
import StatusList from 'soapbox/components/status_list' ;
2022-04-11 12:58:48 -07:00
import SubNavigation from 'soapbox/components/sub_navigation' ;
import { Column } from 'soapbox/components/ui' ;
2022-06-02 12:00:35 -07:00
import { useAppSelector , useAppDispatch } from 'soapbox/hooks' ;
2022-04-11 12:58:48 -07:00
const messages = defineMessages ( {
heading : { id : 'column.bookmarks' , defaultMessage : 'Bookmarks' } ,
} ) ;
const handleLoadMore = debounce ( ( dispatch ) = > {
dispatch ( expandBookmarkedStatuses ( ) ) ;
} , 300 , { leading : true } ) ;
const Bookmarks : React.FC = ( ) = > {
2022-06-02 12:00:35 -07:00
const dispatch = useAppDispatch ( ) ;
2022-04-11 12:58:48 -07:00
const intl = useIntl ( ) ;
const statusIds = useAppSelector ( ( state ) = > state . status_lists . getIn ( [ 'bookmarks' , 'items' ] ) ) ;
const isLoading = useAppSelector ( ( state ) = > state . status_lists . getIn ( [ 'bookmarks' , 'isLoading' ] , true ) ) ;
const hasMore = useAppSelector ( ( state ) = > ! ! state . status_lists . getIn ( [ 'bookmarks' , 'next' ] ) ) ;
React . useEffect ( ( ) = > {
dispatch ( fetchBookmarkedStatuses ( ) ) ;
} , [ ] ) ;
const handleRefresh = ( ) = > {
return dispatch ( fetchBookmarkedStatuses ( ) ) ;
} ;
const emptyMessage = < FormattedMessage id = 'empty_column.bookmarks' defaultMessage = "You don't have any bookmarks yet. When you add one, it will show up here." / > ;
return (
< Column transparent >
2022-05-04 20:58:34 -07:00
< div className = 'px-4 pt-4 sm:p-0' >
< SubNavigation message = { intl . formatMessage ( messages . heading ) } / >
< / div >
2022-04-11 12:58:48 -07:00
< StatusList
statusIds = { statusIds }
2022-06-02 12:00:35 -07:00
scrollKey = 'bookmarked_statuses'
2022-04-11 12:58:48 -07:00
hasMore = { hasMore }
isLoading = { isLoading }
onLoadMore = { ( ) = > handleLoadMore ( dispatch ) }
onRefresh = { handleRefresh }
emptyMessage = { emptyMessage }
divideType = 'space'
/ >
< / Column >
) ;
} ;
export default Bookmarks ;