@uiw/react-pagination
Advanced tools
Comparing version 4.7.12 to 4.7.13
"use strict"; | ||
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); | ||
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default; | ||
@@ -236,2 +236,2 @@ Object.defineProperty(exports, "__esModule", { | ||
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","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"]} |
@@ -1,8 +0,8 @@ | ||
import _extends from "@babel/runtime/helpers/esm/extends"; | ||
import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties"; | ||
import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2"; | ||
import _classCallCheck from "@babel/runtime/helpers/esm/classCallCheck"; | ||
import _createClass from "@babel/runtime/helpers/esm/createClass"; | ||
import _inherits from "@babel/runtime/helpers/esm/inherits"; | ||
import _createSuper from "@babel/runtime/helpers/esm/createSuper"; | ||
import _extends from "@babel/runtime/helpers/extends"; | ||
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"; | ||
@@ -224,2 +224,2 @@ /* eslint-disable jsx-a11y/anchor-has-content */ | ||
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":"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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":["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":"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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"]} |
{ | ||
"name": "@uiw/react-pagination", | ||
"version": "4.7.12", | ||
"version": "4.7.13", | ||
"description": "Pagination component", | ||
@@ -41,16 +41,16 @@ "author": "Kenny Wong <wowohoo@qq.com>", | ||
"peerDependencies": { | ||
"react": ">=16.8.0", | ||
"react-dom": ">=16.8.0" | ||
"react": ">=16.9.0", | ||
"react-dom": ">=16.9.0" | ||
}, | ||
"dependencies": { | ||
"@uiw/utils": "^4.7.12" | ||
"@uiw/utils": "^4.7.13" | ||
}, | ||
"devDependencies": { | ||
"@babel/runtime": "7.12.13", | ||
"@types/react": "16.9.41", | ||
"@types/react-dom": "16.9.8", | ||
"react": "16.14.0", | ||
"react-dom": "16.14.0" | ||
"@babel/runtime": "7.14.0", | ||
"@types/react": "17.0.5", | ||
"@types/react-dom": "17.0.3", | ||
"react": "17.0.2", | ||
"react-dom": "17.0.2" | ||
}, | ||
"gitHead": "2e4f9f9cf8568beadb8ccec3ae4854ea7b68d677" | ||
"gitHead": "cf93d5f2f686b8cabe21ba89039a8afba0433f07" | ||
} |
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
63974
748
Updated@uiw/utils@^4.7.13