UNPKG

tdesign-vue-next

Version:
425 lines (421 loc) 16.8 kB
/** * tdesign v1.11.5 * (c) 2025 tdesign * @license MIT */ import _objectWithoutProperties from '@babel/runtime/helpers/objectWithoutProperties'; import _slicedToArray from '@babel/runtime/helpers/slicedToArray'; import { defineComponent, getCurrentInstance, toRefs, ref, computed, watch, createVNode, mergeProps } from 'vue'; import { isObject, isNaN } from 'lodash-es'; import { PageFirstIcon, PageLastIcon, ChevronLeftIcon, ChevronRightIcon, ChevronLeftDoubleIcon, ChevronRightDoubleIcon, EllipsisIcon } from 'tdesign-icons-vue-next'; import { usePrefixClass } from '../hooks/useConfig.js'; import { useGlobalIcon } from '../hooks/useGlobalIcon.js'; import { InputNumber } from '../input-number/index.js'; import { Select } from '../select/index.js'; import { InputAdornment } from '../input-adornment/index.js'; import props from './props.js'; import { useMoreAction } from './hooks/useMoreAction.js'; import { usePaginationClasses } from './hooks/usePaginationClasses.js'; import useVModel from '../hooks/useVModel.js'; import useDefaultValue from '../hooks/useDefaultValue.js'; import { u as useTNodeJSX } from '../_chunks/dep-7c56a7f5.js'; import { useConfig } from '../config-provider/hooks/useConfig.js'; import '../input-number/input-number.js'; import '@babel/runtime/helpers/defineProperty'; import '../button/index.js'; import '../button/button.js'; import '@babel/runtime/helpers/toConsumableArray'; import '../loading/index.js'; import '../loading/directive.js'; import '../loading/plugin.js'; import '../loading/loading.js'; import '../loading/icon/gradient.js'; import '../_chunks/dep-d60f6309.js'; import '../_chunks/dep-56c3d46e.js'; import '../utils/dom.js'; import '../_chunks/dep-caecb55d.js'; import '../hooks/useTeleport.js'; import '../loading/props.js'; import '../utils/render-tnode.js'; import '../config-provider/utils/context.js'; import '../_chunks/dep-c75b9b8e.js'; import '@babel/runtime/helpers/typeof'; import 'dayjs'; import '../utils/withInstall.js'; import '../button/props.js'; import '../hooks/useRipple.js'; import '../hooks/useKeepAnimation.js'; import '../hooks/useDisabled.js'; import '../input/index.js'; import '../input/input.js'; import '../input/props.js'; import '../hooks/useReadonly.js'; import '../input/hooks/useInput.js'; import '../form/consts/index.js'; import '../input/hooks/useLengthLimit.js'; import '../_chunks/dep-92106726.js'; import '../input/hooks/useInputEventHandler.js'; import '../input/hooks/useInputWidth.js'; import '../hooks/useResizeObserver.js'; import '../input/input-group.js'; import '../input/input-group-props.js'; import '../input-number/props.js'; import '../input-number/hooks/useInputNumber.js'; import '../hooks/useCommonClassName.js'; import '../_chunks/dep-55df6a6c.js'; import '../_chunks/dep-8b9d07bf.js'; import '../select/select.js'; import '@babel/runtime/helpers/asyncToGenerator'; import '@babel/runtime/regenerator'; import '../common-components/fake-arrow.js'; import '../select-input/index.js'; import '../select-input/select-input.js'; import '../popup/index.js'; import '../popup/popup.js'; import '@popperjs/core'; import '../popup/container.js'; import '../popup/props.js'; import '../select-input/props.js'; import '../select-input/hooks/useMultiple.js'; import '../tag-input/index.js'; import '../tag-input/tag-input.js'; import '../tag-input/props.js'; import '../tag-input/hooks/useDragSorter.js'; import '../tag-input/hooks/useHover.js'; import '../tag-input/hooks/useTagScroll.js'; import '../tag-input/hooks/useTagList.js'; import '../tag/index.js'; import '../tag/tag.js'; import 'tinycolor2'; import '../tag/props.js'; import '../tag/check-tag.js'; import '../tag/check-tag-props.js'; import '../_chunks/dep-d2f3d117.js'; import '../tag/check-tag-group.js'; import '../tag/check-tag-group-props.js'; import '../select-input/hooks/useOverlayInnerStyle.js'; import '../select-input/hooks/useSingle.js'; import '../select/select-panel.js'; import '../select/option.js'; import '../select/option-props.js'; import '../checkbox/index.js'; import '../checkbox/checkbox.js'; import '../checkbox/props.js'; import '../checkbox/consts/index.js'; import '../checkbox/hooks/useCheckboxLazyLoad.js'; import '../_chunks/dep-8c2d2d85.js'; import '../checkbox/hooks/useKeyboardEvent.js'; import '../checkbox/group.js'; import '../checkbox/checkbox-group-props.js'; import '../hooks/slot.js'; import '../select/utils/index.js'; import '../select/consts/index.js'; import '../select/option-group.js'; import '../select/option-group-props.js'; import '../select/props.js'; import '../select/hooks/usePanelVirtualScroll.js'; import '../hooks/useVirtualScroll.js'; import '../select/hooks/useKeyboardControl.js'; import '../select/hooks/useSelectOptions.js'; import '../input-adornment/input-adornment.js'; import '../input-adornment/props.js'; var _excluded = ["pageCount"]; var min = 1; var _Pagination = defineComponent({ name: "TPagination", props: props, setup: function setup(props2) { var _getCurrentInstance = getCurrentInstance(), emit = _getCurrentInstance.emit; var _toRefs = toRefs(props2), modelValue = _toRefs.modelValue, pageSize = _toRefs.pageSize, current = _toRefs.current; var renderTNodeJSX = useTNodeJSX(); var _useVModel = useVModel(current, modelValue, props2.defaultCurrent, props2.onCurrentChange, "current"), _useVModel2 = _slicedToArray(_useVModel, 2), innerCurrent = _useVModel2[0], setInnerCurrent = _useVModel2[1]; var _useDefaultValue = useDefaultValue(pageSize, props2.defaultPageSize, props2.onPageSizeChange, "pageSize"), _useDefaultValue2 = _slicedToArray(_useDefaultValue, 2), innerPageSize = _useDefaultValue2[0], setInnerPageSize = _useDefaultValue2[1]; var _useConfig = useConfig("pagination"), t = _useConfig.t, globalConfig = _useConfig.globalConfig; var COMPONENT_NAME = usePrefixClass("pagination"); var _useGlobalIcon = useGlobalIcon({ PageFirstIcon: PageFirstIcon, PageLastIcon: PageLastIcon, ChevronLeftIcon: ChevronLeftIcon, ChevronRightIcon: ChevronRightIcon, ChevronLeftDoubleIcon: ChevronLeftDoubleIcon, ChevronRightDoubleIcon: ChevronRightDoubleIcon, EllipsisIcon: EllipsisIcon }), PageFirstIcon$1 = _useGlobalIcon.PageFirstIcon, PageLastIcon$1 = _useGlobalIcon.PageLastIcon, ChevronLeftIcon$1 = _useGlobalIcon.ChevronLeftIcon, ChevronRightIcon$1 = _useGlobalIcon.ChevronRightIcon, ChevronLeftDoubleIcon$1 = _useGlobalIcon.ChevronLeftDoubleIcon, ChevronRightDoubleIcon$1 = _useGlobalIcon.ChevronRightDoubleIcon, EllipsisIcon$1 = _useGlobalIcon.EllipsisIcon; var _usePaginationClasses = usePaginationClasses(props2, innerCurrent, innerPageSize, COMPONENT_NAME), pageCount = _usePaginationClasses.pageCount, CLASS_MAP = _objectWithoutProperties(_usePaginationClasses, _excluded); var _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 = ref(innerCurrent.value); var isFolded = computed(function () { return pageCount.value > props2.maxPageBtn; }); var sizeOptions = computed(function () { var pageSizeOptions = props2.pageSizeOptions; var options = pageSizeOptions.map(function (option) { return 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 = computed(function () { return props2.pageEllipsisMode === "mid"; }); var pages = 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; }); watch(function () { return pageCount.value; }, function () { if (innerCurrent.value > pageCount.value) innerCurrent.value = 1; }); watch(function () { return innerCurrent.value; }, function (val) { return jumpIndex.value = val; }); var toPage = function toPage(pageIndex, pageInfo) { if (props2.disabled) { return; } var current2 = pageIndex; if (pageIndex < min) { current2 = min; } else if (pageIndex > pageCount.value) { current2 = pageCount.value; } if (innerCurrent.value !== current2) { var prev = innerCurrent.value; pageInfo = pageInfo || { current: current2, previous: prev, pageSize: innerPageSize.value }; if (pageInfo) { var _props2$onChange; setInnerCurrent(current2, pageInfo); (_props2$onChange = props2.onChange) === null || _props2$onChange === void 0 || _props2$onChange.call(props2, pageInfo); } else { emit("update:modelValue", current2); } } }; 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(e) { if (props2.disabled) { return; } var pageSize2 = parseInt(e, 10); var pageCount2 = 1; if (pageSize2 > 0) { pageCount2 = Math.max(Math.ceil(props2.total / pageSize2), 1); } var isIndexChange = false; if (innerCurrent.value > pageCount2) { isIndexChange = true; } var pageInfo = { current: isIndexChange ? pageCount2 : innerCurrent.value, previous: innerCurrent.value, pageSize: pageSize2 }; setInnerPageSize(pageSize2, pageInfo); if (isIndexChange) { toPage(pageCount2, pageInfo); } else { var _props2$onChange2; (_props2$onChange2 = props2.onChange) === null || _props2$onChange2 === void 0 || _props2$onChange2.call(props2, 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 = createVNode("div", { "class": CLASS_MAP.jumperClass.value }, [t(globalConfig.value.jumpTo), createVNode(InputAdornment, { "append": "/ ".concat(pageCount.value, " ").concat(t(globalConfig.value.page)) }, { "default": function _default() { return [createVNode(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 createVNode("div", { "class": CLASS_MAP.paginationClass.value }, [renderTNodeJSX("totalContent", createVNode("div", { "class": CLASS_MAP.totalClass.value }, [t(globalConfig.value.total, { total: total })])), showPageSize && pageSizeOptions.length > 0 && createVNode(Select, mergeProps({ "size": size, "value": innerPageSize, "disabled": disabled, "class": CLASS_MAP.sizerClass.value, "autoWidth": true, "onChange": onSelectorChange, "options": sizeOptions.value }, props2.selectProps), null), props2.showFirstAndLastPageBtn ? createVNode("div", { "class": CLASS_MAP.preBtnClass.value, "onClick": function onClick() { return toPage(1); } }, [createVNode(PageFirstIcon$1, null, null)]) : null, props2.showPreviousAndNextBtn ? createVNode("div", { "class": CLASS_MAP.preBtnClass.value, "onClick": function onClick() { return handlePageChange("prevPage"); } }, [createVNode(ChevronLeftIcon$1, null, null)]) : null, props2.showPageNumber && props2.theme === "default" ? createVNode("ul", { "class": CLASS_MAP.btnWrapClass.value }, [isFolded.value && isMidEllipsis.value && createVNode("li", { "class": CLASS_MAP.getButtonClass(1), "onClick": function onClick() { return toPage(min); } }, [min]), isFolded.value && isPrevMoreShow.value && isMidEllipsis.value ? 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 ? createVNode(ChevronLeftDoubleIcon$1, null, null) : createVNode(EllipsisIcon$1, null, null)]) : null, pages.value.map(function (i) { return createVNode("li", { "class": CLASS_MAP.getButtonClass(i), "key": i, "onClick": function onClick() { return toPage(i); } }, [i]); }), isFolded.value && isNextMoreShow.value && isMidEllipsis.value ? 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 ? createVNode(ChevronRightDoubleIcon$1, null, null) : createVNode(EllipsisIcon$1, null, null)]) : null, isFolded.value && isMidEllipsis.value ? 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 ? createVNode("div", { "class": CLASS_MAP.nextBtnClass.value, "onClick": function onClick() { return handlePageChange("nextPage"); } }, [createVNode(ChevronRightIcon$1, null, null)]) : null, props2.showFirstAndLastPageBtn ? createVNode("div", { "class": CLASS_MAP.nextBtnClass.value, "onClick": function onClick() { return toPage(pageCount.value); } }, [createVNode(PageLastIcon$1, null, null)]) : null, props2.theme === "default" && props2.showJumper && Jumper]); }; } }); export { _Pagination as default }; //# sourceMappingURL=pagination.js.map