tdesign-vue-next
Version:
TDesign Component for vue-next
507 lines (498 loc) • 20.6 kB
JavaScript
/**
* tdesign v1.20.0
* (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-0e867224.js');
var index = require('../_chunks/dep-aa87a8f5.js');
var index$3 = require('../_chunks/dep-b9c82189.js');
var index$2 = require('../_chunks/dep-2c6bdc87.js');
var index$4 = require('../_chunks/dep-3a5e066e.js');
require('../_chunks/dep-ce392f73.js');
var index$1 = require('../_chunks/dep-34e686da.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-5c730151.js');
var isNumber = require('../_chunks/dep-631c1469.js');
var configProvider_hooks_useConfig = require('../config-provider/hooks/useConfig.js');
require('../_chunks/dep-b3ef977e.js');
require('../_chunks/dep-aa61e27f.js');
require('../_chunks/dep-cd6733fb.js');
require('../_chunks/dep-caa8987f.js');
require('../_chunks/dep-f549ecb7.js');
require('../_chunks/dep-8e3205d4.js');
require('../_chunks/dep-1da18355.js');
require('../_chunks/dep-4f8e5834.js');
require('../_chunks/dep-b809bbd2.js');
require('../_chunks/dep-08fc313e.js');
require('../_chunks/dep-ff23118f.js');
require('../_chunks/dep-678c34e4.js');
require('../_chunks/dep-950f8e72.js');
require('../_chunks/dep-bf028c39.js');
require('../_chunks/dep-a64c9b8c.js');
require('../_chunks/dep-aafbacfe.js');
require('dayjs');
require('../_chunks/dep-c539b8cf.js');
require('../_chunks/dep-bd404105.js');
require('../_chunks/dep-5ed96ff4.js');
require('../_chunks/dep-b937ef62.js');
require('../_chunks/dep-0ad5a5a6.js');
require('../_chunks/dep-68ca5b5a.js');
require('../_chunks/dep-ce54d478.js');
require('../_chunks/dep-9b493151.js');
require('../_chunks/dep-933eb47e.js');
require('../_chunks/dep-01e6d254.js');
require('../_chunks/dep-d3fa0c96.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-adeb89aa.js');
require('../loading/plugin.js');
require('../_chunks/dep-c1f105f1.js');
require('../loading/icon/gradient.js');
require('../_chunks/dep-b90ea288.js');
require('../_chunks/dep-a500b5f3.js');
require('../_chunks/dep-ce75379a.js');
require('../_chunks/dep-67d3c773.js');
require('../_chunks/dep-6b2b1f80.js');
require('../loading/props.js');
require('../_chunks/dep-5a252af6.js');
require('../_chunks/dep-f4839f43.js');
require('../_chunks/dep-330e6dfc.js');
require('../_chunks/dep-af55a921.js');
require('../_chunks/dep-b995bb39.js');
require('../_chunks/dep-4517d4ed.js');
require('../_chunks/dep-09706c94.js');
require('../_chunks/dep-85b2a790.js');
require('../_chunks/dep-66b8651a.js');
require('../_chunks/dep-b6ea336e.js');
require('../_chunks/dep-b8c6ffbe.js');
require('../_chunks/dep-4c394c9f.js');
require('../_chunks/dep-69de6962.js');
require('../_chunks/dep-654cced3.js');
require('../button/props.js');
require('../_chunks/dep-d3e2e950.js');
require('../_chunks/dep-c7627f80.js');
require('../_chunks/dep-514a65fd.js');
require('../input/index.js');
require('../input/input.js');
require('../input/props.js');
require('../_chunks/dep-5858b58f.js');
require('../input/hooks/useInput.js');
require('../form/constants/index.js');
require('../input/hooks/useLengthLimit.js');
require('../_chunks/dep-193c4be1.js');
require('../input/hooks/useInputEventHandler.js');
require('../input/hooks/useInputWidth.js');
require('../_chunks/dep-b2523c38.js');
require('../input/input-group.js');
require('../input/input-group-props.js');
require('../input-number/props.js');
require('../_chunks/dep-dcc5ca03.js');
require('../input-number/hooks/useInputNumber.js');
require('../_chunks/dep-8c1f583f.js');
require('../_chunks/dep-fbb091b8.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-d25a9147.js');
require('../_chunks/dep-d7e01c93.js');
require('../_chunks/dep-62080f94.js');
require('../_chunks/dep-382db868.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-f6c6e123.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-1f641c4f.js');
require('../_chunks/dep-8ae7b699.js');
require('../_chunks/dep-f0cb3461.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-2199d5ef.js');
require('../checkbox/hooks/useKeyboardEvent.js');
require('../checkbox/group.js');
require('../checkbox/checkbox-group-props.js');
require('../_chunks/dep-b63ae774.js');
require('../_chunks/dep-2655508e.js');
require('../_chunks/dep-680b807b.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-ff124dc0.js');
require('../_chunks/dep-858b9fa8.js');
require('../select/hooks/useKeyboardControl.js');
require('../select/hooks/useSelectOptions.js');
require('../_chunks/dep-4162650e.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 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 onJumperChange = function onJumperChange(val) {
var currentIndex = Math.trunc(+val);
if (isNaN(currentIndex)) return;
jumpIndex.value = currentIndex;
toPage(currentIndex);
};
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": onJumperChange,
"onEnter": onJumperChange,
"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