rsuite
Version:
A suite of react components
224 lines (187 loc) • 7.53 kB
JavaScript
"use strict";
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
exports.__esModule = true;
exports.default = void 0;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _objectWithoutPropertiesLoose2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutPropertiesLoose"));
var _inheritsLoose2 = _interopRequireDefault(require("@babel/runtime/helpers/inheritsLoose"));
var React = _interopRequireWildcard(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _classnames = _interopRequireDefault(require("classnames"));
var _recompose = require("recompose");
var _Pagination = _interopRequireDefault(require("../Pagination"));
var _SelectPicker = _interopRequireDefault(require("../SelectPicker"));
var _Divider = _interopRequireDefault(require("../Divider"));
var _utils = require("../utils");
var _withLocale = _interopRequireDefault(require("../IntlProvider/withLocale"));
var TablePagination =
/*#__PURE__*/
function (_React$Component) {
(0, _inheritsLoose2.default)(TablePagination, _React$Component);
function TablePagination() {
var _this;
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
_this = _React$Component.call.apply(_React$Component, [this].concat(args)) || this;
_this.handleChangeLength = function (eventKey) {
var _this$props$onChangeL, _this$props;
(_this$props$onChangeL = (_this$props = _this.props).onChangeLength) === null || _this$props$onChangeL === void 0 ? void 0 : _this$props$onChangeL.call(_this$props, eventKey);
};
_this.handleChangePage = function (eventKey) {
var _this$props$onChangeP, _this$props2;
(_this$props$onChangeP = (_this$props2 = _this.props).onChangePage) === null || _this$props$onChangeP === void 0 ? void 0 : _this$props$onChangeP.call(_this$props2, eventKey);
};
_this.addPrefix = function (name) {
return (0, _utils.prefix)(_this.props.classPrefix)(name);
};
return _this;
}
var _proto = TablePagination.prototype;
_proto.renderLengthMenu = function renderLengthMenu() {
var _this$props3 = this.props,
_this$props3$lengthMe = _this$props3.lengthMenu,
lengthMenu = _this$props3$lengthMe === void 0 ? [] : _this$props3$lengthMe,
renderLengthMenu = _this$props3.renderLengthMenu,
showLengthMenu = _this$props3.showLengthMenu,
locale = _this$props3.locale,
displayLength = _this$props3.displayLength,
disabled = _this$props3.disabled;
if (!showLengthMenu) {
return null;
}
var disabledPicker = typeof disabled === 'function' ? disabled('picker') : disabled;
var picker = React.createElement(_SelectPicker.default, {
appearance: "subtle",
cleanable: false,
searchable: false,
placement: "topStart",
data: lengthMenu,
value: displayLength,
onChange: this.handleChangeLength,
menuStyle: {
minWidth: 'auto'
},
disabled: disabledPicker
});
return React.createElement("div", {
className: this.addPrefix('length-menu')
}, renderLengthMenu ? renderLengthMenu(picker) : (0, _utils.tplTransform)(locale.lengthMenuInfo, picker));
};
_proto.renderInfo = function renderInfo() {
var _this$props4 = this.props,
renderTotal = _this$props4.renderTotal,
total = _this$props4.total,
showInfo = _this$props4.showInfo,
locale = _this$props4.locale,
activePage = _this$props4.activePage;
if (!showInfo) {
return null;
}
return React.createElement("div", {
className: this.addPrefix('page-info')
}, renderTotal ? renderTotal(total, activePage) : (0, _utils.tplTransform)(locale.totalInfo, total));
};
_proto.render = function render() {
var _this$props5 = this.props,
total = _this$props5.total,
prev = _this$props5.prev,
next = _this$props5.next,
first = _this$props5.first,
last = _this$props5.last,
maxButtons = _this$props5.maxButtons,
className = _this$props5.className,
displayLength = _this$props5.displayLength,
activePage = _this$props5.activePage,
disabled = _this$props5.disabled,
style = _this$props5.style,
reverse = _this$props5.reverse,
rest = (0, _objectWithoutPropertiesLoose2.default)(_this$props5, ["total", "prev", "next", "first", "last", "maxButtons", "className", "displayLength", "activePage", "disabled", "style", "reverse"]);
var pages = Math.floor(total / displayLength) + (total % displayLength ? 1 : 0);
var classes = (0, _classnames.default)(this.addPrefix('toolbar'), className);
var unhandled = (0, _utils.getUnhandledProps)(TablePagination, rest);
var pagers = [React.createElement("div", {
className: (0, _classnames.default)(this.addPrefix('start')),
key: 1
}, this.renderLengthMenu(), React.createElement(_Divider.default, {
vertical: true
}), this.renderInfo()), React.createElement("div", {
className: (0, _classnames.default)(this.addPrefix('end')),
key: 2
}, React.createElement(_Pagination.default, (0, _extends2.default)({
size: "xs",
prev: prev,
next: next,
first: first,
last: last,
maxButtons: maxButtons,
pages: pages,
disabled: disabled,
onSelect: this.handleChangePage,
activePage: activePage
}, unhandled)))];
return React.createElement("div", {
className: classes,
style: style
}, reverse ? pagers.reverse() : pagers);
};
return TablePagination;
}(React.Component);
TablePagination.propTypes = {
lengthMenu: _propTypes.default.arrayOf(_propTypes.default.shape({
value: _propTypes.default.number,
label: _propTypes.default.node
})),
showLengthMenu: _propTypes.default.bool,
showInfo: _propTypes.default.bool,
total: _propTypes.default.number,
displayLength: _propTypes.default.number,
prev: _propTypes.default.bool,
next: _propTypes.default.bool,
first: _propTypes.default.bool,
last: _propTypes.default.bool,
maxButtons: _propTypes.default.number,
activePage: _propTypes.default.number,
className: _propTypes.default.string,
locale: _propTypes.default.object,
classPrefix: _propTypes.default.string,
disabled: _propTypes.default.oneOfType([_propTypes.default.bool, _propTypes.default.func]),
style: _propTypes.default.object,
// reverse start and end position
reverse: _propTypes.default.bool,
renderLengthMenu: _propTypes.default.func,
renderTotal: _propTypes.default.func,
onChangePage: _propTypes.default.func,
onChangeLength: _propTypes.default.func
};
TablePagination.defaultProps = {
showLengthMenu: true,
showInfo: true,
lengthMenu: [{
value: 30,
label: 30
}, {
value: 50,
label: 50
}, {
value: 100,
label: 100
}],
displayLength: 30,
prev: true,
next: true,
first: true,
last: true,
activePage: 1,
maxButtons: 5,
locale: {
lengthMenuInfo: 'Show {0} data',
totalInfo: 'Total: {0}'
}
};
var _default = (0, _recompose.compose)((0, _withLocale.default)(['TablePagination']), (0, _utils.defaultProps)({
classPrefix: 'table-pagination'
}))(TablePagination);
exports.default = _default;
module.exports = exports.default;