react-table-v6
Version:
A fast, lightweight, opinionated table and datagrid built on React
202 lines (185 loc) • 18.4 kB
JavaScript
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';
//
// import _ from './utils'
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));
_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: 'componentWillReceiveProps',
value: function componentWillReceiveProps(nextProps) {
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: 'render',
value: function render() {
var _this2 = 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,
_props$PreviousCompon = _props.PreviousComponent,
PreviousComponent = _props$PreviousCompon === undefined ? defaultButton : _props$PreviousCompon,
_props$NextComponent = _props.NextComponent,
NextComponent = _props$NextComponent === undefined ? defaultButton : _props$NextComponent;
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;
_this2.changePage(page - 1);
},
disabled: !canPrevious
},
this.props.previousText
)
),
React.createElement(
'div',
{ className: '-center' },
React.createElement(
'span',
{ className: '-pageInfo' },
this.props.pageText,
' ',
showPageJump ? React.createElement(
'div',
{ className: '-pageJump' },
React.createElement('input', {
type: this.state.page === '' ? 'text' : 'number',
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) });
},
value: this.state.page === '' ? '' : this.state.page + 1,
onBlur: this.applyPage,
onKeyPress: function onKeyPress(e) {
if (e.which === 13 || e.keyCode === 13) {
_this2.applyPage();
}
}
})
) : React.createElement(
'span',
{ className: '-currentPage' },
page + 1
),
' ',
this.props.ofText,
' ',
React.createElement(
'span',
{ className: '-totalPages' },
pages || 1
)
),
showPageSizeOptions && React.createElement(
'span',
{ className: 'select-wrap -pageSizeOptions' },
React.createElement(
'select',
{ 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,
' ',
_this2.props.rowsText
)
);
})
)
)
),
React.createElement(
'div',
{ className: '-next' },
React.createElement(
NextComponent,
{
onClick: function onClick() {
if (!canNext) return;
_this2.changePage(page + 1);
},
disabled: !canNext
},
this.props.nextText
)
)
);
}
}]);
return ReactTablePagination;
}(Component);
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","showPageSizeOptions","pageSizeOptions","pageSize","showPageJump","canPrevious","canNext","onPageSizeChange","className","PreviousComponent","NextComponent","style","previousText","pageText","val","target","value","which","keyCode","ofText","map","option","i","rowsText","nextText"],"mappings":"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","file":"pagination.js","sourcesContent":["import React, { Component } from 'react'\nimport classnames from 'classnames'\n//\n// import _ from './utils'\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  constructor (props) {\n    super()\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  componentWillReceiveProps (nextProps) {\n    this.setState({ page: nextProps.page })\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  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 = defaultButton,\n      NextComponent = defaultButton,\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 ? (\n              <div className=\"-pageJump\">\n                <input\n                  type={this.state.page === '' ? 'text' : 'number'}\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                  value={this.state.page === '' ? '' : this.state.page + 1}\n                  onBlur={this.applyPage}\n                  onKeyPress={e => {\n                    if (e.which === 13 || e.keyCode === 13) {\n                      this.applyPage()\n                    }\n                  }}\n                />\n              </div>\n            ) : (\n              <span className=\"-currentPage\">{page + 1}</span>\n            )}{' '}\n            {this.props.ofText} <span className=\"-totalPages\">{pages || 1}</span>\n          </span>\n          {showPageSizeOptions && (\n            <span className=\"select-wrap -pageSizeOptions\">\n              <select onChange={e => onPageSizeChange(Number(e.target.value))} value={pageSize}>\n                {pageSizeOptions.map((option, i) => (\n                  // eslint-disable-next-line react/no-array-index-key\n                  <option key={i} value={option}>\n                    {option} {this.props.rowsText}\n                  </option>\n                ))}\n              </select>\n            </span>\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"]}