@tshio/react-router-pagination
TypeScript icon, indicating that this package has built-in type declarations

1.2.1 • Public • Published

Status

Build Status Code Coverage License Version

react-router-pagination

Installation

Using yarn:

$ yarn add @tshio/react-router-pagination

Using npm:

$ npm install --save @tshio/react-router-pagination

Usage

In order to connect custom component with pagination, it is required to import withRouter function from react-router-dom and use it to wrap connectRouterWithPagination function.

At the beginning, wrap your list component using connectRouterWithPagination function in your container:

import { withRouter } from 'react-router-dom';
import { connect } from 'react-redux';
import { compose } from 'redux';

import { connectRouterWithPagination } from '@tshio/react-router-pagination';

import { fetchUsers } from '../redux/users/users.actions';
import { ListComponent } from '../list.component';
import { PaginationComponent } from '../pagination.component';

const mapStateToProps = () => ({ ... })

const mapDispatchToProps = dispatch => ({
    onPageChange: (params) => dispatch(fetchUsers(params)) // `onPageChange` method will dispatch your redux action when page changes
});

//And now, connect your store with list component

export const ListContainer = compose(
  withRouter,
  connect(mapStateToProps, mapDispatchToProps),
  connectRouterWithPagination(PaginationComponent,
    // In first parameter pass your custom pagination component
    {
        // Second parameter (optional) is an object and allow you to pass config options
        pageChangeCallbackKey: "pageChangeCallback",
        currentPageKey: "page",
        pageParamName: "usersListPage",
        itemsPerPageParamName: "itemsNumber",
        defaultItemsPerPage: 8
        // See list of available options below..
    }
  )
)(ListComponent);

Keep in mind, that onPageChange function is required and always has to be implemented!

And then, you can render pagination component in list component:

import React, { Component } from 'react';

// ...

export class ListComponent extends Component {
  render() {
    return (
      <div>
        // ...
        {this.props.pagination({
          // here, you can define custom properties for pagination component
        })}
      </div>
    );
  }
}

This package is working with page and itemsPerPage parameters which are included in URL. If page param is missing, it will be set as default with value 1. If itemsPerPage param is missing, it will be initialized with value of defaultItemsPerPage from config options or with value of 10.

Config options

Option name Default value Type Role
currentPageKey currentPage string Name of prop which is passed to pagination component to point on current page.
pageChangeCallbackKey onChange string Name of callback function which is called when you click on navigation button in pagination component.
pageParamName page string Determines what is the name of page param which is displayed in URL; e.g. /users?page=1.
itemsPerPageParamName itemsPerPage string Determines what is the name of items per page param displayed in URL; e.g. /users?itemsPerPage=10
defaultItemsPerPage 10 number Determines initial and default value of number of items per page.

Development

We welcome all contributions. Please read our CONTRIBUTING.md first. You can submit any ideas as GitHub issues.

Readme

Keywords

none

Package Sidebar

Install

npm i @tshio/react-router-pagination

Weekly Downloads

1

Version

1.2.1

License

MIT

Unpacked Size

24.5 kB

Total Files

8

Last publish

Collaborators

  • vviktor
  • aherok
  • sethii
  • barograf