UNPKG

choerodon-ui

Version:

An enterprise-class UI design language and React-based implementation

653 lines (543 loc) 23.5 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault")["default"]; Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator")); var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator")); var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2")); var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray")); var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass")); var _get2 = _interopRequireDefault(require("@babel/runtime/helpers/get")); var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); var _createSuper2 = _interopRequireDefault(require("@babel/runtime/helpers/createSuper")); var _tslib = require("tslib"); var _react = _interopRequireDefault(require("react")); var _mobx = require("mobx"); var _mobxReact = require("mobx-react"); var _classnames = _interopRequireDefault(require("classnames")); var _isObject = _interopRequireDefault(require("lodash/isObject")); var _defaultTo = _interopRequireDefault(require("lodash/defaultTo")); var _isString = _interopRequireDefault(require("lodash/isString")); var _noop = _interopRequireDefault(require("lodash/noop")); var _KeyCode = _interopRequireDefault(require("../../../lib/_util/KeyCode")); var _enum = require("../../../lib/_util/enum"); var _DataSetComponent2 = _interopRequireDefault(require("../data-set/DataSetComponent")); var _Select = _interopRequireDefault(require("../select/Select")); var _NumberField = _interopRequireDefault(require("../number-field/NumberField")); var _button = _interopRequireDefault(require("../button")); var _autobind = _interopRequireDefault(require("../_util/autobind")); var _localeContext = require("../locale-context"); var _Pager = _interopRequireDefault(require("./Pager")); var _icon = _interopRequireDefault(require("../icon")); var _enum2 = require("./enum"); var _enum3 = require("../text-field/enum"); var _QuickJumper = _interopRequireDefault(require("./QuickJumper")); function defaultItemRender(page, type) { switch (type) { case 'first': return /*#__PURE__*/_react["default"].createElement(_icon["default"], { type: "first_page" }); case 'last': return /*#__PURE__*/_react["default"].createElement(_icon["default"], { type: "last_page" }); case 'prev': return /*#__PURE__*/_react["default"].createElement(_icon["default"], { type: "navigate_before" }); case 'next': return /*#__PURE__*/_react["default"].createElement(_icon["default"], { type: "navigate_next" }); case 'jump-prev': case 'jump-next': return '•••'; default: return page; } } var Pagination = /*#__PURE__*/function (_DataSetComponent) { (0, _inherits2["default"])(Pagination, _DataSetComponent); var _super = (0, _createSuper2["default"])(Pagination); function Pagination() { (0, _classCallCheck2["default"])(this, Pagination); return _super.apply(this, arguments); } (0, _createClass2["default"])(Pagination, [{ key: "pageSize", get: function get() { var _this$observableProps = this.observableProps, dataSet = _this$observableProps.dataSet, pageSize = _this$observableProps.pageSize; if (dataSet) { return dataSet.pageSize; } return pageSize; } }, { key: "page", get: function get() { var _this$observableProps2 = this.observableProps, dataSet = _this$observableProps2.dataSet, page = _this$observableProps2.page; if (dataSet) { return dataSet.currentPage; } return page; } }, { key: "total", get: function get() { var _this$observableProps3 = this.observableProps, dataSet = _this$observableProps3.dataSet, total = _this$observableProps3.total; if (dataSet) { return dataSet.totalCount; } return total; } }, { key: "totalPage", get: function get() { var dataSet = this.observableProps.dataSet; var total = this.total, pageSize = this.pageSize; if (dataSet) { return dataSet.totalPage; } if (total !== undefined && pageSize !== undefined) { return Math.ceil(total / pageSize); } return 1; } }, { key: "next", get: function get() { var _this$total = this.total, total = _this$total === void 0 ? 0 : _this$total, pageSize = this.pageSize, page = this.page; return page < Math.floor((total - 1) / pageSize) + 1; } }, { key: "getObservableProps", value: function getObservableProps(props, context) { var globalPagination = this.getContextConfig('pagination'); var pageSizeOptions = props.pageSizeOptions || globalPagination && globalPagination.pageSizeOptions || ['10', '20', '50', '100']; var maxPageSize = Math.max.apply(Math, [(0, _defaultTo["default"])('maxPageSize' in props ? props.maxPageSize : globalPagination && globalPagination.maxPageSize, 100)].concat((0, _toConsumableArray2["default"])(pageSizeOptions))); return (0, _objectSpread2["default"])((0, _objectSpread2["default"])({}, (0, _get2["default"])((0, _getPrototypeOf2["default"])(Pagination.prototype), "getObservableProps", this).call(this, props, context)), {}, { page: (0, _defaultTo["default"])('page' in props ? props.page : globalPagination && globalPagination.page, 1), pageSize: (0, _defaultTo["default"])('pageSize' in props ? props.pageSize : globalPagination && globalPagination.pageSize, 10), total: props.total, pageSizeOptions: pageSizeOptions, pageSizeEditable: 'pageSizeEditable' in props ? props.pageSizeEditable : globalPagination && globalPagination.pageSizeEditable, maxPageSize: maxPageSize }); } }, { key: "handlePageSizeBeforeChange", value: function handlePageSizeBeforeChange(value) { if (value < 1 || value > this.observableProps.maxPageSize) { return false; } var dataSet = this.props.dataSet; if (dataSet) { return dataSet.modifiedCheck(); } return true; } }, { key: "handlePageSizeChange", value: function handlePageSizeChange(value) { this.handleChange(this.page, Number(value)); } }, { key: "handleChange", value: function () { var _handleChange = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee(page, pageSize) { var _this = this; var _this$props, dataSet, onChange, _this$props$beforeCha, beforeChange; return _regenerator["default"].wrap(function _callee$(_context) { while (1) { switch (_context.prev = _context.next) { case 0: _this$props = this.props, dataSet = _this$props.dataSet, onChange = _this$props.onChange, _this$props$beforeCha = _this$props.beforeChange, beforeChange = _this$props$beforeCha === void 0 ? _noop["default"] : _this$props$beforeCha; _context.t0 = this.pageSize !== pageSize; if (!_context.t0) { _context.next = 7; break; } _context.next = 5; return beforeChange(page, pageSize); case 5: _context.t1 = _context.sent; _context.t0 = _context.t1 !== false; case 7: if (!_context.t0) { _context.next = 11; break; } (0, _mobx.runInAction)(function () { _this.observableProps.pageSize = pageSize; _this.observableProps.page = 1; if (dataSet) { dataSet.pageSize = pageSize; dataSet.currentPage = 1; dataSet.query(1, undefined, true); } }); _context.next = 12; break; case 11: (0, _mobx.runInAction)(function () { _this.observableProps.page = page; }); case 12: if (onChange) { onChange(page, pageSize); } case 13: case "end": return _context.stop(); } } }, _callee, this); })); function handleChange(_x, _x2) { return _handleChange.apply(this, arguments); } return handleChange; }() }, { key: "handlePagerClick", value: function handlePagerClick(page) { this.jumpPage(page); } }, { key: "getValidValue", value: function getValidValue(value) { var page = this.page, totalPage = this.totalPage; value = Number(value); if (isNaN(value)) { value = page; } if (value > totalPage) { value = totalPage; } return value; } }, { key: "jumpPage", value: function () { var _jumpPage = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2(page) { var _this$props2, dataSet, _this$props2$beforeCh, beforeChange; return _regenerator["default"].wrap(function _callee2$(_context2) { while (1) { switch (_context2.prev = _context2.next) { case 0: _this$props2 = this.props, dataSet = _this$props2.dataSet, _this$props2$beforeCh = _this$props2.beforeChange, beforeChange = _this$props2$beforeCh === void 0 ? _noop["default"] : _this$props2$beforeCh; _context2.next = 3; return beforeChange(page, this.pageSize); case 3: _context2.t0 = _context2.sent; if (!(_context2.t0 !== false)) { _context2.next = 7; break; } if (dataSet) { dataSet.page(page); } this.handleChange(page, this.pageSize); case 7: case "end": return _context2.stop(); } } }, _callee2, this); })); function jumpPage(_x3) { return _jumpPage.apply(this, arguments); } return jumpPage; }() }, { key: "handleJumpChange", value: function handleJumpChange(value) { var page = this.page, totalPage = this.totalPage, _this$props3 = this.props, showQuickJumper = _this$props3.showQuickJumper, simple = _this$props3.simple; value = Number(value); if (isNaN(value)) { value = page; } if (value > totalPage) { value = totalPage; } if (simple) { this.jumpPage(value); } else if (showQuickJumper) { if ((0, _isObject["default"])(showQuickJumper) && showQuickJumper.goButton) { this.pageInput = value; } else { this.jumpPage(value); } } } }, { key: "handleJumpGo", value: function handleJumpGo(e) { if (e.keyCode === _KeyCode["default"].ENTER || e.type === 'click') { var pageInput = this.pageInput; if (pageInput) { this.jumpPage(pageInput); this.pageInput = ''; } } } }, { key: "getOmitPropsKeys", value: function getOmitPropsKeys() { return (0, _get2["default"])((0, _getPrototypeOf2["default"])(Pagination.prototype), "getOmitPropsKeys", this).call(this).concat(['total', 'page', 'pageSize', 'maxPageSize', 'pageSizeEditable', 'onChange', 'pageSizeOptions', 'itemRender', 'showSizeChanger', 'showQuickJumper', 'showSizeChangerLabel', 'showTotal', 'showPager', 'sizeChangerPosition', 'sizeChangerOptionRenderer', 'hideOnSinglePage', 'simple', 'quickJumperPosition']); } }, { key: "getOptions", value: function getOptions() { var Option = _Select["default"].Option; return this.observableProps.pageSizeOptions.map(function (option) { return /*#__PURE__*/_react["default"].createElement(Option, { key: option, value: option }, option); }); } }, { key: "getPager", value: function getPager(page, type) { var active = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; var disabledSender = arguments.length > 3 ? arguments[3] : undefined; var prefixCls = this.prefixCls, _this$props4 = this.props, _this$props4$itemRend = _this$props4.itemRender, itemRender = _this$props4$itemRend === void 0 ? defaultItemRender : _this$props4$itemRend, _this$props4$disabled = _this$props4.disabled, disabled = _this$props4$disabled === void 0 ? false : _this$props4$disabled; var disabledValue = disabledSender || disabled; var classNamePager = (0, _isString["default"])(type) ? "".concat(prefixCls, "-pager-").concat(type) : ""; return /*#__PURE__*/_react["default"].createElement(_Pager["default"], { key: type === 'page' ? page : type, page: page, active: active, type: type, onClick: this.handlePagerClick, renderer: itemRender, disabled: disabledValue, className: "".concat(prefixCls, "-pager ").concat(classNamePager) }); } }, { key: "renderPagers", value: function renderPagers(page) { var totalPage = this.totalPage; var bufferSize = 1; var pagerList = []; if (totalPage <= 3 + bufferSize * 2) { for (var i = 1; i <= totalPage; i += 1) { pagerList.push(this.getPager(i, 'page', page === i)); } } else { var left = Math.max(1, page - bufferSize); var right = Math.min(totalPage, page + bufferSize); if (page - 1 <= bufferSize) { right = 1 + bufferSize * 2; } if (totalPage - page <= bufferSize) { left = totalPage - bufferSize * 2; } for (var _i = left; _i <= right; _i++) { pagerList.push(this.getPager(_i, 'page', page === _i)); } if (page - 1 >= bufferSize * 2 && page !== 1 + 2) { pagerList.unshift(this.getPager(Math.max(page - 5, 1), 'jump-prev')); } if (totalPage - page >= bufferSize * 2 && page !== totalPage - 2) { pagerList.push(this.getPager(Math.min(page + 5, totalPage), 'jump-next')); } if (left !== 1) { pagerList.unshift(this.getPager(1, 'page', page === 1)); } if (totalPage > 1 && right !== totalPage) { pagerList.push(this.getPager(totalPage, 'page', page === totalPage)); } } return pagerList; } }, { key: "renderSizeChange", value: function renderSizeChange(pageSize) { var _this$props5 = this.props, showSizeChangerLabel = _this$props5.showSizeChangerLabel, showSizeChanger = _this$props5.showSizeChanger, sizeChangerOptionRenderer = _this$props5.sizeChangerOptionRenderer, disabled = _this$props5.disabled; if (showSizeChanger) { var pageSizeEditable = this.observableProps.pageSizeEditable; var prefixCls = this.prefixCls; var select = /*#__PURE__*/_react["default"].createElement(_Select["default"], { isFlat: true, searchable: false, key: "size-select", className: (0, _classnames["default"])("".concat(prefixCls, "-size-changer"), (0, _defineProperty2["default"])({}, "".concat(prefixCls, "-size-editable"), pageSizeEditable)), disabled: disabled, onBeforeChange: this.handlePageSizeBeforeChange, onChange: this.handlePageSizeChange, value: String(pageSize), clearButton: false, renderer: sizeChangerOptionRenderer, optionRenderer: sizeChangerOptionRenderer, combo: pageSizeEditable, restrict: "0-9", size: _enum.Size.small }, this.getOptions()); return showSizeChangerLabel ? [/*#__PURE__*/_react["default"].createElement("span", { className: "".concat(prefixCls, "-perpage"), key: "size-info" }, (0, _localeContext.$l)('Pagination', 'records_per_page')), select] : select; } } }, { key: "renderTotal", value: function renderTotal(pageSize, page, total) { var prefixCls = this.prefixCls, showTotal = this.props.showTotal, dataSet = this.dataSet; var from = pageSize * (page - 1) + 1; var to = Math.min(pageSize * page, total); var counting = dataSet && dataSet.counting; if (typeof showTotal === 'function') { return /*#__PURE__*/_react["default"].createElement("span", { key: "total", className: "".concat(prefixCls, "-page-info") }, showTotal(total, [from, to], counting !== undefined)); } return /*#__PURE__*/_react["default"].createElement("span", { key: "total", className: "".concat(prefixCls, "-page-info") }, from, " - ", to, " / ", counting ? '...' : total); } /** * 渲染快速跳至 */ }, { key: "renderQuickGo", value: function renderQuickGo() { var prefixCls = this.prefixCls, page = this.page; var _this$props6 = this.props, disabled = _this$props6.disabled, showQuickJumper = _this$props6.showQuickJumper; var gotoButton = null; if ((0, _isObject["default"])(showQuickJumper) && showQuickJumper.goButton) { var goButton = showQuickJumper.goButton; gotoButton = typeof goButton === 'boolean' ? /*#__PURE__*/_react["default"].createElement(_button["default"], { className: "".concat(prefixCls, "-go-button"), onClick: this.handleJumpGo, onKeyUp: this.handleJumpGo, disabled: disabled, size: _enum.Size.small }, (0, _localeContext.$l)('Pagination', 'jump_to_confirm')) : /*#__PURE__*/_react["default"].createElement("span", { className: "".concat(prefixCls, "-go-button"), onClick: this.handleJumpGo, onKeyUp: this.handleJumpGo }, goButton); } return /*#__PURE__*/_react["default"].createElement(_QuickJumper["default"], { prefixCls: prefixCls, value: this.pageInput || page, onChange: this.handleJumpChange, disabled: disabled, gotoButton: gotoButton }); } }, { key: "render", value: function render() { var total = this.total, pageSize = this.pageSize, page = this.page, _this$props7 = this.props, hideOnSinglePage = _this$props7.hideOnSinglePage, simple = _this$props7.simple, prefixCls = this.prefixCls; if (total === undefined || pageSize === undefined || page === undefined) { return null; } if (hideOnSinglePage === true && total <= pageSize) { return null; } var totalPage = this.totalPage, _this$props8 = this.props, children = _this$props8.children, sizeChangerPosition = _this$props8.sizeChangerPosition, showTotal = _this$props8.showTotal, showPager = _this$props8.showPager, showQuickJumper = _this$props8.showQuickJumper, quickJumperPosition = _this$props8.quickJumperPosition; var sizeChanger = this.renderSizeChange(pageSize); if (simple) { return /*#__PURE__*/_react["default"].createElement("nav", (0, _extends2["default"])({}, this.getMergedProps()), this.getPager(page - 1, 'prev', false, page === 1), /*#__PURE__*/_react["default"].createElement("li", { className: "".concat(prefixCls, "-simple-pager") }, /*#__PURE__*/_react["default"].createElement(_NumberField["default"], { value: page, min: 1, onChange: this.handleJumpChange, valueChangeAction: _enum3.ValueChangeAction.input, wait: 200 }), /*#__PURE__*/_react["default"].createElement("span", null, "\uFF0F"), totalPage), this.getPager(page + 1, 'next', false, !this.next)); } return /*#__PURE__*/_react["default"].createElement("nav", (0, _extends2["default"])({}, this.getMergedProps()), children, sizeChangerPosition === _enum2.SizeChangerPosition.left && sizeChanger, showQuickJumper && quickJumperPosition === _enum2.QuickJumperPosition.left && this.renderQuickGo(), showTotal && this.renderTotal(pageSize, page, total), this.getPager(1, 'first', false, page === 1), this.getPager(page - 1, 'prev', false, page === 1), showPager && this.renderPagers(page), this.getPager(page + 1, 'next', false, !this.next), this.getPager(totalPage, 'last', false, !this.next), sizeChangerPosition === _enum2.SizeChangerPosition.right && sizeChanger, showQuickJumper && quickJumperPosition === _enum2.QuickJumperPosition.right && this.renderQuickGo()); } }]); return Pagination; }(_DataSetComponent2["default"]); Pagination.displayName = 'Pagination'; Pagination.defaultProps = { suffixCls: 'pagination', sizeChangerPosition: _enum2.SizeChangerPosition.left, quickJumperPosition: _enum2.QuickJumperPosition.right, sizeChangerOptionRenderer: function sizeChangerOptionRenderer(_ref) { var text = _ref.text; return text; }, hideOnSinglePage: false, showSizeChanger: true, showQuickJumper: false, showSizeChangerLabel: true, showTotal: true, simple: false }; (0, _tslib.__decorate)([_mobx.observable], Pagination.prototype, "pageInput", void 0); (0, _tslib.__decorate)([_mobx.computed], Pagination.prototype, "pageSize", null); (0, _tslib.__decorate)([_mobx.computed], Pagination.prototype, "page", null); (0, _tslib.__decorate)([_mobx.computed], Pagination.prototype, "total", null); (0, _tslib.__decorate)([_mobx.computed], Pagination.prototype, "totalPage", null); (0, _tslib.__decorate)([_mobx.computed], Pagination.prototype, "next", null); (0, _tslib.__decorate)([_autobind["default"]], Pagination.prototype, "handlePageSizeBeforeChange", null); (0, _tslib.__decorate)([_autobind["default"]], Pagination.prototype, "handlePageSizeChange", null); (0, _tslib.__decorate)([_autobind["default"]], Pagination.prototype, "handlePagerClick", null); (0, _tslib.__decorate)([_autobind["default"]], Pagination.prototype, "handleJumpChange", null); (0, _tslib.__decorate)([_autobind["default"], _mobx.action], Pagination.prototype, "handleJumpGo", null); (0, _tslib.__decorate)([_mobx.action], Pagination.prototype, "getOptions", null); Pagination = (0, _tslib.__decorate)([_mobxReact.observer], Pagination); var _default = Pagination; exports["default"] = _default; //# sourceMappingURL=Pagination.js.map