UNPKG

@nutui/nutui-react

Version:

京东风格的轻量级移动端 React 组件库,支持一套代码生成 H5 和小程序

116 lines (115 loc) 5.8 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); Object.defineProperty(exports, "Pagination", { enumerable: true, get: function() { return Pagination; } }); var _interop_require_default = require("@swc/helpers/_/_interop_require_default"); var _define_property = require("@swc/helpers/_/_define_property"); var _object_spread = require("@swc/helpers/_/_object_spread"); var _object_spread_props = require("@swc/helpers/_/_object_spread_props"); var _object_without_properties = require("@swc/helpers/_/_object_without_properties"); var _sliced_to_array = require("@swc/helpers/_/_sliced_to_array"); var _react = /*#__PURE__*/ _interop_require_default._(require("react")); var _classnames = /*#__PURE__*/ _interop_require_default._(require("classnames")); var _configprovider = require("../configprovider"); var _usepropsvalue = require("../../hooks/use-props-value"); var _typings = require("../../utils/typings"); var _usepagination = require("../../hooks/use-pagination"); var defaultProps = (0, _object_spread_props._)((0, _object_spread._)({}, _typings.ComponentDefaults), { defaultValue: 1, mode: 'multi', prev: null, next: null, total: 50, pageSize: 10, itemSize: 5, ellipse: false }); var Pagination = function Pagination(props) { var locale = (0, _configprovider.useConfig)().locale; var _ref = (0, _object_spread._)({}, defaultProps, props), value = _ref.value, mode = _ref.mode, prev = _ref.prev, next = _ref.next, total = _ref.total, pageSize = _ref.pageSize, itemSize = _ref.itemSize, onChange = _ref.onChange, ellipse = _ref.ellipse, itemRender = _ref.itemRender, defaultValue = _ref.defaultValue, className = _ref.className, style = _ref.style, rest = (0, _object_without_properties._)(_ref, [ "value", "mode", "prev", "next", "total", "pageSize", "itemSize", "onChange", "ellipse", "itemRender", "defaultValue", "className", "style" ]); var classPrefix = 'nut-pagination'; var _usePropsValue = (0, _sliced_to_array._)((0, _usepropsvalue.usePropsValue)({ value: value, defaultValue: defaultValue, finalValue: 1, onChange: onChange }), 2), current = _usePropsValue[0], setCurrent = _usePropsValue[1]; var _usePagination = (0, _sliced_to_array._)((0, _usepagination.usePagination)({ total: total, ellipse: ellipse, current: current, displayCount: itemSize, itemsPerPage: pageSize }), 2), pages = _usePagination[0], pageCount = _usePagination[1]; var handleClick = function handleClick(item) { if (item.selected) return; if (item.number > pageCount || item.number < 1) return; setCurrent(item.number); }; var prevPage = function prevPage() { var prev = current - 1; prev >= 1 && setCurrent(prev); }; var nextPage = function nextPage() { var next = current + 1; next <= pageCount && setCurrent(next); }; var _obj, _obj1; return /*#__PURE__*/ _react.default.createElement("div", (0, _object_spread._)({ className: (0, _classnames.default)(classPrefix, className) }, rest), (mode === 'multi' || mode === 'simple') && /*#__PURE__*/ _react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/ _react.default.createElement("div", { className: (0, _classnames.default)((_obj = {}, (0, _define_property._)(_obj, "".concat(classPrefix, "-prev"), true), (0, _define_property._)(_obj, "".concat(classPrefix, "-simple-border"), mode !== 'multi'), (0, _define_property._)(_obj, "".concat(classPrefix, "-prev-disabled"), current === 1), _obj)), onClick: function onClick() { return prevPage(); } }, prev || locale.pagination.prev), mode === 'multi' && /*#__PURE__*/ _react.default.createElement("div", { className: "".concat(classPrefix, "-contain") }, pages.map(function(item, index) { var _obj; return /*#__PURE__*/ _react.default.createElement("div", { key: "".concat(index, "pagination"), className: (0, _classnames.default)((_obj = {}, (0, _define_property._)(_obj, "".concat(classPrefix, "-item"), true), (0, _define_property._)(_obj, "".concat(classPrefix, "-item-active"), item.selected), _obj)), onClick: function onClick() { handleClick(item); } }, itemRender ? itemRender(item, current) : item.text); })), mode === 'simple' && /*#__PURE__*/ _react.default.createElement("div", { className: "".concat(classPrefix, "-contain") }, /*#__PURE__*/ _react.default.createElement("div", { className: "".concat(classPrefix, "-simple") }, current, "/", pageCount)), /*#__PURE__*/ _react.default.createElement("div", { className: (0, _classnames.default)((_obj1 = {}, (0, _define_property._)(_obj1, "".concat(classPrefix, "-next"), true), (0, _define_property._)(_obj1, "".concat(classPrefix, "-next-disabled"), current >= pageCount), _obj1)), onClick: function onClick() { return nextPage(); } }, next || locale.pagination.next)), mode === 'lite' && /*#__PURE__*/ _react.default.createElement("div", { className: "".concat(classPrefix, "-lite") }, /*#__PURE__*/ _react.default.createElement("div", { className: "".concat(classPrefix, "-lite-active") }, current), /*#__PURE__*/ _react.default.createElement("div", { className: "".concat(classPrefix, "-lite-spliterator") }, "/"), /*#__PURE__*/ _react.default.createElement("div", { className: "".concat(classPrefix, "-lite-default") }, pageCount))); }; Pagination.displayName = 'NutPagination';