react-table-6
Version:
A fast, lightweight, opinionated table and datagrid built on React
267 lines (243 loc) • 23 kB
JavaScript
Object.defineProperty(exports, "__esModule", {
value: true
});
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; };
var _react = require('react');
var _react2 = _interopRequireDefault(_react);
var _classnames = require('classnames');
var _classnames2 = _interopRequireDefault(_classnames);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
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; }
var defaultButton = function defaultButton(props) {
return _react2.default.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 _react2.default.createElement(
'div',
{ className: (0, _classnames2.default)(className, '-pagination'), style: this.props.style },
_react2.default.createElement(
'div',
{ className: '-previous' },
_react2.default.createElement(
PreviousComponent,
{
onClick: function onClick() {
if (!canPrevious) return;
_this3.changePage(page - 1);
},
disabled: !canPrevious
},
this.props.previousText
)
),
_react2.default.createElement(
'div',
{ className: '-center' },
_react2.default.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
})
),
_react2.default.createElement(
'div',
{ className: '-next' },
_react2.default.createElement(
NextComponent,
{
onClick: function onClick() {
if (!canNext) return;
_this3.changePage(page + 1);
},
disabled: !canNext
},
this.props.nextText
)
)
);
}
}]);
return ReactTablePagination;
}(_react.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 _react2.default.createElement(
'div',
{ className: '-pageJump' },
_react2.default.createElement('input', {
'aria-label': pageJumpText,
type: inputType,
onChange: onChange,
value: value,
onBlur: onBlur,
onKeyPress: onKeyPress
})
);
},
renderCurrentPage: function renderCurrentPage(page) {
return _react2.default.createElement(
'span',
{ className: '-currentPage' },
page + 1
);
},
renderTotalPagesCount: function renderTotalPagesCount(pages) {
return _react2.default.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 _react2.default.createElement(
'span',
{ className: 'select-wrap -pageSizeOptions' },
_react2.default.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
_react2.default.createElement(
'option',
{ key: i, value: option },
option + ' ' + rowsText
)
);
})
)
);
}
};
exports.default = ReactTablePagination;
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/pagination.js"],"names":["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","Component","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"]}
;