UNPKG

tdesign-vue-next

Version:
526 lines (517 loc) 21.3 kB
/** * tdesign v1.20.2 * (c) 2026 tdesign * @license MIT */ 'use strict'; Object.defineProperty(exports, '__esModule', { value: true }); var Vue = require('vue'); var _objectWithoutProperties = require('@babel/runtime/helpers/objectWithoutProperties'); var _slicedToArray = require('@babel/runtime/helpers/slicedToArray'); var tdesignIconsVueNext = require('tdesign-icons-vue-next'); require('@babel/runtime/helpers/toConsumableArray'); require('@babel/runtime/helpers/typeof'); require('../_chunks/dep-449273df.js'); var index = require('../_chunks/dep-c0cb4d13.js'); var index$3 = require('../_chunks/dep-95cb1381.js'); var index$2 = require('../_chunks/dep-4b52068a.js'); var index$4 = require('../_chunks/dep-88ae5d8a.js'); require('../_chunks/dep-497fc9a5.js'); var index$1 = require('../_chunks/dep-d0227fbe.js'); require('@babel/runtime/helpers/defineProperty'); var inputNumber_index = require('../input-number/index.js'); var select_index = require('../select/index.js'); var inputAdornment_index = require('../input-adornment/index.js'); var pagination_props = require('./props.js'); var pagination_hooks_useMoreAction = require('./hooks/useMoreAction.js'); var pagination_hooks_usePaginationClasses = require('./hooks/usePaginationClasses.js'); var isObject = require('../_chunks/dep-2c7a67b8.js'); var isNumber = require('../_chunks/dep-d20c4e5e.js'); var configProvider_hooks_useConfig = require('../config-provider/hooks/useConfig.js'); require('../_chunks/dep-f9b59444.js'); require('../_chunks/dep-51846987.js'); require('../_chunks/dep-80827572.js'); require('../_chunks/dep-2610df9f.js'); require('../_chunks/dep-be760bc2.js'); require('../_chunks/dep-959f4847.js'); require('../_chunks/dep-6e64ef0e.js'); require('../_chunks/dep-9dfd682d.js'); require('../_chunks/dep-2db31625.js'); require('../_chunks/dep-0a17438d.js'); require('../_chunks/dep-5090b515.js'); require('../_chunks/dep-39313d05.js'); require('../_chunks/dep-f9bc7c82.js'); require('../_chunks/dep-1c6213b5.js'); require('../_chunks/dep-cfdee5e7.js'); require('../_chunks/dep-31abb282.js'); require('../_chunks/dep-c71a9cd7.js'); require('dayjs'); require('../_chunks/dep-39529ef1.js'); require('../_chunks/dep-f4c1cb5b.js'); require('../_chunks/dep-4896d30f.js'); require('../_chunks/dep-db6459dd.js'); require('../_chunks/dep-4d7a3a91.js'); require('../_chunks/dep-ae380218.js'); require('../_chunks/dep-fdac7521.js'); require('@babel/runtime/helpers/createClass'); require('@babel/runtime/helpers/classCallCheck'); require('../input-number/input-number.js'); require('../button/index.js'); require('../button/button.js'); require('../loading/index.js'); require('../_chunks/dep-203a5570.js'); require('../loading/plugin.js'); require('../_chunks/dep-3231adce.js'); require('../loading/icon/gradient.js'); require('../_chunks/dep-e3eb5659.js'); require('../_chunks/dep-cce7af6a.js'); require('../_chunks/dep-6130f266.js'); require('../_chunks/dep-3ffe18b0.js'); require('../_chunks/dep-df5442c5.js'); require('../_chunks/dep-e41b3434.js'); require('../_chunks/dep-9ada3ec1.js'); require('../loading/props.js'); require('../_chunks/dep-141cbae1.js'); require('../_chunks/dep-c277c7cb.js'); require('../_chunks/dep-7653f80f.js'); require('../_chunks/dep-6e7a2100.js'); require('../_chunks/dep-e46285c0.js'); require('../_chunks/dep-54801354.js'); require('../_chunks/dep-bd59ca66.js'); require('../_chunks/dep-f7508ffa.js'); require('../_chunks/dep-470f211b.js'); require('../_chunks/dep-9b549c85.js'); require('../_chunks/dep-e25ae470.js'); require('../_chunks/dep-bed84553.js'); require('../_chunks/dep-a4b963ab.js'); require('../_chunks/dep-abc005aa.js'); require('../button/props.js'); require('../_chunks/dep-a2e46896.js'); require('../_chunks/dep-6512c9d2.js'); require('../_chunks/dep-3cd26986.js'); require('../input/index.js'); require('../input/input.js'); require('../input/props.js'); require('../_chunks/dep-f02d9258.js'); require('../input/hooks/useInput.js'); require('../form/constants/index.js'); require('../input/hooks/useLengthLimit.js'); require('../_chunks/dep-b4528c21.js'); require('../input/hooks/useInputEventHandler.js'); require('../input/hooks/useInputWidth.js'); require('../_chunks/dep-ba2511b0.js'); require('../input/input-group.js'); require('../input/input-group-props.js'); require('../input-number/props.js'); require('../_chunks/dep-5ea73cce.js'); require('../input-number/hooks/useInputNumber.js'); require('../_chunks/dep-74a0ebc2.js'); require('../_chunks/dep-94323f13.js'); require('../_chunks/dep-75d3928f.js'); require('../select/select.js'); require('@babel/runtime/helpers/asyncToGenerator'); require('@babel/runtime/regenerator'); require('../common-components/fake-arrow.js'); require('../select-input/index.js'); require('../select-input/select-input.js'); require('../popup/index.js'); require('../popup/popup.js'); require('@popperjs/core'); require('../popup/container.js'); require('../popup/props.js'); require('../_chunks/dep-4e2a4791.js'); require('../_chunks/dep-f3377589.js'); require('../_chunks/dep-71d9daf0.js'); require('../select-input/props.js'); require('../select-input/hooks/useMultiple.js'); require('../tag-input/index.js'); require('../tag-input/tag-input.js'); require('../tag-input/props.js'); require('../tag-input/hooks/useDragSorter.js'); require('../tag-input/hooks/useHover.js'); require('../tag-input/hooks/useTagScroll.js'); require('../tag-input/hooks/useTagList.js'); require('../tag/index.js'); require('../tag/tag.js'); require('tinycolor2'); require('../tag/props.js'); require('../tag/check-tag.js'); require('../tag/check-tag-props.js'); require('../_chunks/dep-2e8277b1.js'); require('../tag/check-tag-group.js'); require('../tag/check-tag-group-props.js'); require('../select-input/hooks/useOverlayInnerStyle.js'); require('../select-input/hooks/useSingle.js'); require('../_chunks/dep-008d4a55.js'); require('../_chunks/dep-0e1751ee.js'); require('../_chunks/dep-4e2907e0.js'); require('../select/components/select-panel.js'); require('../select/option.js'); require('../select/option-props.js'); require('../checkbox/index.js'); require('../checkbox/checkbox.js'); require('../checkbox/props.js'); require('../checkbox/constants/index.js'); require('../checkbox/hooks/useCheckboxLazyLoad.js'); require('../_chunks/dep-12e6ec24.js'); require('../checkbox/hooks/useKeyboardEvent.js'); require('../checkbox/group.js'); require('../checkbox/checkbox-group-props.js'); require('../_chunks/dep-cec24bbf.js'); require('../_chunks/dep-f786e1df.js'); require('../_chunks/dep-618d56e7.js'); require('../_chunks/dep-2cf25d25.js'); require('../select/utils/index.js'); require('../select/constants/index.js'); require('../select/option-group.js'); require('../select/option-group-props.js'); require('../select/props.js'); require('../select/hooks/usePanelVirtualScroll.js'); require('../_chunks/dep-3a800699.js'); require('../_chunks/dep-648bfb84.js'); require('../select/hooks/useKeyboardControl.js'); require('../select/hooks/useSelectOptions.js'); require('../_chunks/dep-8f2069e9.js'); require('../input-adornment/input-adornment.js'); require('../input-adornment/props.js'); function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; } var _objectWithoutProperties__default = /*#__PURE__*/_interopDefaultLegacy(_objectWithoutProperties); var _slicedToArray__default = /*#__PURE__*/_interopDefaultLegacy(_slicedToArray); /** * Checks if `value` is `NaN`. * * **Note:** This method is based on * [`Number.isNaN`](https://mdn.io/Number/isNaN) and is not the same as * global [`isNaN`](https://mdn.io/isNaN) which returns `true` for * `undefined` and other non-number values. * * @static * @memberOf _ * @since 0.1.0 * @category Lang * @param {*} value The value to check. * @returns {boolean} Returns `true` if `value` is `NaN`, else `false`. * @example * * _.isNaN(NaN); * // => true * * _.isNaN(new Number(NaN)); * // => true * * isNaN(undefined); * // => true * * _.isNaN(undefined); * // => false */ function isNaN(value) { // An `NaN` primitive is the only value that is not equal to itself. // Perform the `toStringTag` check first to avoid errors with some // ActiveX objects in IE. return isNumber.isNumber(value) && value != +value; } var _excluded = ["pageCount"]; var min = 1; var _Pagination = Vue.defineComponent({ name: "TPagination", props: pagination_props["default"], setup: function setup(props2) { var _toRefs = Vue.toRefs(props2), modelValue = _toRefs.modelValue, pageSize = _toRefs.pageSize, current = _toRefs.current; var renderTNodeJSX = index.useTNodeJSX(); var _useVModel = index$1.useVModel(current, modelValue, props2.defaultCurrent, props2.onCurrentChange, "current"), _useVModel2 = _slicedToArray__default["default"](_useVModel, 2), innerCurrent = _useVModel2[0], setInnerCurrent = _useVModel2[1]; var _useDefaultValue = index$2.useDefaultValue(pageSize, props2.defaultPageSize, props2.onPageSizeChange, "pageSize"), _useDefaultValue2 = _slicedToArray__default["default"](_useDefaultValue, 2), innerPageSize = _useDefaultValue2[0], setInnerPageSize = _useDefaultValue2[1]; var _useConfig = configProvider_hooks_useConfig.useConfig("pagination"), t = _useConfig.t, globalConfig = _useConfig.globalConfig; var COMPONENT_NAME = index$3.usePrefixClass("pagination"); var _useGlobalIcon = index$4.useGlobalIcon({ PageFirstIcon: tdesignIconsVueNext.PageFirstIcon, PageLastIcon: tdesignIconsVueNext.PageLastIcon, ChevronLeftIcon: tdesignIconsVueNext.ChevronLeftIcon, ChevronRightIcon: tdesignIconsVueNext.ChevronRightIcon, ChevronLeftDoubleIcon: tdesignIconsVueNext.ChevronLeftDoubleIcon, ChevronRightDoubleIcon: tdesignIconsVueNext.ChevronRightDoubleIcon, EllipsisIcon: tdesignIconsVueNext.EllipsisIcon }), PageFirstIcon = _useGlobalIcon.PageFirstIcon, PageLastIcon = _useGlobalIcon.PageLastIcon, ChevronLeftIcon = _useGlobalIcon.ChevronLeftIcon, ChevronRightIcon = _useGlobalIcon.ChevronRightIcon, ChevronLeftDoubleIcon = _useGlobalIcon.ChevronLeftDoubleIcon, ChevronRightDoubleIcon = _useGlobalIcon.ChevronRightDoubleIcon, EllipsisIcon = _useGlobalIcon.EllipsisIcon; var _usePaginationClasses = pagination_hooks_usePaginationClasses.usePaginationClasses(props2, innerCurrent, innerPageSize, COMPONENT_NAME), pageCount = _usePaginationClasses.pageCount, CLASS_MAP = _objectWithoutProperties__default["default"](_usePaginationClasses, _excluded); var _useMoreAction = pagination_hooks_useMoreAction.useMoreAction(props2, pageCount, innerCurrent), prevMore = _useMoreAction.prevMore, isPrevMoreShow = _useMoreAction.isPrevMoreShow, curPageLeftCount = _useMoreAction.curPageLeftCount, nextMore = _useMoreAction.nextMore, isNextMoreShow = _useMoreAction.isNextMoreShow, curPageRightCount = _useMoreAction.curPageRightCount; var jumpIndex = Vue.ref(innerCurrent.value); var lastEnterJumpTarget = Vue.ref(); var isFolded = Vue.computed(function () { return pageCount.value > props2.maxPageBtn; }); var sizeOptions = Vue.computed(function () { var pageSizeOptions = props2.pageSizeOptions; var options = pageSizeOptions.map(function (option) { return isObject.isObject(option) ? option : { label: t(globalConfig.value.itemsPerPage, { size: option }), value: Number(option) }; }); return options.sort(function (a, b) { return a.value - b.value; }); }); var isMidEllipsis = Vue.computed(function () { return props2.pageEllipsisMode === "mid"; }); var pages = Vue.computed(function () { var array = []; var start; var end; if (isFolded.value) { if (isPrevMoreShow.value && isNextMoreShow.value) { start = innerCurrent.value - curPageLeftCount.value; end = innerCurrent.value + curPageRightCount.value; } else { var foldedStart = isMidEllipsis.value ? 2 : 1; var foldedEnd = isMidEllipsis.value ? pageCount.value - 1 : pageCount.value; if (isPrevMoreShow.value) { start = Math.min(innerCurrent.value - 1, pageCount.value - props2.foldedMaxPageBtn + 1); } else { start = foldedStart; } if (isNextMoreShow.value) { end = Math.max(innerCurrent.value + 1, props2.foldedMaxPageBtn); } else { end = foldedEnd; } } } else { start = 1; end = pageCount.value; } for (var i = start; i <= end; i++) { array.push(i); } return array; }); Vue.watch(function () { return innerCurrent.value; }, function (val) { return jumpIndex.value = val; }); var toPage = function toPage(pageIndex, pageInfo) { var _props2$onChange; if (props2.disabled) { return; } var toPageCurrent = pageIndex; if (pageIndex < min) { toPageCurrent = min; } else if (pageIndex > pageCount.value) { toPageCurrent = pageCount.value; } pageInfo = pageInfo || { current: toPageCurrent, previous: innerCurrent.value, pageSize: innerPageSize.value }; setInnerCurrent(toPageCurrent, pageInfo); (_props2$onChange = props2.onChange) === null || _props2$onChange === void 0 || _props2$onChange.call(props2, pageInfo); }; var handlePageChange = function handlePageChange(type) { var pageChangeMap = { prevPage: function prevPage() { return toPage(innerCurrent.value - 1); }, nextPage: function nextPage() { return toPage(innerCurrent.value + 1); }, prevMorePage: function prevMorePage() { return toPage(Math.max(2, innerCurrent.value - props2.foldedMaxPageBtn)); }, nextMorePage: function nextMorePage() { return toPage(Math.min(innerCurrent.value + props2.foldedMaxPageBtn, pageCount.value - 1)); } }; pageChangeMap[type](); }; var onSelectorChange = function onSelectorChange(val) { if (props2.disabled) return; var pageSize2 = Number(val); var newPageCount = pageSize2 > 0 ? Math.max(Math.ceil(props2.total / pageSize2), 1) : 1; var previousCurrent = innerCurrent.value; var indexExceeds = previousCurrent > newPageCount; setInnerPageSize(pageSize2, { current: indexExceeds ? newPageCount : previousCurrent, previous: previousCurrent, pageSize: pageSize2 }); Vue.nextTick(function () { var userChanged = innerCurrent.value !== previousCurrent; var targetCurrent = userChanged ? innerCurrent.value : indexExceeds ? newPageCount : innerCurrent.value; var pageInfo = { current: targetCurrent, previous: previousCurrent, pageSize: pageSize2 }; if (userChanged || !indexExceeds) { var _props2$onChange2; (_props2$onChange2 = props2.onChange) === null || _props2$onChange2 === void 0 || _props2$onChange2.call(props2, pageInfo); } else { toPage(targetCurrent, pageInfo); } }); }; var getJumperTarget = function getJumperTarget(val) { var currentIndex = Math.trunc(+val); if (isNaN(currentIndex)) return void 0; return Math.min(Math.max(currentIndex, min), pageCount.value); }; var onJumperChange = function onJumperChange(val) { var currentIndex = getJumperTarget(val); if (currentIndex === void 0) return; jumpIndex.value = currentIndex; toPage(currentIndex); }; var onJumperEnter = function onJumperEnter(val) { lastEnterJumpTarget.value = getJumperTarget(val); onJumperChange(val); }; var onJumperBlur = function onJumperBlur(val) { var currentIndex = getJumperTarget(val); if (currentIndex === lastEnterJumpTarget.value) { lastEnterJumpTarget.value = void 0; return; } lastEnterJumpTarget.value = void 0; onJumperChange(val); }; return function () { var total = props2.total, pageSizeOptions = props2.pageSizeOptions, size = props2.size, disabled = props2.disabled, showPageSize = props2.showPageSize; if (pageCount.value < 1) return null; var Jumper = Vue.createVNode("div", { "class": CLASS_MAP.jumperClass.value }, [t(globalConfig.value.jumpTo), Vue.createVNode(inputAdornment_index.InputAdornment, { "append": "/ ".concat(pageCount.value, " ").concat(t(globalConfig.value.page)) }, { "default": function _default() { return [Vue.createVNode(inputNumber_index.InputNumber, { "class": CLASS_MAP.jumperInputClass.value, "modelValue": jumpIndex.value, "onUpdate:modelValue": function onUpdateModelValue($event) { return jumpIndex.value = $event; }, "onBlur": onJumperBlur, "onEnter": onJumperEnter, "max": pageCount.value, "min": min, "size": size, "disabled": disabled, "theme": "normal", "placeholder": "" }, null)]; } })]); return Vue.createVNode("div", { "class": CLASS_MAP.paginationClass.value }, [renderTNodeJSX("totalContent", Vue.createVNode("div", { "class": CLASS_MAP.totalClass.value }, [t(globalConfig.value.total, total)])), showPageSize && pageSizeOptions.length > 0 && Vue.createVNode(select_index.Select, Vue.mergeProps({ "size": size, "value": innerPageSize, "disabled": disabled, "class": CLASS_MAP.sizerClass.value, "autoWidth": true, "onChange": onSelectorChange, "options": sizeOptions.value }, props2.selectProps), null), props2.showFirstAndLastPageBtn ? Vue.createVNode("div", { "class": CLASS_MAP.preBtnClass.value, "onClick": function onClick() { return toPage(1); } }, [Vue.createVNode(PageFirstIcon, null, null)]) : null, props2.showPreviousAndNextBtn ? Vue.createVNode("div", { "class": CLASS_MAP.preBtnClass.value, "onClick": function onClick() { return handlePageChange("prevPage"); } }, [Vue.createVNode(ChevronLeftIcon, null, null)]) : null, props2.showPageNumber && props2.theme === "default" ? Vue.createVNode("ul", { "class": CLASS_MAP.btnWrapClass.value }, [isFolded.value && isMidEllipsis.value && Vue.createVNode("li", { "class": CLASS_MAP.getButtonClass(1), "onClick": function onClick() { return toPage(min); } }, [min]), isFolded.value && isPrevMoreShow.value && isMidEllipsis.value ? Vue.createVNode("li", { "class": CLASS_MAP.btnMoreClass.value, "onClick": function onClick() { return handlePageChange("prevMorePage"); }, "onMouseover": function onMouseover() { return prevMore.value = true; }, "onMouseout": function onMouseout() { return prevMore.value = false; } }, [prevMore.value ? Vue.createVNode(ChevronLeftDoubleIcon, null, null) : Vue.createVNode(EllipsisIcon, null, null)]) : null, pages.value.map(function (i) { return Vue.createVNode("li", { "class": CLASS_MAP.getButtonClass(i), "key": i, "onClick": function onClick() { return toPage(i); } }, [i]); }), isFolded.value && isNextMoreShow.value && isMidEllipsis.value ? Vue.createVNode("li", { "class": CLASS_MAP.btnMoreClass.value, "onClick": function onClick() { return handlePageChange("nextMorePage"); }, "onMouseover": function onMouseover() { return nextMore.value = true; }, "onMouseout": function onMouseout() { return nextMore.value = false; } }, [nextMore.value ? Vue.createVNode(ChevronRightDoubleIcon, null, null) : Vue.createVNode(EllipsisIcon, null, null)]) : null, isFolded.value && isMidEllipsis.value ? Vue.createVNode("li", { "class": CLASS_MAP.getButtonClass(pageCount.value), "onClick": function onClick() { return toPage(pageCount.value); } }, [pageCount.value]) : null]) : null, props2.theme === "simple" && Jumper, props2.showPreviousAndNextBtn ? Vue.createVNode("div", { "class": CLASS_MAP.nextBtnClass.value, "onClick": function onClick() { return handlePageChange("nextPage"); } }, [Vue.createVNode(ChevronRightIcon, null, null)]) : null, props2.showFirstAndLastPageBtn ? Vue.createVNode("div", { "class": CLASS_MAP.nextBtnClass.value, "onClick": function onClick() { return toPage(pageCount.value); } }, [Vue.createVNode(PageLastIcon, null, null)]) : null, props2.theme === "default" && props2.showJumper && Jumper]); }; } }); exports["default"] = _Pagination; //# sourceMappingURL=pagination.js.map