tdesign-vue-next
Version:
TDesign Component for vue-next
526 lines (517 loc) • 21.3 kB
JavaScript
/**
* tdesign v1.20.2
* (c) 2026 tdesign
* @license MIT
*/
;
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