lbry-desktop/ui/component/common/paginate.jsx

97 lines
3.1 KiB
React
Raw Permalink Normal View History

2019-05-06 22:35:04 -04:00
// @flow
import React from 'react';
import { withRouter } from 'react-router';
import { Form, FormField } from 'component/common/form';
import ReactPaginate from 'react-paginate';
2020-08-10 16:47:39 -04:00
import { useIsMobile } from 'effects/use-screensize';
2019-05-06 22:35:04 -04:00
const PAGINATE_PARAM = 'page';
type Props = {
totalPages: number,
location: { search: string },
history: { push: (string) => void },
onPageChange?: (number) => void,
disableHistory?: boolean, // Disables the use of '&page=' param and history stack.
2019-05-06 22:35:04 -04:00
};
function Paginate(props: Props) {
const { totalPages = 1, location, history, onPageChange, disableHistory } = props;
2019-05-06 22:35:04 -04:00
const { search } = location;
2019-09-26 11:38:48 -04:00
const [textValue, setTextValue] = React.useState('');
2019-05-06 22:35:04 -04:00
const urlParams = new URLSearchParams(search);
const urlParamPage = Number(urlParams.get(PAGINATE_PARAM));
const initialPage = disableHistory ? 1 : urlParamPage || 1;
const [currentPage, setCurrentPage] = React.useState(initialPage);
2020-01-08 14:20:30 -05:00
const isMobile = useIsMobile();
2019-05-06 22:35:04 -04:00
function handleChangePage(newPageNumber: number) {
if (onPageChange) {
onPageChange(newPageNumber);
}
if (currentPage !== newPageNumber) {
setCurrentPage(newPageNumber);
if (!disableHistory) {
const params = new URLSearchParams(search);
params.set(PAGINATE_PARAM, newPageNumber.toString());
history.push('?' + params.toString());
}
2019-05-06 22:35:04 -04:00
}
}
2019-09-26 11:38:48 -04:00
function handlePaginateKeyUp() {
const newPage = Number(textValue);
if (newPage && newPage > 0 && newPage <= totalPages) {
2019-05-06 22:35:04 -04:00
handleChangePage(newPage);
}
}
React.useEffect(() => {
if (urlParamPage) {
setCurrentPage(urlParamPage);
}
}, [urlParamPage, setCurrentPage]);
2019-05-06 22:35:04 -04:00
return (
// Hide the paginate controls if we are loading or there is only one page
// It should still be rendered to trigger the onPageChange callback
2020-05-21 11:38:28 -04:00
<Form style={totalPages <= 1 ? { display: 'none' } : null} onSubmit={handlePaginateKeyUp}>
2019-05-06 22:35:04 -04:00
<fieldset-group class="fieldset-group--smushed fieldgroup--paginate">
<fieldset-section>
<ReactPaginate
pageCount={totalPages}
pageRangeDisplayed={2}
previousLabel=""
nextLabel=""
activeClassName="pagination__item--selected"
pageClassName="pagination__item"
previousClassName="pagination__item pagination__item--previous"
nextClassName="pagination__item pagination__item--next"
breakClassName="pagination__item pagination__item--break"
marginPagesDisplayed={2}
onPageChange={(e) => handleChangePage(e.selected + 1)}
2019-05-06 22:35:04 -04:00
forcePage={currentPage - 1}
initialPage={currentPage - 1}
containerClassName="pagination"
/>
</fieldset-section>
2020-01-08 14:20:30 -05:00
{!isMobile && (
<FormField
value={textValue}
onChange={(e) => setTextValue(e.target.value)}
className="paginate-goto"
aria-label={__('Go to page:')}
placeholder={__('Go to')}
2020-01-08 14:20:30 -05:00
type="text"
name="paginate-file"
/>
)}
2019-05-06 22:35:04 -04:00
</fieldset-group>
</Form>
);
}
export default withRouter(Paginate);