@aplus-frontend/antdv
Version:
Vue basic component library maintained based on ant-design-vue
149 lines • 5.91 kB
JavaScript
import { createTextVNode as _createTextVNode, createVNode as _createVNode } from "vue";
import _extends from "@babel/runtime/helpers/esm/extends";
var __rest = this && this.__rest || function (s, e) {
var t = {};
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
}
return t;
};
import { computed, toRef, defineComponent } from 'vue';
import LeftOutlined from "@ant-design/icons-vue/es/icons/LeftOutlined";
import RightOutlined from "@ant-design/icons-vue/es/icons/RightOutlined";
import DoubleLeftOutlined from "@ant-design/icons-vue/es/icons/DoubleLeftOutlined";
import DoubleRightOutlined from "@ant-design/icons-vue/es/icons/DoubleRightOutlined";
import MiniSelect, { MiddleSelect } from './Select';
import { useLocaleReceiver } from '../locale-provider/LocaleReceiver';
import VcPagination from '../vc-pagination';
import enUS from '../vc-pagination/locale/en_US';
import classNames from '../_util/classNames';
import useConfigInject from '../config-provider/hooks/useConfigInject';
import useBreakpoint from '../_util/hooks/useBreakpoint';
import { booleanType, arrayType, stringType, functionType, someType } from '../_util/type';
// CSSINJS
import useStyle from './style';
export const paginationProps = () => ({
total: Number,
defaultCurrent: Number,
disabled: booleanType(),
current: Number,
defaultPageSize: Number,
pageSize: Number,
hideOnSinglePage: booleanType(),
showSizeChanger: booleanType(),
pageSizeOptions: arrayType(),
buildOptionText: functionType(),
showQuickJumper: someType([Boolean, Object]),
showTotal: functionType(),
size: stringType(),
simple: booleanType(),
locale: Object,
prefixCls: String,
selectPrefixCls: String,
totalBoundaryShowSizeChanger: Number,
selectComponentClass: String,
itemRender: functionType(),
role: String,
responsive: Boolean,
showLessItems: booleanType(),
onChange: functionType(),
onShowSizeChange: functionType(),
'onUpdate:current': functionType(),
'onUpdate:pageSize': functionType()
});
export const paginationConfig = () => _extends(_extends({}, paginationProps()), {
position: stringType()
});
export default defineComponent({
compatConfig: {
MODE: 3
},
name: 'APagination',
inheritAttrs: false,
props: paginationProps(),
// emits: ['change', 'showSizeChange', 'update:current', 'update:pageSize'],
setup(props, _ref) {
let {
slots,
attrs
} = _ref;
const {
prefixCls,
configProvider,
direction,
size
} = useConfigInject('pagination', props);
// style
const [wrapSSR, hashId] = useStyle(prefixCls);
const selectPrefixCls = computed(() => configProvider.getPrefixCls('select', props.selectPrefixCls));
const breakpoint = useBreakpoint();
const [locale] = useLocaleReceiver('Pagination', enUS, toRef(props, 'locale'));
const getIconsProps = pre => {
const ellipsis = _createVNode("span", {
"class": `${pre}-item-ellipsis`
}, [_createTextVNode("\u2022\u2022\u2022")]);
const prevIcon = _createVNode("button", {
"class": `${pre}-item-link`,
"type": "button",
"tabindex": -1
}, [direction.value === 'rtl' ? _createVNode(RightOutlined, null, null) : _createVNode(LeftOutlined, null, null)]);
const nextIcon = _createVNode("button", {
"class": `${pre}-item-link`,
"type": "button",
"tabindex": -1
}, [direction.value === 'rtl' ? _createVNode(LeftOutlined, null, null) : _createVNode(RightOutlined, null, null)]);
const jumpPrevIcon = _createVNode("a", {
"rel": "nofollow",
"class": `${pre}-item-link`
}, [_createVNode("div", {
"class": `${pre}-item-container`
}, [direction.value === 'rtl' ? _createVNode(DoubleRightOutlined, {
"class": `${pre}-item-link-icon`
}, null) : _createVNode(DoubleLeftOutlined, {
"class": `${pre}-item-link-icon`
}, null), ellipsis])]);
const jumpNextIcon = _createVNode("a", {
"rel": "nofollow",
"class": `${pre}-item-link`
}, [_createVNode("div", {
"class": `${pre}-item-container`
}, [direction.value === 'rtl' ? _createVNode(DoubleLeftOutlined, {
"class": `${pre}-item-link-icon`
}, null) : _createVNode(DoubleRightOutlined, {
"class": `${pre}-item-link-icon`
}, null), ellipsis])]);
return {
prevIcon,
nextIcon,
jumpPrevIcon,
jumpNextIcon
};
};
return () => {
var _a;
const {
itemRender = slots.itemRender,
buildOptionText = slots.buildOptionText,
selectComponentClass,
responsive
} = props,
restProps = __rest(props, ["itemRender", "buildOptionText", "selectComponentClass", "responsive"]);
const isSmall = size.value === 'small' || !!(((_a = breakpoint.value) === null || _a === void 0 ? void 0 : _a.xs) && !size.value && responsive);
const paginationProps = _extends(_extends(_extends(_extends(_extends({}, restProps), getIconsProps(prefixCls.value)), {
prefixCls: prefixCls.value,
selectPrefixCls: selectPrefixCls.value,
selectComponentClass: selectComponentClass || (isSmall ? MiniSelect : MiddleSelect),
locale: locale.value,
buildOptionText
}), attrs), {
class: classNames({
[`${prefixCls.value}-mini`]: isSmall,
[`${prefixCls.value}-rtl`]: direction.value === 'rtl'
}, attrs.class, hashId.value),
itemRender
});
return wrapSSR(_createVNode(VcPagination, paginationProps, null));
};
}
});