@aplus-frontend/antdv
Version:
Vue basic component library maintained based on ant-design-vue
161 lines (158 loc) • 7.81 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.paginationProps = exports.paginationConfig = exports.default = void 0;
var _vue = require("vue");
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _LeftOutlined = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/LeftOutlined"));
var _RightOutlined = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/RightOutlined"));
var _DoubleLeftOutlined = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/DoubleLeftOutlined"));
var _DoubleRightOutlined = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/DoubleRightOutlined"));
var _Select = _interopRequireWildcard(require("./Select"));
var _LocaleReceiver = require("../locale-provider/LocaleReceiver");
var _vcPagination = _interopRequireDefault(require("../vc-pagination"));
var _en_US = _interopRequireDefault(require("../vc-pagination/locale/en_US"));
var _classNames = _interopRequireDefault(require("../_util/classNames"));
var _useConfigInject = _interopRequireDefault(require("../config-provider/hooks/useConfigInject"));
var _useBreakpoint = _interopRequireDefault(require("../_util/hooks/useBreakpoint"));
var _type = require("../_util/type");
var _style = _interopRequireDefault(require("./style"));
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
var __rest = void 0 && (void 0).__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;
};
// CSSINJS
const paginationProps = () => ({
total: Number,
defaultCurrent: Number,
disabled: (0, _type.booleanType)(),
current: Number,
defaultPageSize: Number,
pageSize: Number,
hideOnSinglePage: (0, _type.booleanType)(),
showSizeChanger: (0, _type.booleanType)(),
pageSizeOptions: (0, _type.arrayType)(),
buildOptionText: (0, _type.functionType)(),
showQuickJumper: (0, _type.someType)([Boolean, Object]),
showTotal: (0, _type.functionType)(),
size: (0, _type.stringType)(),
simple: (0, _type.booleanType)(),
locale: Object,
prefixCls: String,
selectPrefixCls: String,
totalBoundaryShowSizeChanger: Number,
selectComponentClass: String,
itemRender: (0, _type.functionType)(),
role: String,
responsive: Boolean,
showLessItems: (0, _type.booleanType)(),
onChange: (0, _type.functionType)(),
onShowSizeChange: (0, _type.functionType)(),
'onUpdate:current': (0, _type.functionType)(),
'onUpdate:pageSize': (0, _type.functionType)()
});
exports.paginationProps = paginationProps;
const paginationConfig = () => (0, _extends2.default)((0, _extends2.default)({}, paginationProps()), {
position: (0, _type.stringType)()
});
exports.paginationConfig = paginationConfig;
var _default = exports.default = (0, _vue.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
} = (0, _useConfigInject.default)('pagination', props);
// style
const [wrapSSR, hashId] = (0, _style.default)(prefixCls);
const selectPrefixCls = (0, _vue.computed)(() => configProvider.getPrefixCls('select', props.selectPrefixCls));
const breakpoint = (0, _useBreakpoint.default)();
const [locale] = (0, _LocaleReceiver.useLocaleReceiver)('Pagination', _en_US.default, (0, _vue.toRef)(props, 'locale'));
const getIconsProps = pre => {
const ellipsis = (0, _vue.createVNode)("span", {
"class": `${pre}-item-ellipsis`
}, [(0, _vue.createTextVNode)("\u2022\u2022\u2022")]);
const prevIcon = (0, _vue.createVNode)("button", {
"class": `${pre}-item-link`,
"type": "button",
"tabindex": -1
}, [direction.value === 'rtl' ? (0, _vue.createVNode)(_RightOutlined.default, null, null) : (0, _vue.createVNode)(_LeftOutlined.default, null, null)]);
const nextIcon = (0, _vue.createVNode)("button", {
"class": `${pre}-item-link`,
"type": "button",
"tabindex": -1
}, [direction.value === 'rtl' ? (0, _vue.createVNode)(_LeftOutlined.default, null, null) : (0, _vue.createVNode)(_RightOutlined.default, null, null)]);
const jumpPrevIcon = (0, _vue.createVNode)("a", {
"rel": "nofollow",
"class": `${pre}-item-link`
}, [(0, _vue.createVNode)("div", {
"class": `${pre}-item-container`
}, [direction.value === 'rtl' ? (0, _vue.createVNode)(_DoubleRightOutlined.default, {
"class": `${pre}-item-link-icon`
}, null) : (0, _vue.createVNode)(_DoubleLeftOutlined.default, {
"class": `${pre}-item-link-icon`
}, null), ellipsis])]);
const jumpNextIcon = (0, _vue.createVNode)("a", {
"rel": "nofollow",
"class": `${pre}-item-link`
}, [(0, _vue.createVNode)("div", {
"class": `${pre}-item-container`
}, [direction.value === 'rtl' ? (0, _vue.createVNode)(_DoubleLeftOutlined.default, {
"class": `${pre}-item-link-icon`
}, null) : (0, _vue.createVNode)(_DoubleRightOutlined.default, {
"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 = (0, _extends2.default)((0, _extends2.default)((0, _extends2.default)((0, _extends2.default)((0, _extends2.default)({}, restProps), getIconsProps(prefixCls.value)), {
prefixCls: prefixCls.value,
selectPrefixCls: selectPrefixCls.value,
selectComponentClass: selectComponentClass || (isSmall ? _Select.default : _Select.MiddleSelect),
locale: locale.value,
buildOptionText
}), attrs), {
class: (0, _classNames.default)({
[`${prefixCls.value}-mini`]: isSmall,
[`${prefixCls.value}-rtl`]: direction.value === 'rtl'
}, attrs.class, hashId.value),
itemRender
});
return wrapSSR((0, _vue.createVNode)(_vcPagination.default, paginationProps, null));
};
}
});
;