Socket
Socket
Sign inDemoInstall

@uiw/react-pagination

Package Overview
Dependencies
Maintainers
1
Versions
171
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@uiw/react-pagination - npm Package Compare versions

Comparing version 4.8.0 to 4.8.1

11

lib/cjs/index.d.ts

@@ -1,2 +0,2 @@

import React from 'react';
/// <reference types="react" />
import { IProps, HTMLUlProps } from '@uiw/utils';

@@ -24,9 +24,2 @@ import './style/index.less';

}
export default class Pagination extends React.Component<PaginationProps, PaginationState> {
static defaultProps: PaginationProps;
constructor(props: PaginationProps);
UNSAFE_componentWillReceiveProps(nextProps: PaginationProps): void;
onClick(item: PaginationItemSourceData): void;
initPageSoure(): PaginationItemSourceData[];
render(): JSX.Element;
}
export default function Pagination(props: PaginationProps): JSX.Element;

328

lib/cjs/index.js

@@ -5,234 +5,188 @@ "use strict";

var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
exports.default = Pagination;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
var _react = _interopRequireWildcard(require("react"));
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _excluded = ["className", "prefixCls", "alignment", "size", "total", "pageSize", "current", "onChange", "divider"];
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
function Pagination(props) {
var className = props.className,
_props$prefixCls = props.prefixCls,
prefixCls = _props$prefixCls === void 0 ? 'w-pagination' : _props$prefixCls,
_props$alignment = props.alignment,
alignment = _props$alignment === void 0 ? 'left' : _props$alignment,
_props$size = props.size,
size = _props$size === void 0 ? 'default' : _props$size,
_props$total = props.total,
total = _props$total === void 0 ? 0 : _props$total,
_props$pageSize = props.pageSize,
pageSize = _props$pageSize === void 0 ? 10 : _props$pageSize,
_props$current = props.current,
currentNumber = _props$current === void 0 ? 1 : _props$current,
_props$onChange = props.onChange,
onChange = _props$onChange === void 0 ? function () {
return null;
} : _props$onChange,
divider = props.divider,
other = (0, _objectWithoutProperties2.default)(props, _excluded);
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _useState = (0, _react.useState)(currentNumber),
_useState2 = (0, _slicedToArray2.default)(_useState, 2),
current = _useState2[0],
setCurrent = _useState2[1];
var _createSuper2 = _interopRequireDefault(require("@babel/runtime/helpers/createSuper"));
(0, _react.useEffect)(function () {
return setCurrent(currentNumber);
}, [currentNumber]);
var cls = [prefixCls, className, divider ? 'divider' : null, size].filter(Boolean).join(' ').trim();
var initPageSoure = (0, _react.useMemo)(function () {
var data = [{
type: 'prev',
disabled: current === 1
}];
var count = Math.ceil(total / pageSize);
var itemCount = count <= 5 ? count : 5;
var num = 0;
var basic = 0;
var _react = _interopRequireDefault(require("react"));
if (current > 3 && count > 5) {
data.push({
label: 1
});
}
var _excluded = ["prefixCls", "className", "total", "current", "pageSize", "size", "alignment", "divider", "onChange"];
if (current > 4 && count > 6) {
data.push({
type: 'jumpPrev',
label: '•••',
goto: 5
});
}
var Pagination = /*#__PURE__*/function (_React$Component) {
(0, _inherits2.default)(Pagination, _React$Component);
while (num < itemCount) {
num += 1;
var _super = (0, _createSuper2.default)(Pagination);
function Pagination(props) {
var _this;
(0, _classCallCheck2.default)(this, Pagination);
_this = _super.call(this, props);
_this.state = {
current: props.current
};
return _this;
}
(0, _createClass2.default)(Pagination, [{
key: "UNSAFE_componentWillReceiveProps",
value: function UNSAFE_componentWillReceiveProps(nextProps) {
if (nextProps.current !== this.props.current) {
this.setState({
current: nextProps.current
});
if (current > 3 && count > 5) {
basic = current - 3;
}
}
}, {
key: "onClick",
value: function onClick(item) {
var _this2 = this;
if (item.active || item.disabled) {
return;
}
var label = num + basic;
var _this$props = this.props,
total = _this$props.total,
pageSize = _this$props.pageSize,
onChange = _this$props.onChange;
var current = this.state.current;
var count = Math.ceil(total / pageSize);
var state = {};
if (item.label) {
state.current = item.label;
if (count - current === 0 && count > 5) {
label -= 2;
}
if (item.type === 'prev') {
state.current = current - 1 > 0 ? current - 1 : 1;
if (count - current === 1 && count > 5) {
label -= 1;
}
if (item.type === 'next') {
state.current = current + 1 <= count ? current + 1 : count;
if (label <= count) {
data.push({
label: label,
active: current === label
});
}
}
if (/^(jumpPrev|jumpNext)/.test(item.type) && item.goto) {
state.current = item.type === 'jumpPrev' ? current - item.goto : current + item.goto;
if (current + 3 < count && count > 6) {
data.push({
type: 'jumpNext',
label: '•••',
goto: 5
});
}
if (state.current > count) {
state.current = count;
}
if (state.current < 1) {
state.current = 1;
}
}
this.setState((0, _objectSpread2.default)({}, state), function () {
onChange && onChange(_this2.state.current, total, pageSize);
if (current + 2 < count && count > 5) {
data.push({
label: count
});
}
}, {
key: "initPageSoure",
value: function initPageSoure() {
var _this$props2 = this.props,
total = _this$props2.total,
pageSize = _this$props2.pageSize;
var current = this.state.current;
var data = [{
type: 'prev',
disabled: current === 1
}];
var count = Math.ceil(total / pageSize);
var itemCount = count <= 5 ? count : 5;
var num = 0;
var basic = 0;
if (current > 3 && count > 5) {
data.push({
label: 1
});
}
data.push({
type: 'next',
disabled: current === count
});
return data; // return [
// { type: 'prev', disabled: true },
// { type: 'jumpPrev', label: '•••', goto: 5 },
// { label: 1 },
// { label: 2, active: true },
// { label: 3 },
// { label: 4 },
// { type: 'jumpPrev', label: '•••', goto: 5 },
// { type: 'next' },
// ];
}, [current, total, pageSize]);
if (current > 4 && count > 6) {
data.push({
type: 'jumpPrev',
label: '•••',
goto: 5
});
}
function handleClick(item) {
if (item.active || item.disabled) {
return;
}
while (num < itemCount) {
num += 1;
var count = Math.ceil(total / pageSize);
var state = {};
if (current > 3 && count > 5) {
basic = current - 3;
}
if (item.label) {
state.current = item.label;
}
var label = num + basic;
if (item.type === 'prev') {
state.current = current - 1 > 0 ? current - 1 : 1;
}
if (count - current === 0 && count > 5) {
label -= 2;
}
if (item.type === 'next') {
state.current = current + 1 <= count ? current + 1 : count;
}
if (count - current === 1 && count > 5) {
label -= 1;
}
if (/^(jumpPrev|jumpNext)/.test(item.type) && item.goto) {
state.current = item.type === 'jumpPrev' ? current - item.goto : current + item.goto;
if (label <= count) {
data.push({
label: label,
active: current === label
});
}
if (state.current > count) {
state.current = count;
}
if (current + 3 < count && count > 6) {
data.push({
type: 'jumpNext',
label: '•••',
goto: 5
});
if (state.current < 1) {
state.current = 1;
}
}
if (current + 2 < count && count > 5) {
data.push({
label: count
});
}
setCurrent(state.current);
onChange && onChange(state.current, total, pageSize);
}
data.push({
type: 'next',
disabled: current === count
return /*#__PURE__*/_react.default.createElement("ul", (0, _extends2.default)({
className: cls
}, other), initPageSoure.map(function (item, idx) {
// eslint-disable-next-line jsx-a11y/anchor-is-valid
var label = /*#__PURE__*/_react.default.createElement("a", null, item.label);
if (/^(prev|next)$/.test(item.type)) {
// eslint-disable-next-line jsx-a11y/anchor-is-valid
label = /*#__PURE__*/_react.default.createElement("a", {
className: "arrow ".concat(item.type)
});
return data; // return [
// { type: 'prev', disabled: true },
// { type: 'jumpPrev', label: '•••', goto: 5 },
// { label: 1 },
// { label: 2, active: true },
// { label: 3 },
// { label: 4 },
// { type: 'jumpPrev', label: '•••', goto: 5 },
// { type: 'next' },
// ];
}
}, {
key: "render",
value: function render() {
var _this3 = this;
var _this$props3 = this.props,
prefixCls = _this$props3.prefixCls,
className = _this$props3.className,
total = _this$props3.total,
current = _this$props3.current,
pageSize = _this$props3.pageSize,
size = _this$props3.size,
alignment = _this$props3.alignment,
divider = _this$props3.divider,
onChange = _this$props3.onChange,
other = (0, _objectWithoutProperties2.default)(_this$props3, _excluded);
var cls = [prefixCls, className, divider ? 'divider' : null, size].filter(Boolean).join(' ').trim();
return /*#__PURE__*/_react.default.createElement("ul", (0, _extends2.default)({
className: cls
}, other), this.initPageSoure().map(function (item, idx) {
// eslint-disable-next-line jsx-a11y/anchor-is-valid
var label = /*#__PURE__*/_react.default.createElement("a", null, item.label);
return /*#__PURE__*/_react.default.createElement("li", {
className: [item.active ? 'active' : null, item.disabled ? 'disabled' : null].filter(Boolean).join(' ').trim(),
onClick: function onClick() {
return handleClick(item);
},
key: idx
}, label);
}));
}
if (/^(prev|next)$/.test(item.type)) {
// eslint-disable-next-line jsx-a11y/anchor-is-valid
label = /*#__PURE__*/_react.default.createElement("a", {
className: "arrow ".concat(item.type)
});
}
return /*#__PURE__*/_react.default.createElement("li", {
className: [item.active ? 'active' : null, item.disabled ? 'disabled' : null].filter(Boolean).join(' ').trim(),
onClick: _this3.onClick.bind(_this3, item),
key: idx
}, label);
}));
}
}]);
return Pagination;
}(_react.default.Component);
exports.default = Pagination;
Pagination.defaultProps = {
prefixCls: 'w-pagination',
alignment: 'left',
size: 'default',
total: 0,
pageSize: 10,
// The number of pages displayed.
current: 1,
onChange: function onChange() {
return null;
}
};
module.exports = exports.default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/index.tsx"],"names":["Pagination","props","state","current","nextProps","setState","item","active","disabled","total","pageSize","onChange","count","Math","ceil","label","type","test","goto","data","itemCount","num","basic","push","prefixCls","className","size","alignment","divider","other","cls","filter","Boolean","join","trim","initPageSoure","map","idx","onClick","bind","React","Component","defaultProps"],"mappings":"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","sourcesContent":["/* eslint-disable jsx-a11y/anchor-has-content */\nimport React from 'react';\nimport { IProps, HTMLUlProps } from '@uiw/utils';\nimport './style/index.less';\n\nexport interface PaginationProps extends IProps, Omit<HTMLUlProps, 'onChange'> {\n  prefixCls?: string;\n  alignment?: 'left' | 'center' | 'right';\n  size?: 'default' | 'small';\n  total?: number;\n  pageSize?: number;\n  divider?: boolean;\n  current?: number;\n  onChange?: (current: number, total: number, pageSize: number) => void;\n}\n\nexport interface PaginationState {\n  current: number;\n}\n\nexport interface PaginationItemSourceData {\n  type?: string;\n  disabled?: boolean;\n  active?: boolean;\n  label?: number | string;\n  goto?: number;\n}\n\nexport default class Pagination extends React.Component<\n  PaginationProps,\n  PaginationState\n> {\n  public static defaultProps: PaginationProps = {\n    prefixCls: 'w-pagination',\n    alignment: 'left',\n    size: 'default',\n    total: 0,\n    pageSize: 10, // The number of pages displayed.\n    current: 1,\n    onChange: () => null,\n  };\n  constructor(props: PaginationProps) {\n    super(props);\n    this.state = {\n      current: props.current as number,\n    };\n  }\n  UNSAFE_componentWillReceiveProps(nextProps: PaginationProps) {\n    if (nextProps.current !== this.props.current) {\n      this.setState({\n        current: nextProps.current as number,\n      });\n    }\n  }\n  onClick(item: PaginationItemSourceData) {\n    if (item.active || item.disabled) {\n      return;\n    }\n    const { total, pageSize, onChange } = this.props;\n    const { current } = this.state;\n    const count = Math.ceil((total as number) / (pageSize as number));\n    const state = {} as PaginationState;\n    if (item.label) {\n      state.current = item.label as number;\n    }\n    if (item.type === 'prev') {\n      state.current = current - 1 > 0 ? current - 1 : 1;\n    }\n    if (item.type === 'next') {\n      state.current = current + 1 <= count ? current + 1 : count;\n    }\n    if (/^(jumpPrev|jumpNext)/.test(item.type as string) && item.goto) {\n      state.current =\n        item.type === 'jumpPrev' ? current - item.goto : current + item.goto;\n      if (state.current > count) {\n        state.current = count;\n      }\n      if (state.current < 1) {\n        state.current = 1;\n      }\n    }\n    this.setState({ ...state }, () => {\n      onChange &&\n        onChange(this.state.current, total as number, pageSize as number);\n    });\n  }\n  initPageSoure(): PaginationItemSourceData[] {\n    const { total, pageSize } = this.props;\n    const { current } = this.state;\n    const data: PaginationItemSourceData[] = [\n      { type: 'prev', disabled: current === 1 },\n    ];\n    const count = Math.ceil((total as number) / (pageSize as number));\n    const itemCount = count <= 5 ? count : 5;\n    let num = 0;\n    let basic = 0;\n    if (current > 3 && count > 5) {\n      data.push({ label: 1 });\n    }\n    if (current > 4 && count > 6) {\n      data.push({ type: 'jumpPrev', label: '•••', goto: 5 });\n    }\n    while (num < itemCount) {\n      num += 1;\n      if (current > 3 && count > 5) {\n        basic = current - 3;\n      }\n      let label = num + basic;\n      if (count - current === 0 && count > 5) {\n        label -= 2;\n      }\n      if (count - current === 1 && count > 5) {\n        label -= 1;\n      }\n      if (label <= count) {\n        data.push({ label, active: current === label });\n      }\n    }\n    if (current + 3 < count && count > 6) {\n      data.push({ type: 'jumpNext', label: '•••', goto: 5 });\n    }\n    if (current + 2 < count && count > 5) {\n      data.push({ label: count });\n    }\n    data.push({ type: 'next', disabled: current === count });\n    return data;\n    // return [\n    //   { type: 'prev', disabled: true },\n    //   { type: 'jumpPrev', label: '•••', goto: 5 },\n    //   { label: 1 },\n    //   { label: 2, active: true },\n    //   { label: 3 },\n    //   { label: 4 },\n    //   { type: 'jumpPrev', label: '•••', goto: 5 },\n    //   { type: 'next' },\n    // ];\n  }\n  render() {\n    const {\n      prefixCls,\n      className,\n      total,\n      current,\n      pageSize,\n      size,\n      alignment,\n      divider,\n      onChange,\n      ...other\n    } = this.props;\n    const cls = [prefixCls, className, divider ? 'divider' : null, size]\n      .filter(Boolean)\n      .join(' ')\n      .trim();\n    return (\n      <ul className={cls} {...other}>\n        {this.initPageSoure().map((item: PaginationItemSourceData, idx) => {\n          // eslint-disable-next-line jsx-a11y/anchor-is-valid\n          let label = <a>{item.label}</a>;\n          if (/^(prev|next)$/.test(item.type as string)) {\n            // eslint-disable-next-line jsx-a11y/anchor-is-valid\n            label = <a className={`arrow ${item.type}`} />;\n          }\n          return (\n            <li\n              className={[\n                item.active ? 'active' : null,\n                item.disabled ? 'disabled' : null,\n              ]\n                .filter(Boolean)\n                .join(' ')\n                .trim()}\n              onClick={this.onClick.bind(this, item)}\n              key={idx}\n            >\n              {label}\n            </li>\n          );\n        })}\n      </ul>\n    );\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/index.tsx"],"names":["Pagination","props","className","prefixCls","alignment","size","total","pageSize","current","currentNumber","onChange","divider","other","setCurrent","cls","filter","Boolean","join","trim","initPageSoure","data","type","disabled","count","Math","ceil","itemCount","num","basic","push","label","goto","active","handleClick","item","state","test","map","idx"],"mappings":"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","sourcesContent":["import React, { useEffect, useMemo, useState } from 'react';\nimport { IProps, HTMLUlProps } from '@uiw/utils';\nimport './style/index.less';\n\nexport interface PaginationProps extends IProps, Omit<HTMLUlProps, 'onChange'> {\n  prefixCls?: string;\n  alignment?: 'left' | 'center' | 'right';\n  size?: 'default' | 'small';\n  total?: number;\n  pageSize?: number;\n  divider?: boolean;\n  current?: number;\n  onChange?: (current: number, total: number, pageSize: number) => void;\n}\n\nexport interface PaginationState {\n  current: number;\n}\n\nexport interface PaginationItemSourceData {\n  type?: string;\n  disabled?: boolean;\n  active?: boolean;\n  label?: number | string;\n  goto?: number;\n}\n\nexport default function Pagination(props: PaginationProps) {\n  const {\n    className,\n    prefixCls = 'w-pagination',\n    alignment = 'left',\n    size = 'default',\n    total = 0,\n    pageSize = 10, // The number of pages displayed.\n    current: currentNumber = 1,\n    onChange = () => null,\n    divider,\n    ...other\n  } = props;\n\n  const [current, setCurrent] = useState(currentNumber);\n  useEffect(() => setCurrent(currentNumber), [currentNumber]);\n\n  const cls = [prefixCls, className, divider ? 'divider' : null, size]\n    .filter(Boolean)\n    .join(' ')\n    .trim();\n\n  const initPageSoure = useMemo(() => {\n    const data: PaginationItemSourceData[] = [\n      { type: 'prev', disabled: current === 1 },\n    ];\n    const count = Math.ceil(total / pageSize);\n    const itemCount = count <= 5 ? count : 5;\n    let num = 0;\n    let basic = 0;\n    if (current > 3 && count > 5) {\n      data.push({ label: 1 });\n    }\n    if (current > 4 && count > 6) {\n      data.push({ type: 'jumpPrev', label: '•••', goto: 5 });\n    }\n    while (num < itemCount) {\n      num += 1;\n      if (current > 3 && count > 5) {\n        basic = current - 3;\n      }\n      let label = num + basic;\n      if (count - current === 0 && count > 5) {\n        label -= 2;\n      }\n      if (count - current === 1 && count > 5) {\n        label -= 1;\n      }\n      if (label <= count) {\n        data.push({ label, active: current === label });\n      }\n    }\n    if (current + 3 < count && count > 6) {\n      data.push({ type: 'jumpNext', label: '•••', goto: 5 });\n    }\n    if (current + 2 < count && count > 5) {\n      data.push({ label: count });\n    }\n    data.push({ type: 'next', disabled: current === count });\n    return data;\n    // return [\n    //   { type: 'prev', disabled: true },\n    //   { type: 'jumpPrev', label: '•••', goto: 5 },\n    //   { label: 1 },\n    //   { label: 2, active: true },\n    //   { label: 3 },\n    //   { label: 4 },\n    //   { type: 'jumpPrev', label: '•••', goto: 5 },\n    //   { type: 'next' },\n    // ];\n  }, [current, total, pageSize]);\n\n  function handleClick(item: PaginationItemSourceData) {\n    if (item.active || item.disabled) {\n      return;\n    }\n    const count = Math.ceil(total / pageSize);\n    const state = {} as PaginationState;\n    if (item.label) {\n      state.current = item.label as number;\n    }\n    if (item.type === 'prev') {\n      state.current = current - 1 > 0 ? current - 1 : 1;\n    }\n    if (item.type === 'next') {\n      state.current = current + 1 <= count ? current + 1 : count;\n    }\n    if (/^(jumpPrev|jumpNext)/.test(item.type as string) && item.goto) {\n      state.current =\n        item.type === 'jumpPrev' ? current - item.goto : current + item.goto;\n      if (state.current > count) {\n        state.current = count;\n      }\n      if (state.current < 1) {\n        state.current = 1;\n      }\n    }\n\n    setCurrent(state.current);\n    onChange && onChange(state.current, total as number, pageSize as number);\n  }\n\n  return (\n    <ul className={cls} {...other}>\n      {initPageSoure.map((item: PaginationItemSourceData, idx) => {\n        // eslint-disable-next-line jsx-a11y/anchor-is-valid\n        let label = <a>{item.label}</a>;\n        if (/^(prev|next)$/.test(item.type as string)) {\n          // eslint-disable-next-line jsx-a11y/anchor-is-valid\n          label = <a className={`arrow ${item.type}`} />;\n        }\n        return (\n          <li\n            className={[\n              item.active ? 'active' : null,\n              item.disabled ? 'disabled' : null,\n            ]\n              .filter(Boolean)\n              .join(' ')\n              .trim()}\n            onClick={() => handleClick(item)}\n            key={idx}\n          >\n            {label}\n          </li>\n        );\n      })}\n    </ul>\n  );\n}\n"]}

@@ -1,2 +0,2 @@

import React from 'react';
/// <reference types="react" />
import { IProps, HTMLUlProps } from '@uiw/utils';

@@ -24,9 +24,2 @@ import './style/index.less';

}
export default class Pagination extends React.Component<PaginationProps, PaginationState> {
static defaultProps: PaginationProps;
constructor(props: PaginationProps);
UNSAFE_componentWillReceiveProps(nextProps: PaginationProps): void;
onClick(item: PaginationItemSourceData): void;
initPageSoure(): PaginationItemSourceData[];
render(): JSX.Element;
}
export default function Pagination(props: PaginationProps): JSX.Element;
import _extends from "@babel/runtime/helpers/extends";
import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
import _objectSpread from "@babel/runtime/helpers/objectSpread2";
import _classCallCheck from "@babel/runtime/helpers/classCallCheck";
import _createClass from "@babel/runtime/helpers/createClass";
import _inherits from "@babel/runtime/helpers/inherits";
import _createSuper from "@babel/runtime/helpers/createSuper";
var _excluded = ["prefixCls", "className", "total", "current", "pageSize", "size", "alignment", "divider", "onChange"];
/* eslint-disable jsx-a11y/anchor-has-content */
import React from 'react';
var _excluded = ["className", "prefixCls", "alignment", "size", "total", "pageSize", "current", "onChange", "divider"];
import React, { useEffect, useMemo, useState } from 'react';
import "./style/index.css";
export default function Pagination(props) {
var className = props.className,
_props$prefixCls = props.prefixCls,
prefixCls = _props$prefixCls === void 0 ? 'w-pagination' : _props$prefixCls,
_props$alignment = props.alignment,
alignment = _props$alignment === void 0 ? 'left' : _props$alignment,
_props$size = props.size,
size = _props$size === void 0 ? 'default' : _props$size,
_props$total = props.total,
total = _props$total === void 0 ? 0 : _props$total,
_props$pageSize = props.pageSize,
pageSize = _props$pageSize === void 0 ? 10 : _props$pageSize,
_props$current = props.current,
currentNumber = _props$current === void 0 ? 1 : _props$current,
_props$onChange = props.onChange,
onChange = _props$onChange === void 0 ? function () {
return null;
} : _props$onChange,
divider = props.divider,
other = _objectWithoutProperties(props, _excluded);
var Pagination = /*#__PURE__*/function (_React$Component) {
_inherits(Pagination, _React$Component);
var _useState = useState(currentNumber),
_useState2 = _slicedToArray(_useState, 2),
current = _useState2[0],
setCurrent = _useState2[1];
var _super = _createSuper(Pagination);
useEffect(function () {
return setCurrent(currentNumber);
}, [currentNumber]);
var cls = [prefixCls, className, divider ? 'divider' : null, size].filter(Boolean).join(' ').trim();
var initPageSoure = useMemo(function () {
var data = [{
type: 'prev',
disabled: current === 1
}];
var count = Math.ceil(total / pageSize);
var itemCount = count <= 5 ? count : 5;
var num = 0;
var basic = 0;
function Pagination(props) {
var _this;
if (current > 3 && count > 5) {
data.push({
label: 1
});
}
_classCallCheck(this, Pagination);
if (current > 4 && count > 6) {
data.push({
type: 'jumpPrev',
label: '•••',
goto: 5
});
}
_this = _super.call(this, props);
_this.state = {
current: props.current
};
return _this;
}
while (num < itemCount) {
num += 1;
_createClass(Pagination, [{
key: "UNSAFE_componentWillReceiveProps",
value: function UNSAFE_componentWillReceiveProps(nextProps) {
if (nextProps.current !== this.props.current) {
this.setState({
current: nextProps.current
});
if (current > 3 && count > 5) {
basic = current - 3;
}
}
}, {
key: "onClick",
value: function onClick(item) {
var _this2 = this;
if (item.active || item.disabled) {
return;
}
var label = num + basic;
var _this$props = this.props,
total = _this$props.total,
pageSize = _this$props.pageSize,
onChange = _this$props.onChange;
var current = this.state.current;
var count = Math.ceil(total / pageSize);
var state = {};
if (item.label) {
state.current = item.label;
if (count - current === 0 && count > 5) {
label -= 2;
}
if (item.type === 'prev') {
state.current = current - 1 > 0 ? current - 1 : 1;
if (count - current === 1 && count > 5) {
label -= 1;
}
if (item.type === 'next') {
state.current = current + 1 <= count ? current + 1 : count;
if (label <= count) {
data.push({
label: label,
active: current === label
});
}
}
if (/^(jumpPrev|jumpNext)/.test(item.type) && item.goto) {
state.current = item.type === 'jumpPrev' ? current - item.goto : current + item.goto;
if (current + 3 < count && count > 6) {
data.push({
type: 'jumpNext',
label: '•••',
goto: 5
});
}
if (state.current > count) {
state.current = count;
}
if (state.current < 1) {
state.current = 1;
}
}
this.setState(_objectSpread({}, state), function () {
onChange && onChange(_this2.state.current, total, pageSize);
if (current + 2 < count && count > 5) {
data.push({
label: count
});
}
}, {
key: "initPageSoure",
value: function initPageSoure() {
var _this$props2 = this.props,
total = _this$props2.total,
pageSize = _this$props2.pageSize;
var current = this.state.current;
var data = [{
type: 'prev',
disabled: current === 1
}];
var count = Math.ceil(total / pageSize);
var itemCount = count <= 5 ? count : 5;
var num = 0;
var basic = 0;
if (current > 3 && count > 5) {
data.push({
label: 1
});
}
data.push({
type: 'next',
disabled: current === count
});
return data; // return [
// { type: 'prev', disabled: true },
// { type: 'jumpPrev', label: '•••', goto: 5 },
// { label: 1 },
// { label: 2, active: true },
// { label: 3 },
// { label: 4 },
// { type: 'jumpPrev', label: '•••', goto: 5 },
// { type: 'next' },
// ];
}, [current, total, pageSize]);
if (current > 4 && count > 6) {
data.push({
type: 'jumpPrev',
label: '•••',
goto: 5
});
}
function handleClick(item) {
if (item.active || item.disabled) {
return;
}
while (num < itemCount) {
num += 1;
var count = Math.ceil(total / pageSize);
var state = {};
if (current > 3 && count > 5) {
basic = current - 3;
}
if (item.label) {
state.current = item.label;
}
var label = num + basic;
if (item.type === 'prev') {
state.current = current - 1 > 0 ? current - 1 : 1;
}
if (count - current === 0 && count > 5) {
label -= 2;
}
if (item.type === 'next') {
state.current = current + 1 <= count ? current + 1 : count;
}
if (count - current === 1 && count > 5) {
label -= 1;
}
if (/^(jumpPrev|jumpNext)/.test(item.type) && item.goto) {
state.current = item.type === 'jumpPrev' ? current - item.goto : current + item.goto;
if (label <= count) {
data.push({
label: label,
active: current === label
});
}
if (state.current > count) {
state.current = count;
}
if (current + 3 < count && count > 6) {
data.push({
type: 'jumpNext',
label: '•••',
goto: 5
});
if (state.current < 1) {
state.current = 1;
}
if (current + 2 < count && count > 5) {
data.push({
label: count
});
}
data.push({
type: 'next',
disabled: current === count
});
return data; // return [
// { type: 'prev', disabled: true },
// { type: 'jumpPrev', label: '•••', goto: 5 },
// { label: 1 },
// { label: 2, active: true },
// { label: 3 },
// { label: 4 },
// { type: 'jumpPrev', label: '•••', goto: 5 },
// { type: 'next' },
// ];
}
}, {
key: "render",
value: function render() {
var _this3 = this;
var _this$props3 = this.props,
prefixCls = _this$props3.prefixCls,
className = _this$props3.className,
total = _this$props3.total,
current = _this$props3.current,
pageSize = _this$props3.pageSize,
size = _this$props3.size,
alignment = _this$props3.alignment,
divider = _this$props3.divider,
onChange = _this$props3.onChange,
other = _objectWithoutProperties(_this$props3, _excluded);
setCurrent(state.current);
onChange && onChange(state.current, total, pageSize);
}
var cls = [prefixCls, className, divider ? 'divider' : null, size].filter(Boolean).join(' ').trim();
return /*#__PURE__*/React.createElement("ul", _extends({
className: cls
}, other), this.initPageSoure().map(function (item, idx) {
// eslint-disable-next-line jsx-a11y/anchor-is-valid
var label = /*#__PURE__*/React.createElement("a", null, item.label);
return /*#__PURE__*/React.createElement("ul", _extends({
className: cls
}, other), initPageSoure.map(function (item, idx) {
// eslint-disable-next-line jsx-a11y/anchor-is-valid
var label = /*#__PURE__*/React.createElement("a", null, item.label);
if (/^(prev|next)$/.test(item.type)) {
// eslint-disable-next-line jsx-a11y/anchor-is-valid
label = /*#__PURE__*/React.createElement("a", {
className: "arrow ".concat(item.type)
});
}
return /*#__PURE__*/React.createElement("li", {
className: [item.active ? 'active' : null, item.disabled ? 'disabled' : null].filter(Boolean).join(' ').trim(),
onClick: _this3.onClick.bind(_this3, item),
key: idx
}, label);
}));
if (/^(prev|next)$/.test(item.type)) {
// eslint-disable-next-line jsx-a11y/anchor-is-valid
label = /*#__PURE__*/React.createElement("a", {
className: "arrow ".concat(item.type)
});
}
}]);
return Pagination;
}(React.Component);
Pagination.defaultProps = {
prefixCls: 'w-pagination',
alignment: 'left',
size: 'default',
total: 0,
pageSize: 10,
// The number of pages displayed.
current: 1,
onChange: function onChange() {
return null;
}
};
export { Pagination as default };
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/index.tsx"],"names":["React","Pagination","props","state","current","nextProps","setState","item","active","disabled","total","pageSize","onChange","count","Math","ceil","label","type","test","goto","data","itemCount","num","basic","push","prefixCls","className","size","alignment","divider","other","cls","filter","Boolean","join","trim","initPageSoure","map","idx","onClick","bind","Component","defaultProps"],"mappings":";;;;;;;;;AAAA;AACA,OAAOA,KAAP,MAAkB,OAAlB;AAEA;;IAyBqBC,U;;;;;AAanB,sBAAYC,KAAZ,EAAoC;AAAA;;AAAA;;AAClC,8BAAMA,KAAN;AACA,UAAKC,KAAL,GAAa;AACXC,MAAAA,OAAO,EAAEF,KAAK,CAACE;AADJ,KAAb;AAFkC;AAKnC;;;;WACD,0CAAiCC,SAAjC,EAA6D;AAC3D,UAAIA,SAAS,CAACD,OAAV,KAAsB,KAAKF,KAAL,CAAWE,OAArC,EAA8C;AAC5C,aAAKE,QAAL,CAAc;AACZF,UAAAA,OAAO,EAAEC,SAAS,CAACD;AADP,SAAd;AAGD;AACF;;;WACD,iBAAQG,IAAR,EAAwC;AAAA;;AACtC,UAAIA,IAAI,CAACC,MAAL,IAAeD,IAAI,CAACE,QAAxB,EAAkC;AAChC;AACD;;AACD,wBAAsC,KAAKP,KAA3C;AAAA,UAAQQ,KAAR,eAAQA,KAAR;AAAA,UAAeC,QAAf,eAAeA,QAAf;AAAA,UAAyBC,QAAzB,eAAyBA,QAAzB;AACA,UAAQR,OAAR,GAAoB,KAAKD,KAAzB,CAAQC,OAAR;AACA,UAAMS,KAAK,GAAGC,IAAI,CAACC,IAAL,CAAWL,KAAD,GAAqBC,QAA/B,CAAd;AACA,UAAMR,KAAK,GAAG,EAAd;;AACA,UAAII,IAAI,CAACS,KAAT,EAAgB;AACdb,QAAAA,KAAK,CAACC,OAAN,GAAgBG,IAAI,CAACS,KAArB;AACD;;AACD,UAAIT,IAAI,CAACU,IAAL,KAAc,MAAlB,EAA0B;AACxBd,QAAAA,KAAK,CAACC,OAAN,GAAgBA,OAAO,GAAG,CAAV,GAAc,CAAd,GAAkBA,OAAO,GAAG,CAA5B,GAAgC,CAAhD;AACD;;AACD,UAAIG,IAAI,CAACU,IAAL,KAAc,MAAlB,EAA0B;AACxBd,QAAAA,KAAK,CAACC,OAAN,GAAgBA,OAAO,GAAG,CAAV,IAAeS,KAAf,GAAuBT,OAAO,GAAG,CAAjC,GAAqCS,KAArD;AACD;;AACD,UAAI,uBAAuBK,IAAvB,CAA4BX,IAAI,CAACU,IAAjC,KAAoDV,IAAI,CAACY,IAA7D,EAAmE;AACjEhB,QAAAA,KAAK,CAACC,OAAN,GACEG,IAAI,CAACU,IAAL,KAAc,UAAd,GAA2Bb,OAAO,GAAGG,IAAI,CAACY,IAA1C,GAAiDf,OAAO,GAAGG,IAAI,CAACY,IADlE;;AAEA,YAAIhB,KAAK,CAACC,OAAN,GAAgBS,KAApB,EAA2B;AACzBV,UAAAA,KAAK,CAACC,OAAN,GAAgBS,KAAhB;AACD;;AACD,YAAIV,KAAK,CAACC,OAAN,GAAgB,CAApB,EAAuB;AACrBD,UAAAA,KAAK,CAACC,OAAN,GAAgB,CAAhB;AACD;AACF;;AACD,WAAKE,QAAL,mBAAmBH,KAAnB,GAA4B,YAAM;AAChCS,QAAAA,QAAQ,IACNA,QAAQ,CAAC,MAAI,CAACT,KAAL,CAAWC,OAAZ,EAAqBM,KAArB,EAAsCC,QAAtC,CADV;AAED,OAHD;AAID;;;WACD,yBAA4C;AAC1C,yBAA4B,KAAKT,KAAjC;AAAA,UAAQQ,KAAR,gBAAQA,KAAR;AAAA,UAAeC,QAAf,gBAAeA,QAAf;AACA,UAAQP,OAAR,GAAoB,KAAKD,KAAzB,CAAQC,OAAR;AACA,UAAMgB,IAAgC,GAAG,CACvC;AAAEH,QAAAA,IAAI,EAAE,MAAR;AAAgBR,QAAAA,QAAQ,EAAEL,OAAO,KAAK;AAAtC,OADuC,CAAzC;AAGA,UAAMS,KAAK,GAAGC,IAAI,CAACC,IAAL,CAAWL,KAAD,GAAqBC,QAA/B,CAAd;AACA,UAAMU,SAAS,GAAGR,KAAK,IAAI,CAAT,GAAaA,KAAb,GAAqB,CAAvC;AACA,UAAIS,GAAG,GAAG,CAAV;AACA,UAAIC,KAAK,GAAG,CAAZ;;AACA,UAAInB,OAAO,GAAG,CAAV,IAAeS,KAAK,GAAG,CAA3B,EAA8B;AAC5BO,QAAAA,IAAI,CAACI,IAAL,CAAU;AAAER,UAAAA,KAAK,EAAE;AAAT,SAAV;AACD;;AACD,UAAIZ,OAAO,GAAG,CAAV,IAAeS,KAAK,GAAG,CAA3B,EAA8B;AAC5BO,QAAAA,IAAI,CAACI,IAAL,CAAU;AAAEP,UAAAA,IAAI,EAAE,UAAR;AAAoBD,UAAAA,KAAK,EAAE,KAA3B;AAAkCG,UAAAA,IAAI,EAAE;AAAxC,SAAV;AACD;;AACD,aAAOG,GAAG,GAAGD,SAAb,EAAwB;AACtBC,QAAAA,GAAG,IAAI,CAAP;;AACA,YAAIlB,OAAO,GAAG,CAAV,IAAeS,KAAK,GAAG,CAA3B,EAA8B;AAC5BU,UAAAA,KAAK,GAAGnB,OAAO,GAAG,CAAlB;AACD;;AACD,YAAIY,KAAK,GAAGM,GAAG,GAAGC,KAAlB;;AACA,YAAIV,KAAK,GAAGT,OAAR,KAAoB,CAApB,IAAyBS,KAAK,GAAG,CAArC,EAAwC;AACtCG,UAAAA,KAAK,IAAI,CAAT;AACD;;AACD,YAAIH,KAAK,GAAGT,OAAR,KAAoB,CAApB,IAAyBS,KAAK,GAAG,CAArC,EAAwC;AACtCG,UAAAA,KAAK,IAAI,CAAT;AACD;;AACD,YAAIA,KAAK,IAAIH,KAAb,EAAoB;AAClBO,UAAAA,IAAI,CAACI,IAAL,CAAU;AAAER,YAAAA,KAAK,EAALA,KAAF;AAASR,YAAAA,MAAM,EAAEJ,OAAO,KAAKY;AAA7B,WAAV;AACD;AACF;;AACD,UAAIZ,OAAO,GAAG,CAAV,GAAcS,KAAd,IAAuBA,KAAK,GAAG,CAAnC,EAAsC;AACpCO,QAAAA,IAAI,CAACI,IAAL,CAAU;AAAEP,UAAAA,IAAI,EAAE,UAAR;AAAoBD,UAAAA,KAAK,EAAE,KAA3B;AAAkCG,UAAAA,IAAI,EAAE;AAAxC,SAAV;AACD;;AACD,UAAIf,OAAO,GAAG,CAAV,GAAcS,KAAd,IAAuBA,KAAK,GAAG,CAAnC,EAAsC;AACpCO,QAAAA,IAAI,CAACI,IAAL,CAAU;AAAER,UAAAA,KAAK,EAAEH;AAAT,SAAV;AACD;;AACDO,MAAAA,IAAI,CAACI,IAAL,CAAU;AAAEP,QAAAA,IAAI,EAAE,MAAR;AAAgBR,QAAAA,QAAQ,EAAEL,OAAO,KAAKS;AAAtC,OAAV;AACA,aAAOO,IAAP,CAvC0C,CAwC1C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACD;;;WACD,kBAAS;AAAA;;AACP,yBAWI,KAAKlB,KAXT;AAAA,UACEuB,SADF,gBACEA,SADF;AAAA,UAEEC,SAFF,gBAEEA,SAFF;AAAA,UAGEhB,KAHF,gBAGEA,KAHF;AAAA,UAIEN,OAJF,gBAIEA,OAJF;AAAA,UAKEO,QALF,gBAKEA,QALF;AAAA,UAMEgB,IANF,gBAMEA,IANF;AAAA,UAOEC,SAPF,gBAOEA,SAPF;AAAA,UAQEC,OARF,gBAQEA,OARF;AAAA,UASEjB,QATF,gBASEA,QATF;AAAA,UAUKkB,KAVL;;AAYA,UAAMC,GAAG,GAAG,CAACN,SAAD,EAAYC,SAAZ,EAAuBG,OAAO,GAAG,SAAH,GAAe,IAA7C,EAAmDF,IAAnD,EACTK,MADS,CACFC,OADE,EAETC,IAFS,CAEJ,GAFI,EAGTC,IAHS,EAAZ;AAIA,0BACE;AAAI,QAAA,SAAS,EAAEJ;AAAf,SAAwBD,KAAxB,GACG,KAAKM,aAAL,GAAqBC,GAArB,CAAyB,UAAC9B,IAAD,EAAiC+B,GAAjC,EAAyC;AACjE;AACA,YAAItB,KAAK,gBAAG,+BAAIT,IAAI,CAACS,KAAT,CAAZ;;AACA,YAAI,gBAAgBE,IAAhB,CAAqBX,IAAI,CAACU,IAA1B,CAAJ,EAA+C;AAC7C;AACAD,UAAAA,KAAK,gBAAG;AAAG,YAAA,SAAS,kBAAWT,IAAI,CAACU,IAAhB;AAAZ,YAAR;AACD;;AACD,4BACE;AACE,UAAA,SAAS,EAAE,CACTV,IAAI,CAACC,MAAL,GAAc,QAAd,GAAyB,IADhB,EAETD,IAAI,CAACE,QAAL,GAAgB,UAAhB,GAA6B,IAFpB,EAIRuB,MAJQ,CAIDC,OAJC,EAKRC,IALQ,CAKH,GALG,EAMRC,IANQ,EADb;AAQE,UAAA,OAAO,EAAE,MAAI,CAACI,OAAL,CAAaC,IAAb,CAAkB,MAAlB,EAAwBjC,IAAxB,CARX;AASE,UAAA,GAAG,EAAE+B;AATP,WAWGtB,KAXH,CADF;AAeD,OAtBA,CADH,CADF;AA2BD;;;;EAzJqChB,KAAK,CAACyC,S;;AAAzBxC,U,CAILyC,Y,GAAgC;AAC5CjB,EAAAA,SAAS,EAAE,cADiC;AAE5CG,EAAAA,SAAS,EAAE,MAFiC;AAG5CD,EAAAA,IAAI,EAAE,SAHsC;AAI5CjB,EAAAA,KAAK,EAAE,CAJqC;AAK5CC,EAAAA,QAAQ,EAAE,EALkC;AAK9B;AACdP,EAAAA,OAAO,EAAE,CANmC;AAO5CQ,EAAAA,QAAQ,EAAE;AAAA,WAAM,IAAN;AAAA;AAPkC,C;SAJ3BX,U","sourcesContent":["/* eslint-disable jsx-a11y/anchor-has-content */\nimport React from 'react';\nimport { IProps, HTMLUlProps } from '@uiw/utils';\nimport './style/index.less';\n\nexport interface PaginationProps extends IProps, Omit<HTMLUlProps, 'onChange'> {\n  prefixCls?: string;\n  alignment?: 'left' | 'center' | 'right';\n  size?: 'default' | 'small';\n  total?: number;\n  pageSize?: number;\n  divider?: boolean;\n  current?: number;\n  onChange?: (current: number, total: number, pageSize: number) => void;\n}\n\nexport interface PaginationState {\n  current: number;\n}\n\nexport interface PaginationItemSourceData {\n  type?: string;\n  disabled?: boolean;\n  active?: boolean;\n  label?: number | string;\n  goto?: number;\n}\n\nexport default class Pagination extends React.Component<\n  PaginationProps,\n  PaginationState\n> {\n  public static defaultProps: PaginationProps = {\n    prefixCls: 'w-pagination',\n    alignment: 'left',\n    size: 'default',\n    total: 0,\n    pageSize: 10, // The number of pages displayed.\n    current: 1,\n    onChange: () => null,\n  };\n  constructor(props: PaginationProps) {\n    super(props);\n    this.state = {\n      current: props.current as number,\n    };\n  }\n  UNSAFE_componentWillReceiveProps(nextProps: PaginationProps) {\n    if (nextProps.current !== this.props.current) {\n      this.setState({\n        current: nextProps.current as number,\n      });\n    }\n  }\n  onClick(item: PaginationItemSourceData) {\n    if (item.active || item.disabled) {\n      return;\n    }\n    const { total, pageSize, onChange } = this.props;\n    const { current } = this.state;\n    const count = Math.ceil((total as number) / (pageSize as number));\n    const state = {} as PaginationState;\n    if (item.label) {\n      state.current = item.label as number;\n    }\n    if (item.type === 'prev') {\n      state.current = current - 1 > 0 ? current - 1 : 1;\n    }\n    if (item.type === 'next') {\n      state.current = current + 1 <= count ? current + 1 : count;\n    }\n    if (/^(jumpPrev|jumpNext)/.test(item.type as string) && item.goto) {\n      state.current =\n        item.type === 'jumpPrev' ? current - item.goto : current + item.goto;\n      if (state.current > count) {\n        state.current = count;\n      }\n      if (state.current < 1) {\n        state.current = 1;\n      }\n    }\n    this.setState({ ...state }, () => {\n      onChange &&\n        onChange(this.state.current, total as number, pageSize as number);\n    });\n  }\n  initPageSoure(): PaginationItemSourceData[] {\n    const { total, pageSize } = this.props;\n    const { current } = this.state;\n    const data: PaginationItemSourceData[] = [\n      { type: 'prev', disabled: current === 1 },\n    ];\n    const count = Math.ceil((total as number) / (pageSize as number));\n    const itemCount = count <= 5 ? count : 5;\n    let num = 0;\n    let basic = 0;\n    if (current > 3 && count > 5) {\n      data.push({ label: 1 });\n    }\n    if (current > 4 && count > 6) {\n      data.push({ type: 'jumpPrev', label: '•••', goto: 5 });\n    }\n    while (num < itemCount) {\n      num += 1;\n      if (current > 3 && count > 5) {\n        basic = current - 3;\n      }\n      let label = num + basic;\n      if (count - current === 0 && count > 5) {\n        label -= 2;\n      }\n      if (count - current === 1 && count > 5) {\n        label -= 1;\n      }\n      if (label <= count) {\n        data.push({ label, active: current === label });\n      }\n    }\n    if (current + 3 < count && count > 6) {\n      data.push({ type: 'jumpNext', label: '•••', goto: 5 });\n    }\n    if (current + 2 < count && count > 5) {\n      data.push({ label: count });\n    }\n    data.push({ type: 'next', disabled: current === count });\n    return data;\n    // return [\n    //   { type: 'prev', disabled: true },\n    //   { type: 'jumpPrev', label: '•••', goto: 5 },\n    //   { label: 1 },\n    //   { label: 2, active: true },\n    //   { label: 3 },\n    //   { label: 4 },\n    //   { type: 'jumpPrev', label: '•••', goto: 5 },\n    //   { type: 'next' },\n    // ];\n  }\n  render() {\n    const {\n      prefixCls,\n      className,\n      total,\n      current,\n      pageSize,\n      size,\n      alignment,\n      divider,\n      onChange,\n      ...other\n    } = this.props;\n    const cls = [prefixCls, className, divider ? 'divider' : null, size]\n      .filter(Boolean)\n      .join(' ')\n      .trim();\n    return (\n      <ul className={cls} {...other}>\n        {this.initPageSoure().map((item: PaginationItemSourceData, idx) => {\n          // eslint-disable-next-line jsx-a11y/anchor-is-valid\n          let label = <a>{item.label}</a>;\n          if (/^(prev|next)$/.test(item.type as string)) {\n            // eslint-disable-next-line jsx-a11y/anchor-is-valid\n            label = <a className={`arrow ${item.type}`} />;\n          }\n          return (\n            <li\n              className={[\n                item.active ? 'active' : null,\n                item.disabled ? 'disabled' : null,\n              ]\n                .filter(Boolean)\n                .join(' ')\n                .trim()}\n              onClick={this.onClick.bind(this, item)}\n              key={idx}\n            >\n              {label}\n            </li>\n          );\n        })}\n      </ul>\n    );\n  }\n}\n"]}
return /*#__PURE__*/React.createElement("li", {
className: [item.active ? 'active' : null, item.disabled ? 'disabled' : null].filter(Boolean).join(' ').trim(),
onClick: function onClick() {
return handleClick(item);
},
key: idx
}, label);
}));
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/index.tsx"],"names":["React","useEffect","useMemo","useState","Pagination","props","className","prefixCls","alignment","size","total","pageSize","current","currentNumber","onChange","divider","other","setCurrent","cls","filter","Boolean","join","trim","initPageSoure","data","type","disabled","count","Math","ceil","itemCount","num","basic","push","label","goto","active","handleClick","item","state","test","map","idx"],"mappings":"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","sourcesContent":["import React, { useEffect, useMemo, useState } from 'react';\nimport { IProps, HTMLUlProps } from '@uiw/utils';\nimport './style/index.less';\n\nexport interface PaginationProps extends IProps, Omit<HTMLUlProps, 'onChange'> {\n  prefixCls?: string;\n  alignment?: 'left' | 'center' | 'right';\n  size?: 'default' | 'small';\n  total?: number;\n  pageSize?: number;\n  divider?: boolean;\n  current?: number;\n  onChange?: (current: number, total: number, pageSize: number) => void;\n}\n\nexport interface PaginationState {\n  current: number;\n}\n\nexport interface PaginationItemSourceData {\n  type?: string;\n  disabled?: boolean;\n  active?: boolean;\n  label?: number | string;\n  goto?: number;\n}\n\nexport default function Pagination(props: PaginationProps) {\n  const {\n    className,\n    prefixCls = 'w-pagination',\n    alignment = 'left',\n    size = 'default',\n    total = 0,\n    pageSize = 10, // The number of pages displayed.\n    current: currentNumber = 1,\n    onChange = () => null,\n    divider,\n    ...other\n  } = props;\n\n  const [current, setCurrent] = useState(currentNumber);\n  useEffect(() => setCurrent(currentNumber), [currentNumber]);\n\n  const cls = [prefixCls, className, divider ? 'divider' : null, size]\n    .filter(Boolean)\n    .join(' ')\n    .trim();\n\n  const initPageSoure = useMemo(() => {\n    const data: PaginationItemSourceData[] = [\n      { type: 'prev', disabled: current === 1 },\n    ];\n    const count = Math.ceil(total / pageSize);\n    const itemCount = count <= 5 ? count : 5;\n    let num = 0;\n    let basic = 0;\n    if (current > 3 && count > 5) {\n      data.push({ label: 1 });\n    }\n    if (current > 4 && count > 6) {\n      data.push({ type: 'jumpPrev', label: '•••', goto: 5 });\n    }\n    while (num < itemCount) {\n      num += 1;\n      if (current > 3 && count > 5) {\n        basic = current - 3;\n      }\n      let label = num + basic;\n      if (count - current === 0 && count > 5) {\n        label -= 2;\n      }\n      if (count - current === 1 && count > 5) {\n        label -= 1;\n      }\n      if (label <= count) {\n        data.push({ label, active: current === label });\n      }\n    }\n    if (current + 3 < count && count > 6) {\n      data.push({ type: 'jumpNext', label: '•••', goto: 5 });\n    }\n    if (current + 2 < count && count > 5) {\n      data.push({ label: count });\n    }\n    data.push({ type: 'next', disabled: current === count });\n    return data;\n    // return [\n    //   { type: 'prev', disabled: true },\n    //   { type: 'jumpPrev', label: '•••', goto: 5 },\n    //   { label: 1 },\n    //   { label: 2, active: true },\n    //   { label: 3 },\n    //   { label: 4 },\n    //   { type: 'jumpPrev', label: '•••', goto: 5 },\n    //   { type: 'next' },\n    // ];\n  }, [current, total, pageSize]);\n\n  function handleClick(item: PaginationItemSourceData) {\n    if (item.active || item.disabled) {\n      return;\n    }\n    const count = Math.ceil(total / pageSize);\n    const state = {} as PaginationState;\n    if (item.label) {\n      state.current = item.label as number;\n    }\n    if (item.type === 'prev') {\n      state.current = current - 1 > 0 ? current - 1 : 1;\n    }\n    if (item.type === 'next') {\n      state.current = current + 1 <= count ? current + 1 : count;\n    }\n    if (/^(jumpPrev|jumpNext)/.test(item.type as string) && item.goto) {\n      state.current =\n        item.type === 'jumpPrev' ? current - item.goto : current + item.goto;\n      if (state.current > count) {\n        state.current = count;\n      }\n      if (state.current < 1) {\n        state.current = 1;\n      }\n    }\n\n    setCurrent(state.current);\n    onChange && onChange(state.current, total as number, pageSize as number);\n  }\n\n  return (\n    <ul className={cls} {...other}>\n      {initPageSoure.map((item: PaginationItemSourceData, idx) => {\n        // eslint-disable-next-line jsx-a11y/anchor-is-valid\n        let label = <a>{item.label}</a>;\n        if (/^(prev|next)$/.test(item.type as string)) {\n          // eslint-disable-next-line jsx-a11y/anchor-is-valid\n          label = <a className={`arrow ${item.type}`} />;\n        }\n        return (\n          <li\n            className={[\n              item.active ? 'active' : null,\n              item.disabled ? 'disabled' : null,\n            ]\n              .filter(Boolean)\n              .join(' ')\n              .trim()}\n            onClick={() => handleClick(item)}\n            key={idx}\n          >\n            {label}\n          </li>\n        );\n      })}\n    </ul>\n  );\n}\n"]}
{
"name": "@uiw/react-pagination",
"version": "4.8.0",
"version": "4.8.1",
"description": "Pagination component",

@@ -45,3 +45,3 @@ "author": "Kenny Wong <wowohoo@qq.com>",

"dependencies": {
"@uiw/utils": "^4.8.0"
"@uiw/utils": "^4.8.1"
},

@@ -48,0 +48,0 @@ "devDependencies": {

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc