Pagination.js 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  1. "use strict";
  2. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
  3. Object.defineProperty(exports, "__esModule", {
  4. value: true
  5. });
  6. exports.paginationProps = exports.paginationConfig = exports.default = void 0;
  7. var _vue = require("vue");
  8. var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
  9. var _LeftOutlined = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/LeftOutlined"));
  10. var _RightOutlined = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/RightOutlined"));
  11. var _DoubleLeftOutlined = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/DoubleLeftOutlined"));
  12. var _DoubleRightOutlined = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/DoubleRightOutlined"));
  13. var _Select = _interopRequireWildcard(require("./Select"));
  14. var _LocaleReceiver = require("../locale-provider/LocaleReceiver");
  15. var _vcPagination = _interopRequireDefault(require("../vc-pagination"));
  16. var _en_US = _interopRequireDefault(require("../vc-pagination/locale/en_US"));
  17. var _classNames = _interopRequireDefault(require("../_util/classNames"));
  18. var _useConfigInject = _interopRequireDefault(require("../config-provider/hooks/useConfigInject"));
  19. var _useBreakpoint = _interopRequireDefault(require("../_util/hooks/useBreakpoint"));
  20. var _type = require("../_util/type");
  21. var _style = _interopRequireDefault(require("./style"));
  22. 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); }
  23. 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 && Object.prototype.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; }
  24. var __rest = void 0 && (void 0).__rest || function (s, e) {
  25. var t = {};
  26. for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
  27. if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
  28. if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
  29. }
  30. return t;
  31. };
  32. // CSSINJS
  33. const paginationProps = () => ({
  34. total: Number,
  35. defaultCurrent: Number,
  36. disabled: (0, _type.booleanType)(),
  37. current: Number,
  38. defaultPageSize: Number,
  39. pageSize: Number,
  40. hideOnSinglePage: (0, _type.booleanType)(),
  41. showSizeChanger: (0, _type.booleanType)(),
  42. pageSizeOptions: (0, _type.arrayType)(),
  43. buildOptionText: (0, _type.functionType)(),
  44. showQuickJumper: (0, _type.someType)([Boolean, Object]),
  45. showTotal: (0, _type.functionType)(),
  46. size: (0, _type.stringType)(),
  47. simple: (0, _type.booleanType)(),
  48. locale: Object,
  49. prefixCls: String,
  50. selectPrefixCls: String,
  51. totalBoundaryShowSizeChanger: Number,
  52. selectComponentClass: String,
  53. itemRender: (0, _type.functionType)(),
  54. role: String,
  55. responsive: Boolean,
  56. showLessItems: (0, _type.booleanType)(),
  57. onChange: (0, _type.functionType)(),
  58. onShowSizeChange: (0, _type.functionType)(),
  59. 'onUpdate:current': (0, _type.functionType)(),
  60. 'onUpdate:pageSize': (0, _type.functionType)()
  61. });
  62. exports.paginationProps = paginationProps;
  63. const paginationConfig = () => (0, _extends2.default)((0, _extends2.default)({}, paginationProps()), {
  64. position: (0, _type.stringType)()
  65. });
  66. exports.paginationConfig = paginationConfig;
  67. var _default = exports.default = (0, _vue.defineComponent)({
  68. compatConfig: {
  69. MODE: 3
  70. },
  71. name: 'APagination',
  72. inheritAttrs: false,
  73. props: paginationProps(),
  74. // emits: ['change', 'showSizeChange', 'update:current', 'update:pageSize'],
  75. setup(props, _ref) {
  76. let {
  77. slots,
  78. attrs
  79. } = _ref;
  80. const {
  81. prefixCls,
  82. configProvider,
  83. direction,
  84. size
  85. } = (0, _useConfigInject.default)('pagination', props);
  86. // style
  87. const [wrapSSR, hashId] = (0, _style.default)(prefixCls);
  88. const selectPrefixCls = (0, _vue.computed)(() => configProvider.getPrefixCls('select', props.selectPrefixCls));
  89. const breakpoint = (0, _useBreakpoint.default)();
  90. const [locale] = (0, _LocaleReceiver.useLocaleReceiver)('Pagination', _en_US.default, (0, _vue.toRef)(props, 'locale'));
  91. const getIconsProps = pre => {
  92. const ellipsis = (0, _vue.createVNode)("span", {
  93. "class": `${pre}-item-ellipsis`
  94. }, [(0, _vue.createTextVNode)("\u2022\u2022\u2022")]);
  95. const prevIcon = (0, _vue.createVNode)("button", {
  96. "class": `${pre}-item-link`,
  97. "type": "button",
  98. "tabindex": -1
  99. }, [direction.value === 'rtl' ? (0, _vue.createVNode)(_RightOutlined.default, null, null) : (0, _vue.createVNode)(_LeftOutlined.default, null, null)]);
  100. const nextIcon = (0, _vue.createVNode)("button", {
  101. "class": `${pre}-item-link`,
  102. "type": "button",
  103. "tabindex": -1
  104. }, [direction.value === 'rtl' ? (0, _vue.createVNode)(_LeftOutlined.default, null, null) : (0, _vue.createVNode)(_RightOutlined.default, null, null)]);
  105. const jumpPrevIcon = (0, _vue.createVNode)("a", {
  106. "rel": "nofollow",
  107. "class": `${pre}-item-link`
  108. }, [(0, _vue.createVNode)("div", {
  109. "class": `${pre}-item-container`
  110. }, [direction.value === 'rtl' ? (0, _vue.createVNode)(_DoubleRightOutlined.default, {
  111. "class": `${pre}-item-link-icon`
  112. }, null) : (0, _vue.createVNode)(_DoubleLeftOutlined.default, {
  113. "class": `${pre}-item-link-icon`
  114. }, null), ellipsis])]);
  115. const jumpNextIcon = (0, _vue.createVNode)("a", {
  116. "rel": "nofollow",
  117. "class": `${pre}-item-link`
  118. }, [(0, _vue.createVNode)("div", {
  119. "class": `${pre}-item-container`
  120. }, [direction.value === 'rtl' ? (0, _vue.createVNode)(_DoubleLeftOutlined.default, {
  121. "class": `${pre}-item-link-icon`
  122. }, null) : (0, _vue.createVNode)(_DoubleRightOutlined.default, {
  123. "class": `${pre}-item-link-icon`
  124. }, null), ellipsis])]);
  125. return {
  126. prevIcon,
  127. nextIcon,
  128. jumpPrevIcon,
  129. jumpNextIcon
  130. };
  131. };
  132. return () => {
  133. var _a;
  134. const {
  135. itemRender = slots.itemRender,
  136. buildOptionText = slots.buildOptionText,
  137. selectComponentClass,
  138. responsive
  139. } = props,
  140. restProps = __rest(props, ["itemRender", "buildOptionText", "selectComponentClass", "responsive"]);
  141. const isSmall = size.value === 'small' || !!(((_a = breakpoint.value) === null || _a === void 0 ? void 0 : _a.xs) && !size.value && responsive);
  142. const paginationProps = (0, _extends2.default)((0, _extends2.default)((0, _extends2.default)((0, _extends2.default)((0, _extends2.default)({}, restProps), getIconsProps(prefixCls.value)), {
  143. prefixCls: prefixCls.value,
  144. selectPrefixCls: selectPrefixCls.value,
  145. selectComponentClass: selectComponentClass || (isSmall ? _Select.default : _Select.MiddleSelect),
  146. locale: locale.value,
  147. buildOptionText
  148. }), attrs), {
  149. class: (0, _classNames.default)({
  150. [`${prefixCls.value}-mini`]: isSmall,
  151. [`${prefixCls.value}-rtl`]: direction.value === 'rtl'
  152. }, attrs.class, hashId.value),
  153. itemRender
  154. });
  155. return wrapSSR((0, _vue.createVNode)(_vcPagination.default, paginationProps, null));
  156. };
  157. }
  158. });