Socket
Socket
Sign inDemoInstall

react-paginate

Package Overview
Dependencies
1
Maintainers
1
Versions
106
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

    react-paginate

A ReactJS component that creates a pagination.


Version published
Weekly downloads
435K
increased by0.01%
Maintainers
1
Install size
472 kB
Created
Weekly downloads
 

Changelog

Source

= 7.1.5

  • Fix the Webpack build to work for both browser and Node (see: https://github.com/AdeleD/react-paginate/issues/389)
  • Add a warning when providing both initialPage and forcePage props. You should only provides forcePage when the component is controlled. (see: https://github.com/AdeleD/react-paginate/pull/290)

Readme

Source

react-paginate

NPM Build Status

A ReactJS component to render a pagination.

By installing this component and writing only a little bit of CSS you can obtain this: Note: You should write your own css to obtain this UI. This package do not provide any css.

Pagination demo 2

or

Pagination demo 1

Installation

Install react-paginate with npm:

npm install react-paginate --save

Usage

import React, { useEffect, useState } from 'react';
import ReactDOM from 'react-dom';
import ReactPaginate from 'react-paginate';

// Example items, to simulate fetching from another resources.
const items = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14];

function Items({ currentItems }) {
  return (
    <>
      {currentItems &&
        currentItems.map((item) => (
          <div>
            <h3>Item #{item}</h3>
          </div>
        ))}
    </>
  );
}

function PaginatedItems({ itemsPerPage }) {
  // We start with an empty list of items.
  const [currentItems, setCurrentItems] = useState(null);
  const [pageCount, setPageCount] = useState(0);
  // Here we use item offsets; we could also use page offsets
  // following the API or data you're working with.
  const [itemOffset, setItemOffset] = useState(0);

  useEffect(() => {
    // Fetch items from another resources.
    const endOffset = itemOffset + itemsPerPage;
    console.log(`Loading items from ${itemOffset} to ${endOffset}`);
    setCurrentItems(items.slice(itemOffset, endOffset));
    setPageCount(Math.ceil(items.length / itemsPerPage));
  }, [itemOffset, itemsPerPage]);

  // Invoke when user click to request another page.
  const handlePageClick = (event) => {
    const newOffset = (event.selected * itemsPerPage) % items.length;
    console.log(
      `User requested page number ${event.selected}, which is offset ${newOffset}`
    );
    setItemOffset(newOffset);
  };

  return (
    <>
      <Items currentItems={currentItems} />
      <ReactPaginate
        breakLabel="..."
        nextLabel="next >"
        onPageChange={handlePageClick}
        pageRangeDisplayed={5}
        pageCount={pageCount}
        previousLabel="< previous"
        renderOnZeroPageCount={null}
      />
    </>
  );
}

// Add a <div id="container"> to your HTML to see the componend rendered.
ReactDOM.render(
  <PaginatedItems itemsPerPage={4} />,
  document.getElementById('container')
);

Test it on CodePen.

You can also read the code of demo/js/demo.js to quickly understand how to make react-paginate work with a list of objects.

You can also check this CodePen demo with fetching sample code (using GitHub API) and synchronized pagination widgets.

Props

NameTypeDescription
pageCountNumberRequired. The total number of pages.
pageRangeDisplayedNumberRequired. The range of pages displayed.
marginPagesDisplayedNumberRequired. The number of pages to display for margins.
previousLabelNodeLabel for the previous button.
nextLabelNodeLabel for the next button.
breakLabelNodeLabel for ellipsis.
breakClassNameStringThe classname on tag li of the ellipsis element.
breakLinkClassNameStringThe classname on tag a of the ellipsis element.
onPageChangeFunctionThe method to call when a page is clicked. Exposes the current page object as an argument.
onPageActiveFunctionThe method to call when an active page is clicked. Exposes the active page object as an argument.
initialPageNumberThe initial page selected, in uncontrolled mode. Do not use with forcePage at the same time.
forcePageNumberTo override selected page with parent prop. Use this if you want to control the page from your app state.
disableInitialCallbackbooleanDisable onPageChange callback with initial page. Default: false
containerClassNameStringThe classname of the pagination container.
classNameStringSame as containerClassName. For use with styled-components & other CSS-in-JS.
pageClassNameStringThe classname on tag li of each page element.
pageLinkClassNameStringThe classname on tag a of each page element.
pageLabelBuilderFunctionFunction to set the text on page links. Defaults to (page) => page
activeClassNameStringThe classname for the active page.
activeLinkClassNameStringThe classname on the active tag a.
previousClassNameStringThe classname on tag li of the previous button.
nextClassNameStringThe classname on tag li of the next button.
previousLinkClassNameStringThe classname on tag a of the previous button.
nextLinkClassNameStringThe classname on tag a of the next button.
disabledClassNameStringThe classname for disabled previous and next buttons.
hrefBuilderFunctionThe method is called to generate the href attribute value on tag a of each page element.
extraAriaContextStringDEPRECATED: Extra context to add to the aria-label HTML attribute.
ariaLabelBuilderFunctionThe method is called to generate the aria-label attribute value on each page link
eventListenerStringThe event to listen onto before changing the selected page. Default is: onClick.
renderOnZeroPageCountFunctionA render fonction called when pageCount is zero. Let the Previous / Next buttons displayed by default (undefined). Display nothing when null is provided.

Demo

To run the demo locally, clone the repository and move into it:

git clone git@github.com:AdeleD/react-paginate.git
cd react-paginate

Install dependencies:

make install

Prepare the demo:

make demo

Run the server:

make serve

Open your browser and go to http://localhost:3000/

Pagination demo

Contribute

  1. Submit an issue
  2. Fork the repository
  3. Create a dedicated branch (never ever work in master)
  4. Run npm start http://localhost:3000
  5. Fix bugs or implement features
  6. Always write tests
  7. Format with Prettier npm run format and check ESLint npm run lint

Run tests:

make test

Keywords

FAQs

Last updated on 27 Oct 2021

Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc