2022-01-10 14:17:52 -08:00
import { debounce } from 'lodash' ;
2020-07-29 14:08:36 -07:00
import PropTypes from 'prop-types' ;
2022-01-10 14:17:52 -08:00
import React from 'react' ;
2020-07-29 14:08:36 -07:00
import ImmutablePropTypes from 'react-immutable-proptypes' ;
import ImmutablePureComponent from 'react-immutable-pure-component' ;
2022-01-10 14:17:52 -08:00
import { defineMessages , injectIntl , FormattedMessage } from 'react-intl' ;
import { connect } from 'react-redux' ;
2022-01-10 14:01:24 -08:00
import Column from 'soapbox/components/column' ;
import SubNavigation from 'soapbox/components/sub_navigation' ;
2020-07-29 22:38:40 -07:00
import { fetchBookmarkedStatuses , expandBookmarkedStatuses } from '../../actions/bookmarks' ;
2022-01-10 14:17:52 -08:00
import StatusList from '../../components/status_list' ;
2020-07-29 14:08:36 -07:00
const messages = defineMessages ( {
heading : { id : 'column.bookmarks' , defaultMessage : 'Bookmarks' } ,
} ) ;
const mapStateToProps = state => ( {
statusIds : state . getIn ( [ 'status_lists' , 'bookmarks' , 'items' ] ) ,
isLoading : state . getIn ( [ 'status_lists' , 'bookmarks' , 'isLoading' ] , true ) ,
hasMore : ! ! state . getIn ( [ 'status_lists' , 'bookmarks' , 'next' ] ) ,
} ) ;
export default @ connect ( mapStateToProps )
@ injectIntl
class Bookmarks extends ImmutablePureComponent {
static contextTypes = {
router : PropTypes . object ,
} ;
static propTypes = {
dispatch : PropTypes . func . isRequired ,
shouldUpdateScroll : PropTypes . func ,
2021-07-08 14:12:04 -07:00
statusIds : ImmutablePropTypes . orderedSet . isRequired ,
2020-07-29 14:08:36 -07:00
intl : PropTypes . object . isRequired ,
columnId : PropTypes . string ,
multiColumn : PropTypes . bool ,
hasMore : PropTypes . bool ,
isLoading : PropTypes . bool ,
} ;
2021-11-04 12:07:20 -07:00
fetchData = ( ) => {
2020-07-29 14:08:36 -07:00
const { dispatch } = this . props ;
2021-11-04 12:07:20 -07:00
return dispatch ( fetchBookmarkedStatuses ( ) ) ;
}
componentDidMount ( ) {
this . fetchData ( ) ;
2020-07-29 14:08:36 -07:00
}
2020-07-29 22:38:40 -07:00
handleLoadMore = debounce ( ( ) => {
this . props . dispatch ( expandBookmarkedStatuses ( ) ) ;
} , 300 , { leading : true } )
2020-07-29 14:08:36 -07:00
2021-11-04 12:07:20 -07:00
handleRefresh = ( ) => {
return this . fetchData ( ) ;
}
2020-07-29 14:08:36 -07:00
render ( ) {
const { intl , shouldUpdateScroll , statusIds , columnId , multiColumn , hasMore , isLoading } = this . props ;
const pinned = ! ! columnId ;
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 (
2021-11-04 12:07:20 -07:00
< Column transparent >
< SubNavigation message = { intl . formatMessage ( messages . heading ) } / >
2020-07-29 14:08:36 -07:00
< StatusList
trackScroll = { ! pinned }
statusIds = { statusIds }
scrollKey = { ` bookmarked_statuses- ${ columnId } ` }
hasMore = { hasMore }
isLoading = { isLoading }
onLoadMore = { this . handleLoadMore }
2021-11-04 12:07:20 -07:00
onRefresh = { this . handleRefresh }
2020-07-29 14:08:36 -07:00
shouldUpdateScroll = { shouldUpdateScroll }
emptyMessage = { emptyMessage }
bindToDocument = { ! multiColumn }
/ >
< / C o l u m n >
) ;
}
}