UNPKG

react-table-6

Version:

A fast, lightweight, opinionated table and datagrid built on React

254 lines (236 loc) 22.6 kB
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } import React, { Component } from 'react'; import classnames from 'classnames'; var defaultButton = function defaultButton(props) { return React.createElement( 'button', _extends({ type: 'button' }, props, { className: '-btn' }), props.children ); }; var ReactTablePagination = function (_Component) { _inherits(ReactTablePagination, _Component); function ReactTablePagination(props) { _classCallCheck(this, ReactTablePagination); var _this = _possibleConstructorReturn(this, (ReactTablePagination.__proto__ || Object.getPrototypeOf(ReactTablePagination)).call(this, props)); _this.getSafePage = _this.getSafePage.bind(_this); _this.changePage = _this.changePage.bind(_this); _this.applyPage = _this.applyPage.bind(_this); _this.state = { page: props.page }; return _this; } _createClass(ReactTablePagination, [{ key: 'UNSAFE_componentWillReceiveProps', value: function UNSAFE_componentWillReceiveProps(nextProps) { if (this.props.page !== nextProps.page) { this.setState({ page: nextProps.page }); } } }, { key: 'getSafePage', value: function getSafePage(page) { if (Number.isNaN(page)) { page = this.props.page; } return Math.min(Math.max(page, 0), this.props.pages - 1); } }, { key: 'changePage', value: function changePage(page) { page = this.getSafePage(page); this.setState({ page: page }); if (this.props.page !== page) { this.props.onPageChange(page); } } }, { key: 'applyPage', value: function applyPage(e) { if (e) { e.preventDefault(); } var page = this.state.page; this.changePage(page === '' ? this.props.page : page); } }, { key: 'getPageJumpProperties', value: function getPageJumpProperties() { var _this2 = this; return { onKeyPress: function onKeyPress(e) { if (e.which === 13 || e.keyCode === 13) { _this2.applyPage(); } }, onBlur: this.applyPage, value: this.state.page === '' ? '' : this.state.page + 1, onChange: function onChange(e) { var val = e.target.value; var page = val - 1; if (val === '') { return _this2.setState({ page: val }); } _this2.setState({ page: _this2.getSafePage(page) }); }, inputType: this.state.page === '' ? 'text' : 'number', pageJumpText: this.props.pageJumpText }; } }, { key: 'render', value: function render() { var _this3 = this; var _props = this.props, pages = _props.pages, page = _props.page, showPageSizeOptions = _props.showPageSizeOptions, pageSizeOptions = _props.pageSizeOptions, pageSize = _props.pageSize, showPageJump = _props.showPageJump, canPrevious = _props.canPrevious, canNext = _props.canNext, onPageSizeChange = _props.onPageSizeChange, className = _props.className, PreviousComponent = _props.PreviousComponent, NextComponent = _props.NextComponent, renderPageJump = _props.renderPageJump, renderCurrentPage = _props.renderCurrentPage, renderTotalPagesCount = _props.renderTotalPagesCount, renderPageSizeOptions = _props.renderPageSizeOptions; return React.createElement( 'div', { className: classnames(className, '-pagination'), style: this.props.style }, React.createElement( 'div', { className: '-previous' }, React.createElement( PreviousComponent, { onClick: function onClick() { if (!canPrevious) return; _this3.changePage(page - 1); }, disabled: !canPrevious }, this.props.previousText ) ), React.createElement( 'div', { className: '-center' }, React.createElement( 'span', { className: '-pageInfo' }, this.props.pageText, ' ', showPageJump ? renderPageJump(this.getPageJumpProperties()) : renderCurrentPage(page), ' ', this.props.ofText, ' ', renderTotalPagesCount(pages) ), showPageSizeOptions && renderPageSizeOptions({ pageSize: pageSize, rowsSelectorText: this.props.rowsSelectorText, pageSizeOptions: pageSizeOptions, onPageSizeChange: onPageSizeChange, rowsText: this.props.rowsText }) ), React.createElement( 'div', { className: '-next' }, React.createElement( NextComponent, { onClick: function onClick() { if (!canNext) return; _this3.changePage(page + 1); }, disabled: !canNext }, this.props.nextText ) ) ); } }]); return ReactTablePagination; }(Component); ReactTablePagination.defaultProps = { PreviousComponent: defaultButton, NextComponent: defaultButton, renderPageJump: function renderPageJump(_ref) { var onChange = _ref.onChange, value = _ref.value, onBlur = _ref.onBlur, onKeyPress = _ref.onKeyPress, inputType = _ref.inputType, pageJumpText = _ref.pageJumpText; return React.createElement( 'div', { className: '-pageJump' }, React.createElement('input', { 'aria-label': pageJumpText, type: inputType, onChange: onChange, value: value, onBlur: onBlur, onKeyPress: onKeyPress }) ); }, renderCurrentPage: function renderCurrentPage(page) { return React.createElement( 'span', { className: '-currentPage' }, page + 1 ); }, renderTotalPagesCount: function renderTotalPagesCount(pages) { return React.createElement( 'span', { className: '-totalPages' }, pages || 1 ); }, renderPageSizeOptions: function renderPageSizeOptions(_ref2) { var pageSize = _ref2.pageSize, pageSizeOptions = _ref2.pageSizeOptions, rowsSelectorText = _ref2.rowsSelectorText, onPageSizeChange = _ref2.onPageSizeChange, rowsText = _ref2.rowsText; return React.createElement( 'span', { className: 'select-wrap -pageSizeOptions' }, React.createElement( 'select', { 'aria-label': rowsSelectorText, onChange: function onChange(e) { return onPageSizeChange(Number(e.target.value)); }, value: pageSize }, pageSizeOptions.map(function (option, i) { return ( // eslint-disable-next-line react/no-array-index-key React.createElement( 'option', { key: i, value: option }, option + ' ' + rowsText ) ); }) ) ); } }; export default ReactTablePagination; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/pagination.js"],"names":["React","Component","classnames","defaultButton","props","children","ReactTablePagination","getSafePage","bind","changePage","applyPage","state","page","nextProps","setState","Number","isNaN","Math","min","max","pages","onPageChange","e","preventDefault","onKeyPress","which","keyCode","onBlur","value","onChange","val","target","inputType","pageJumpText","showPageSizeOptions","pageSizeOptions","pageSize","showPageJump","canPrevious","canNext","onPageSizeChange","className","PreviousComponent","NextComponent","renderPageJump","renderCurrentPage","renderTotalPagesCount","renderPageSizeOptions","style","previousText","pageText","getPageJumpProperties","ofText","rowsSelectorText","rowsText","nextText","defaultProps","map","option","i"],"mappings":"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","file":"pagination.js","sourcesContent":["import React, { Component } from 'react'\nimport classnames from 'classnames'\n\nconst defaultButton = props => (\n  <button type=\"button\" {...props} className=\"-btn\">\n    {props.children}\n  </button>\n)\n\nexport default class ReactTablePagination extends Component {\n  static defaultProps = {\n    PreviousComponent: defaultButton,\n    NextComponent: defaultButton,\n    renderPageJump: ({\n      onChange, value, onBlur, onKeyPress, inputType, pageJumpText,\n    }) => (\n      <div className=\"-pageJump\">\n        <input\n          aria-label={pageJumpText}\n          type={inputType}\n          onChange={onChange}\n          value={value}\n          onBlur={onBlur}\n          onKeyPress={onKeyPress}\n        />\n      </div>\n    ),\n    renderCurrentPage: page => <span className=\"-currentPage\">{page + 1}</span>,\n    renderTotalPagesCount: pages => <span className=\"-totalPages\">{pages || 1}</span>,\n    renderPageSizeOptions: ({\n      pageSize,\n      pageSizeOptions,\n      rowsSelectorText,\n      onPageSizeChange,\n      rowsText,\n    }) => (\n      <span className=\"select-wrap -pageSizeOptions\">\n        <select\n          aria-label={rowsSelectorText}\n          onChange={e => onPageSizeChange(Number(e.target.value))}\n          value={pageSize}\n        >\n          {pageSizeOptions.map((option, i) => (\n            // eslint-disable-next-line react/no-array-index-key\n            <option key={i} value={option}>\n              {`${option} ${rowsText}`}\n            </option>\n          ))}\n        </select>\n      </span>\n    ),\n  }\n\n  constructor (props) {\n    super(props)\n\n    this.getSafePage = this.getSafePage.bind(this)\n    this.changePage = this.changePage.bind(this)\n    this.applyPage = this.applyPage.bind(this)\n\n    this.state = {\n      page: props.page,\n    }\n  }\n\n  UNSAFE_componentWillReceiveProps (nextProps) {\n    if (this.props.page !== nextProps.page) {\n      this.setState({ page: nextProps.page })\n    }\n  }\n\n  getSafePage (page) {\n    if (Number.isNaN(page)) {\n      page = this.props.page\n    }\n    return Math.min(Math.max(page, 0), this.props.pages - 1)\n  }\n\n  changePage (page) {\n    page = this.getSafePage(page)\n    this.setState({ page })\n    if (this.props.page !== page) {\n      this.props.onPageChange(page)\n    }\n  }\n\n  applyPage (e) {\n    if (e) {\n      e.preventDefault()\n    }\n    const page = this.state.page\n    this.changePage(page === '' ? this.props.page : page)\n  }\n\n  getPageJumpProperties () {\n    return {\n      onKeyPress: e => {\n        if (e.which === 13 || e.keyCode === 13) {\n          this.applyPage()\n        }\n      },\n      onBlur: this.applyPage,\n      value: this.state.page === '' ? '' : this.state.page + 1,\n      onChange: e => {\n        const val = e.target.value\n        const page = val - 1\n        if (val === '') {\n          return this.setState({ page: val })\n        }\n        this.setState({ page: this.getSafePage(page) })\n      },\n      inputType: this.state.page === '' ? 'text' : 'number',\n      pageJumpText: this.props.pageJumpText,\n    }\n  }\n\n  render () {\n    const {\n      // Computed\n      pages,\n      // Props\n      page,\n      showPageSizeOptions,\n      pageSizeOptions,\n      pageSize,\n      showPageJump,\n      canPrevious,\n      canNext,\n      onPageSizeChange,\n      className,\n      PreviousComponent,\n      NextComponent,\n      renderPageJump,\n      renderCurrentPage,\n      renderTotalPagesCount,\n      renderPageSizeOptions,\n    } = this.props\n\n    return (\n      <div className={classnames(className, '-pagination')} style={this.props.style}>\n        <div className=\"-previous\">\n          <PreviousComponent\n            onClick={() => {\n              if (!canPrevious) return\n              this.changePage(page - 1)\n            }}\n            disabled={!canPrevious}\n          >\n            {this.props.previousText}\n          </PreviousComponent>\n        </div>\n        <div className=\"-center\">\n          <span className=\"-pageInfo\">\n            {this.props.pageText}{' '}\n            {showPageJump ? renderPageJump(this.getPageJumpProperties()) : renderCurrentPage(page)}{' '}\n            {this.props.ofText} {renderTotalPagesCount(pages)}\n          </span>\n          {showPageSizeOptions &&\n            renderPageSizeOptions({\n              pageSize,\n              rowsSelectorText: this.props.rowsSelectorText,\n              pageSizeOptions,\n              onPageSizeChange,\n              rowsText: this.props.rowsText,\n            })}\n        </div>\n        <div className=\"-next\">\n          <NextComponent\n            onClick={() => {\n              if (!canNext) return\n              this.changePage(page + 1)\n            }}\n            disabled={!canNext}\n          >\n            {this.props.nextText}\n          </NextComponent>\n        </div>\n      </div>\n    )\n  }\n}\n"]}