2019-01-12 03:33:27 +00:00
|
|
|
|
import PropTypes from '../_util/vue-types';
|
|
|
|
|
import BaseMixin from '../_util/BaseMixin';
|
2020-03-07 11:45:13 +00:00
|
|
|
|
import { hasProp, getComponentFromProp, getOptionProps } from '../_util/props-util';
|
2019-01-12 03:33:27 +00:00
|
|
|
|
import Pager from './Pager';
|
|
|
|
|
import Options from './Options';
|
|
|
|
|
import LOCALE from './locale/zh_CN';
|
|
|
|
|
import KEYCODE from './KeyCode';
|
2018-03-19 02:16:27 +00:00
|
|
|
|
|
2019-01-12 03:33:27 +00:00
|
|
|
|
function noop() {}
|
2018-03-05 11:06:44 +00:00
|
|
|
|
|
|
|
|
|
// 是否是正整数
|
2019-01-12 03:33:27 +00:00
|
|
|
|
function isInteger(value) {
|
|
|
|
|
return typeof value === 'number' && isFinite(value) && Math.floor(value) === value;
|
2018-03-05 11:06:44 +00:00
|
|
|
|
}
|
|
|
|
|
|
2019-01-12 03:33:27 +00:00
|
|
|
|
function defaultItemRender(page, type, element) {
|
|
|
|
|
return element;
|
2018-03-05 11:06:44 +00:00
|
|
|
|
}
|
|
|
|
|
|
2019-01-12 03:33:27 +00:00
|
|
|
|
function calculatePage(p, state, props) {
|
|
|
|
|
let pageSize = p;
|
2019-01-01 13:19:50 +00:00
|
|
|
|
if (typeof pageSize === 'undefined') {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
pageSize = state.statePageSize;
|
2019-01-01 13:19:50 +00:00
|
|
|
|
}
|
2019-01-12 03:33:27 +00:00
|
|
|
|
return Math.floor((props.total - 1) / pageSize) + 1;
|
2019-01-01 13:19:50 +00:00
|
|
|
|
}
|
|
|
|
|
|
2018-03-05 11:06:44 +00:00
|
|
|
|
export default {
|
|
|
|
|
name: 'Pagination',
|
|
|
|
|
mixins: [BaseMixin],
|
2019-02-01 09:23:00 +00:00
|
|
|
|
model: {
|
|
|
|
|
prop: 'current',
|
|
|
|
|
event: 'change.current',
|
|
|
|
|
},
|
2018-03-05 11:06:44 +00:00
|
|
|
|
props: {
|
2019-08-27 15:11:12 +00:00
|
|
|
|
disabled: PropTypes.bool,
|
2018-03-05 11:06:44 +00:00
|
|
|
|
prefixCls: PropTypes.string.def('rc-pagination'),
|
|
|
|
|
selectPrefixCls: PropTypes.string.def('rc-select'),
|
|
|
|
|
current: PropTypes.number,
|
|
|
|
|
defaultCurrent: PropTypes.number.def(1),
|
|
|
|
|
total: PropTypes.number.def(0),
|
|
|
|
|
pageSize: PropTypes.number,
|
|
|
|
|
defaultPageSize: PropTypes.number.def(10),
|
|
|
|
|
hideOnSinglePage: PropTypes.bool.def(false),
|
|
|
|
|
showSizeChanger: PropTypes.bool.def(false),
|
|
|
|
|
showLessItems: PropTypes.bool.def(false),
|
|
|
|
|
// showSizeChange: PropTypes.func.def(noop),
|
|
|
|
|
selectComponentClass: PropTypes.any,
|
2018-03-22 09:23:51 +00:00
|
|
|
|
showPrevNextJumpers: PropTypes.bool.def(true),
|
2018-03-05 11:06:44 +00:00
|
|
|
|
showQuickJumper: PropTypes.oneOfType([PropTypes.bool, PropTypes.object]).def(false),
|
|
|
|
|
showTitle: PropTypes.bool.def(true),
|
|
|
|
|
pageSizeOptions: PropTypes.arrayOf(PropTypes.string),
|
2018-03-06 07:40:42 +00:00
|
|
|
|
buildOptionText: PropTypes.func,
|
2018-03-05 11:06:44 +00:00
|
|
|
|
showTotal: PropTypes.func,
|
|
|
|
|
simple: PropTypes.bool,
|
|
|
|
|
locale: PropTypes.object.def(LOCALE),
|
|
|
|
|
itemRender: PropTypes.func.def(defaultItemRender),
|
2018-11-08 11:59:09 +00:00
|
|
|
|
prevIcon: PropTypes.any,
|
|
|
|
|
nextIcon: PropTypes.any,
|
|
|
|
|
jumpPrevIcon: PropTypes.any,
|
|
|
|
|
jumpNextIcon: PropTypes.any,
|
2018-03-05 11:06:44 +00:00
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
data() {
|
2020-03-07 11:45:13 +00:00
|
|
|
|
const props = getOptionProps(this);
|
2019-01-12 03:33:27 +00:00
|
|
|
|
const hasOnChange = this.onChange !== noop;
|
2020-03-07 11:45:13 +00:00
|
|
|
|
const hasCurrent = 'current' in props;
|
2018-03-05 11:06:44 +00:00
|
|
|
|
if (hasCurrent && !hasOnChange) {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
console.warn(
|
|
|
|
|
'Warning: You provided a `current` prop to a Pagination component without an `onChange` handler. This will render a read-only component.',
|
|
|
|
|
); // eslint-disable-line
|
2018-03-05 11:06:44 +00:00
|
|
|
|
}
|
2019-01-12 03:33:27 +00:00
|
|
|
|
let current = this.defaultCurrent;
|
2020-03-07 11:45:13 +00:00
|
|
|
|
if ('current' in props) {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
current = this.current;
|
2018-03-05 11:06:44 +00:00
|
|
|
|
}
|
|
|
|
|
|
2019-01-12 03:33:27 +00:00
|
|
|
|
let pageSize = this.defaultPageSize;
|
2020-03-07 11:45:13 +00:00
|
|
|
|
if ('pageSize' in props) {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
pageSize = this.pageSize;
|
2018-03-05 11:06:44 +00:00
|
|
|
|
}
|
|
|
|
|
|
2020-03-07 11:45:13 +00:00
|
|
|
|
current = Math.min(current, calculatePage(pageSize, undefined, props));
|
|
|
|
|
|
2018-03-05 11:06:44 +00:00
|
|
|
|
return {
|
|
|
|
|
stateCurrent: current,
|
|
|
|
|
stateCurrentInputValue: current,
|
|
|
|
|
statePageSize: pageSize,
|
2019-01-12 03:33:27 +00:00
|
|
|
|
};
|
2018-03-05 11:06:44 +00:00
|
|
|
|
},
|
|
|
|
|
watch: {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
current(val) {
|
2018-03-05 11:06:44 +00:00
|
|
|
|
this.setState({
|
|
|
|
|
stateCurrent: val,
|
|
|
|
|
stateCurrentInputValue: val,
|
2019-01-12 03:33:27 +00:00
|
|
|
|
});
|
2018-03-05 11:06:44 +00:00
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
pageSize(val) {
|
|
|
|
|
const newState = {};
|
|
|
|
|
let current = this.stateCurrent;
|
|
|
|
|
const newCurrent = calculatePage(val, this.$data, this.$props);
|
|
|
|
|
current = current > newCurrent ? newCurrent : current;
|
2018-03-07 02:48:33 +00:00
|
|
|
|
if (!hasProp(this, 'current')) {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
newState.stateCurrent = current;
|
|
|
|
|
newState.stateCurrentInputValue = current;
|
2018-03-05 11:06:44 +00:00
|
|
|
|
}
|
2019-01-12 03:33:27 +00:00
|
|
|
|
newState.statePageSize = val;
|
|
|
|
|
this.setState(newState);
|
2018-03-05 11:06:44 +00:00
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
stateCurrent(val, oldValue) {
|
2018-04-07 10:52:02 +00:00
|
|
|
|
// When current page change, fix focused style of prev item
|
|
|
|
|
// A hacky solution of https://github.com/ant-design/ant-design/issues/8948
|
2018-04-21 04:51:56 +00:00
|
|
|
|
this.$nextTick(() => {
|
|
|
|
|
if (this.$refs.paginationNode) {
|
2018-04-07 10:52:02 +00:00
|
|
|
|
const lastCurrentNode = this.$refs.paginationNode.querySelector(
|
2019-01-12 03:33:27 +00:00
|
|
|
|
`.${this.prefixCls}-item-${oldValue}`,
|
|
|
|
|
);
|
2018-04-07 10:52:02 +00:00
|
|
|
|
if (lastCurrentNode && document.activeElement === lastCurrentNode) {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
lastCurrentNode.blur();
|
2018-04-07 10:52:02 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
2019-01-12 03:33:27 +00:00
|
|
|
|
});
|
2018-04-07 10:52:02 +00:00
|
|
|
|
},
|
2020-03-31 05:48:01 +00:00
|
|
|
|
total() {
|
|
|
|
|
const newState = {};
|
|
|
|
|
const newCurrent = calculatePage(this.pageSize, this.$data, this.$props);
|
|
|
|
|
if (hasProp(this, 'current')) {
|
|
|
|
|
const current = Math.min(this.current, newCurrent);
|
|
|
|
|
newState.stateCurrent = current;
|
|
|
|
|
newState.stateCurrentInputValue = current;
|
|
|
|
|
} else {
|
|
|
|
|
let current = this.stateCurrent;
|
|
|
|
|
if (current === 0 && newCurrent > 0) {
|
|
|
|
|
current = 1;
|
|
|
|
|
} else {
|
|
|
|
|
current = Math.min(this.stateCurrent, newCurrent);
|
|
|
|
|
}
|
|
|
|
|
newState.stateCurrent = current;
|
|
|
|
|
}
|
|
|
|
|
this.setState(newState);
|
|
|
|
|
},
|
2018-03-05 11:06:44 +00:00
|
|
|
|
},
|
|
|
|
|
methods: {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
getJumpPrevPage() {
|
|
|
|
|
return Math.max(1, this.stateCurrent - (this.showLessItems ? 3 : 5));
|
2019-01-01 13:19:50 +00:00
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
getJumpNextPage() {
|
2019-01-01 13:19:50 +00:00
|
|
|
|
return Math.min(
|
|
|
|
|
calculatePage(undefined, this.$data, this.$props),
|
2019-01-12 03:33:27 +00:00
|
|
|
|
this.stateCurrent + (this.showLessItems ? 3 : 5),
|
|
|
|
|
);
|
2018-03-05 11:06:44 +00:00
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
getItemIcon(icon) {
|
|
|
|
|
const { prefixCls } = this.$props;
|
|
|
|
|
const iconNode = getComponentFromProp(this, icon, this.$props) || (
|
|
|
|
|
<a class={`${prefixCls}-item-link`} />
|
|
|
|
|
);
|
|
|
|
|
return iconNode;
|
2018-11-08 11:59:09 +00:00
|
|
|
|
},
|
2019-08-27 15:11:12 +00:00
|
|
|
|
getValidValue(e) {
|
|
|
|
|
const inputValue = e.target.value;
|
2020-03-07 11:45:13 +00:00
|
|
|
|
const allPages = calculatePage(undefined, this.$data, this.$props);
|
2019-08-27 15:11:12 +00:00
|
|
|
|
const { stateCurrentInputValue } = this.$data;
|
|
|
|
|
let value;
|
|
|
|
|
if (inputValue === '') {
|
|
|
|
|
value = inputValue;
|
|
|
|
|
} else if (isNaN(Number(inputValue))) {
|
|
|
|
|
value = stateCurrentInputValue;
|
2020-03-07 11:45:13 +00:00
|
|
|
|
} else if (inputValue >= allPages) {
|
|
|
|
|
value = allPages;
|
2019-08-27 15:11:12 +00:00
|
|
|
|
} else {
|
|
|
|
|
value = Number(inputValue);
|
|
|
|
|
}
|
|
|
|
|
return value;
|
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
isValid(page) {
|
2020-03-07 11:45:13 +00:00
|
|
|
|
return isInteger(page) && page !== this.stateCurrent;
|
2018-03-05 11:06:44 +00:00
|
|
|
|
},
|
2019-08-27 15:11:12 +00:00
|
|
|
|
shouldDisplayQuickJumper() {
|
|
|
|
|
const { showQuickJumper, pageSize, total } = this.$props;
|
|
|
|
|
if (total <= pageSize) {
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
return showQuickJumper;
|
|
|
|
|
},
|
2019-01-01 13:19:50 +00:00
|
|
|
|
// calculatePage (p) {
|
|
|
|
|
// let pageSize = p
|
|
|
|
|
// if (typeof pageSize === 'undefined') {
|
|
|
|
|
// pageSize = this.statePageSize
|
|
|
|
|
// }
|
|
|
|
|
// return Math.floor((this.total - 1) / pageSize) + 1
|
|
|
|
|
// },
|
2019-01-12 03:33:27 +00:00
|
|
|
|
handleKeyDown(event) {
|
2018-03-05 11:06:44 +00:00
|
|
|
|
if (event.keyCode === KEYCODE.ARROW_UP || event.keyCode === KEYCODE.ARROW_DOWN) {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
event.preventDefault();
|
2018-03-05 11:06:44 +00:00
|
|
|
|
}
|
|
|
|
|
},
|
2019-10-24 10:50:51 +00:00
|
|
|
|
handleKeyUp(e) {
|
2020-05-08 09:09:41 +00:00
|
|
|
|
if (e.isComposing || e.target.composing) return;
|
2019-10-24 10:50:51 +00:00
|
|
|
|
const value = this.getValidValue(e);
|
2019-01-12 03:33:27 +00:00
|
|
|
|
const stateCurrentInputValue = this.stateCurrentInputValue;
|
2018-03-05 11:06:44 +00:00
|
|
|
|
|
|
|
|
|
if (value !== stateCurrentInputValue) {
|
|
|
|
|
this.setState({
|
|
|
|
|
stateCurrentInputValue: value,
|
2019-01-12 03:33:27 +00:00
|
|
|
|
});
|
2018-03-05 11:06:44 +00:00
|
|
|
|
}
|
|
|
|
|
|
2019-10-24 10:50:51 +00:00
|
|
|
|
if (e.keyCode === KEYCODE.ENTER) {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
this.handleChange(value);
|
2019-10-24 10:50:51 +00:00
|
|
|
|
} else if (e.keyCode === KEYCODE.ARROW_UP) {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
this.handleChange(value - 1);
|
2019-10-24 10:50:51 +00:00
|
|
|
|
} else if (e.keyCode === KEYCODE.ARROW_DOWN) {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
this.handleChange(value + 1);
|
2018-03-05 11:06:44 +00:00
|
|
|
|
}
|
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
changePageSize(size) {
|
|
|
|
|
let current = this.stateCurrent;
|
|
|
|
|
const preCurrent = current;
|
|
|
|
|
const newCurrent = calculatePage(size, this.$data, this.$props);
|
|
|
|
|
current = current > newCurrent ? newCurrent : current;
|
2018-09-05 13:28:54 +00:00
|
|
|
|
// fix the issue:
|
|
|
|
|
// Once 'total' is 0, 'current' in 'onShowSizeChange' is 0, which is not correct.
|
|
|
|
|
if (newCurrent === 0) {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
current = this.stateCurrent;
|
2018-09-05 13:28:54 +00:00
|
|
|
|
}
|
2018-03-05 11:06:44 +00:00
|
|
|
|
if (typeof size === 'number') {
|
|
|
|
|
if (!hasProp(this, 'pageSize')) {
|
|
|
|
|
this.setState({
|
|
|
|
|
statePageSize: size,
|
2019-01-12 03:33:27 +00:00
|
|
|
|
});
|
2018-03-05 11:06:44 +00:00
|
|
|
|
}
|
|
|
|
|
if (!hasProp(this, 'current')) {
|
|
|
|
|
this.setState({
|
|
|
|
|
stateCurrent: current,
|
|
|
|
|
stateCurrentInputValue: current,
|
2019-01-12 03:33:27 +00:00
|
|
|
|
});
|
2018-03-05 11:06:44 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
2019-01-12 03:33:27 +00:00
|
|
|
|
this.$emit('update:pageSize', size);
|
|
|
|
|
this.$emit('showSizeChange', current, size);
|
2018-10-23 04:49:40 +00:00
|
|
|
|
if (current !== preCurrent) {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
this.$emit('change.current', current, size);
|
2018-10-23 04:49:40 +00:00
|
|
|
|
}
|
2018-03-05 11:06:44 +00:00
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
handleChange(p) {
|
2019-08-27 15:11:12 +00:00
|
|
|
|
const { disabled } = this.$props;
|
2019-01-12 03:33:27 +00:00
|
|
|
|
let page = p;
|
2019-08-27 15:11:12 +00:00
|
|
|
|
if (this.isValid(page) && !disabled) {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
const currentPage = calculatePage(undefined, this.$data, this.$props);
|
2019-01-01 13:19:50 +00:00
|
|
|
|
if (page > currentPage) {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
page = currentPage;
|
2020-03-07 11:45:13 +00:00
|
|
|
|
} else if (page < 1) {
|
|
|
|
|
page = 1;
|
2018-03-05 11:06:44 +00:00
|
|
|
|
}
|
|
|
|
|
if (!hasProp(this, 'current')) {
|
|
|
|
|
this.setState({
|
|
|
|
|
stateCurrent: page,
|
|
|
|
|
stateCurrentInputValue: page,
|
2019-01-12 03:33:27 +00:00
|
|
|
|
});
|
2018-03-05 11:06:44 +00:00
|
|
|
|
}
|
2018-03-07 02:48:33 +00:00
|
|
|
|
// this.$emit('input', page)
|
2019-01-12 03:33:27 +00:00
|
|
|
|
this.$emit('change.current', page, this.statePageSize);
|
2020-07-21 03:29:59 +00:00
|
|
|
|
this.$emit('change', page, this.statePageSize);
|
2019-01-12 03:33:27 +00:00
|
|
|
|
return page;
|
2018-03-05 11:06:44 +00:00
|
|
|
|
}
|
2019-01-12 03:33:27 +00:00
|
|
|
|
return this.stateCurrent;
|
2018-03-05 11:06:44 +00:00
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
prev() {
|
2019-01-01 13:19:50 +00:00
|
|
|
|
if (this.hasPrev()) {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
this.handleChange(this.stateCurrent - 1);
|
2019-01-01 13:19:50 +00:00
|
|
|
|
}
|
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
next() {
|
2019-01-01 13:19:50 +00:00
|
|
|
|
if (this.hasNext()) {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
this.handleChange(this.stateCurrent + 1);
|
2019-01-01 13:19:50 +00:00
|
|
|
|
}
|
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
jumpPrev() {
|
|
|
|
|
this.handleChange(this.getJumpPrevPage());
|
2019-01-01 13:19:50 +00:00
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
jumpNext() {
|
|
|
|
|
this.handleChange(this.getJumpNextPage());
|
2019-01-01 13:19:50 +00:00
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
hasPrev() {
|
|
|
|
|
return this.stateCurrent > 1;
|
2019-01-01 13:19:50 +00:00
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
hasNext() {
|
|
|
|
|
return this.stateCurrent < calculatePage(undefined, this.$data, this.$props);
|
2019-01-01 13:19:50 +00:00
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
runIfEnter(event, callback, ...restParams) {
|
2018-03-05 11:06:44 +00:00
|
|
|
|
if (event.key === 'Enter' || event.charCode === 13) {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
callback(...restParams);
|
2018-03-05 11:06:44 +00:00
|
|
|
|
}
|
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
runIfEnterPrev(event) {
|
|
|
|
|
this.runIfEnter(event, this.prev);
|
2018-03-05 11:06:44 +00:00
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
runIfEnterNext(event) {
|
|
|
|
|
this.runIfEnter(event, this.next);
|
2018-03-05 11:06:44 +00:00
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
runIfEnterJumpPrev(event) {
|
|
|
|
|
this.runIfEnter(event, this.jumpPrev);
|
2018-03-05 11:06:44 +00:00
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
runIfEnterJumpNext(event) {
|
|
|
|
|
this.runIfEnter(event, this.jumpNext);
|
2018-03-05 11:06:44 +00:00
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
handleGoTO(event) {
|
2019-01-01 13:19:50 +00:00
|
|
|
|
if (event.keyCode === KEYCODE.ENTER || event.type === 'click') {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
this.handleChange(this.stateCurrentInputValue);
|
2019-01-01 13:19:50 +00:00
|
|
|
|
}
|
2018-03-05 11:06:44 +00:00
|
|
|
|
},
|
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
render() {
|
2019-08-27 15:11:12 +00:00
|
|
|
|
const { prefixCls, disabled } = this.$props;
|
|
|
|
|
|
2018-03-05 11:06:44 +00:00
|
|
|
|
// When hideOnSinglePage is true and there is only 1 page, hide the pager
|
|
|
|
|
if (this.hideOnSinglePage === true && this.total <= this.statePageSize) {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
return null;
|
2018-03-05 11:06:44 +00:00
|
|
|
|
}
|
2019-01-12 03:33:27 +00:00
|
|
|
|
const props = this.$props;
|
|
|
|
|
const locale = this.locale;
|
2018-03-05 11:06:44 +00:00
|
|
|
|
|
2019-01-12 03:33:27 +00:00
|
|
|
|
const allPages = calculatePage(undefined, this.$data, this.$props);
|
|
|
|
|
const pagerList = [];
|
|
|
|
|
let jumpPrev = null;
|
|
|
|
|
let jumpNext = null;
|
|
|
|
|
let firstPager = null;
|
|
|
|
|
let lastPager = null;
|
|
|
|
|
let gotoButton = null;
|
|
|
|
|
const goButton = this.showQuickJumper && this.showQuickJumper.goButton;
|
|
|
|
|
const pageBufferSize = this.showLessItems ? 1 : 2;
|
|
|
|
|
const { stateCurrent, statePageSize } = this;
|
|
|
|
|
const prevPage = stateCurrent - 1 > 0 ? stateCurrent - 1 : 0;
|
|
|
|
|
const nextPage = stateCurrent + 1 < allPages ? stateCurrent + 1 : allPages;
|
2018-03-05 11:06:44 +00:00
|
|
|
|
|
|
|
|
|
if (this.simple) {
|
|
|
|
|
if (goButton) {
|
|
|
|
|
if (typeof goButton === 'boolean') {
|
|
|
|
|
gotoButton = (
|
2019-01-12 03:33:27 +00:00
|
|
|
|
<button type="button" onClick={this.handleGoTO} onKeyup={this.handleGoTO}>
|
2018-03-05 11:06:44 +00:00
|
|
|
|
{locale.jump_to_confirm}
|
|
|
|
|
</button>
|
2019-01-12 03:33:27 +00:00
|
|
|
|
);
|
2018-03-05 11:06:44 +00:00
|
|
|
|
} else {
|
|
|
|
|
gotoButton = (
|
2019-01-12 03:33:27 +00:00
|
|
|
|
<span onClick={this.handleGoTO} onKeyup={this.handleGoTO}>
|
|
|
|
|
{goButton}
|
|
|
|
|
</span>
|
|
|
|
|
);
|
2018-03-05 11:06:44 +00:00
|
|
|
|
}
|
|
|
|
|
gotoButton = (
|
|
|
|
|
<li
|
|
|
|
|
title={this.showTitle ? `${locale.jump_to}${this.stateCurrent}/${allPages}` : null}
|
|
|
|
|
class={`${prefixCls}-simple-pager`}
|
|
|
|
|
>
|
|
|
|
|
{gotoButton}
|
|
|
|
|
</li>
|
2019-01-12 03:33:27 +00:00
|
|
|
|
);
|
2018-03-05 11:06:44 +00:00
|
|
|
|
}
|
2019-01-12 03:33:27 +00:00
|
|
|
|
const hasPrev = this.hasPrev();
|
|
|
|
|
const hasNext = this.hasNext();
|
2018-03-05 11:06:44 +00:00
|
|
|
|
return (
|
|
|
|
|
<ul class={`${prefixCls} ${prefixCls}-simple`}>
|
|
|
|
|
<li
|
|
|
|
|
title={this.showTitle ? locale.prev_page : null}
|
|
|
|
|
onClick={this.prev}
|
2018-03-09 04:20:21 +00:00
|
|
|
|
tabIndex={hasPrev ? 0 : null}
|
2018-03-05 11:06:44 +00:00
|
|
|
|
onKeypress={this.runIfEnterPrev}
|
2018-03-09 04:20:21 +00:00
|
|
|
|
class={`${hasPrev ? '' : `${prefixCls}-disabled`} ${prefixCls}-prev`}
|
2018-03-05 11:06:44 +00:00
|
|
|
|
aria-disabled={!this.hasPrev()}
|
|
|
|
|
>
|
2018-11-08 11:59:09 +00:00
|
|
|
|
{this.itemRender(prevPage, 'prev', this.getItemIcon('prevIcon'))}
|
2018-03-05 11:06:44 +00:00
|
|
|
|
</li>
|
|
|
|
|
<li
|
|
|
|
|
title={this.showTitle ? `${stateCurrent}/${allPages}` : null}
|
|
|
|
|
class={`${prefixCls}-simple-pager`}
|
|
|
|
|
>
|
|
|
|
|
<input
|
2019-01-12 03:33:27 +00:00
|
|
|
|
type="text"
|
2018-03-05 11:06:44 +00:00
|
|
|
|
value={this.stateCurrentInputValue}
|
|
|
|
|
onKeydown={this.handleKeyDown}
|
|
|
|
|
onKeyup={this.handleKeyUp}
|
2018-03-12 14:13:59 +00:00
|
|
|
|
onInput={this.handleKeyUp}
|
2019-01-12 03:33:27 +00:00
|
|
|
|
size="3"
|
2019-11-14 11:19:24 +00:00
|
|
|
|
{...{
|
|
|
|
|
directives: [
|
|
|
|
|
{
|
|
|
|
|
name: 'ant-input',
|
|
|
|
|
},
|
|
|
|
|
],
|
|
|
|
|
}}
|
2018-03-05 11:06:44 +00:00
|
|
|
|
/>
|
|
|
|
|
<span class={`${prefixCls}-slash`}>/</span>
|
|
|
|
|
{allPages}
|
|
|
|
|
</li>
|
|
|
|
|
<li
|
|
|
|
|
title={this.showTitle ? locale.next_page : null}
|
|
|
|
|
onClick={this.next}
|
2018-03-22 09:23:51 +00:00
|
|
|
|
tabIndex={this.hasNext ? 0 : null}
|
2018-03-05 11:06:44 +00:00
|
|
|
|
onKeypress={this.runIfEnterNext}
|
2018-03-09 04:20:21 +00:00
|
|
|
|
class={`${hasNext ? '' : `${prefixCls}-disabled`} ${prefixCls}-next`}
|
2018-03-05 11:06:44 +00:00
|
|
|
|
aria-disabled={!this.hasNext()}
|
|
|
|
|
>
|
2018-11-08 11:59:09 +00:00
|
|
|
|
{this.itemRender(nextPage, 'next', this.getItemIcon('nextIcon'))}
|
2018-03-05 11:06:44 +00:00
|
|
|
|
</li>
|
|
|
|
|
{gotoButton}
|
|
|
|
|
</ul>
|
2019-01-12 03:33:27 +00:00
|
|
|
|
);
|
2018-03-05 11:06:44 +00:00
|
|
|
|
}
|
|
|
|
|
if (allPages <= 5 + pageBufferSize * 2) {
|
2019-01-01 13:19:50 +00:00
|
|
|
|
const pagerProps = {
|
|
|
|
|
props: {
|
|
|
|
|
locale,
|
|
|
|
|
rootPrefixCls: prefixCls,
|
|
|
|
|
showTitle: props.showTitle,
|
|
|
|
|
itemRender: props.itemRender,
|
|
|
|
|
},
|
|
|
|
|
on: {
|
|
|
|
|
click: this.handleChange,
|
|
|
|
|
keypress: this.runIfEnter,
|
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
};
|
2019-01-01 13:19:50 +00:00
|
|
|
|
if (!allPages) {
|
|
|
|
|
pagerList.push(
|
2019-01-12 03:33:27 +00:00
|
|
|
|
<Pager {...pagerProps} key="noPager" page={allPages} class={`${prefixCls}-disabled`} />,
|
|
|
|
|
);
|
2019-01-01 13:19:50 +00:00
|
|
|
|
}
|
2018-03-05 11:06:44 +00:00
|
|
|
|
for (let i = 1; i <= allPages; i++) {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
const active = stateCurrent === i;
|
|
|
|
|
pagerList.push(<Pager {...pagerProps} key={i} page={i} active={active} />);
|
2018-03-05 11:06:44 +00:00
|
|
|
|
}
|
|
|
|
|
} else {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
const prevItemTitle = this.showLessItems ? locale.prev_3 : locale.prev_5;
|
|
|
|
|
const nextItemTitle = this.showLessItems ? locale.next_3 : locale.next_5;
|
2018-03-22 09:23:51 +00:00
|
|
|
|
if (this.showPrevNextJumpers) {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
let jumpPrevClassString = `${prefixCls}-jump-prev`;
|
2018-11-08 11:59:09 +00:00
|
|
|
|
if (props.jumpPrevIcon) {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
jumpPrevClassString += ` ${prefixCls}-jump-prev-custom-icon`;
|
2018-11-08 11:59:09 +00:00
|
|
|
|
}
|
2018-03-22 09:23:51 +00:00
|
|
|
|
jumpPrev = (
|
|
|
|
|
<li
|
|
|
|
|
title={this.showTitle ? prevItemTitle : null}
|
2019-01-12 03:33:27 +00:00
|
|
|
|
key="prev"
|
2018-03-22 09:23:51 +00:00
|
|
|
|
onClick={this.jumpPrev}
|
2019-01-12 03:33:27 +00:00
|
|
|
|
tabIndex="0"
|
2018-03-22 09:23:51 +00:00
|
|
|
|
onKeypress={this.runIfEnterJumpPrev}
|
2018-11-08 11:59:09 +00:00
|
|
|
|
class={jumpPrevClassString}
|
2018-03-22 09:23:51 +00:00
|
|
|
|
>
|
2019-01-12 03:33:27 +00:00
|
|
|
|
{this.itemRender(this.getJumpPrevPage(), 'jump-prev', this.getItemIcon('jumpPrevIcon'))}
|
2018-03-22 09:23:51 +00:00
|
|
|
|
</li>
|
2019-01-12 03:33:27 +00:00
|
|
|
|
);
|
|
|
|
|
let jumpNextClassString = `${prefixCls}-jump-next`;
|
2018-11-08 11:59:09 +00:00
|
|
|
|
if (props.jumpNextIcon) {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
jumpNextClassString += ` ${prefixCls}-jump-next-custom-icon`;
|
2018-11-08 11:59:09 +00:00
|
|
|
|
}
|
2018-03-22 09:23:51 +00:00
|
|
|
|
jumpNext = (
|
|
|
|
|
<li
|
|
|
|
|
title={this.showTitle ? nextItemTitle : null}
|
2019-01-12 03:33:27 +00:00
|
|
|
|
key="next"
|
|
|
|
|
tabIndex="0"
|
2018-03-22 09:23:51 +00:00
|
|
|
|
onClick={this.jumpNext}
|
|
|
|
|
onKeypress={this.runIfEnterJumpNext}
|
2018-11-08 11:59:09 +00:00
|
|
|
|
class={jumpNextClassString}
|
2018-03-22 09:23:51 +00:00
|
|
|
|
>
|
2019-01-12 03:33:27 +00:00
|
|
|
|
{this.itemRender(this.getJumpNextPage(), 'jump-next', this.getItemIcon('jumpNextIcon'))}
|
2018-03-22 09:23:51 +00:00
|
|
|
|
</li>
|
2019-01-12 03:33:27 +00:00
|
|
|
|
);
|
2018-03-22 09:23:51 +00:00
|
|
|
|
}
|
|
|
|
|
|
2018-03-05 11:06:44 +00:00
|
|
|
|
lastPager = (
|
|
|
|
|
<Pager
|
|
|
|
|
locale={locale}
|
|
|
|
|
last
|
|
|
|
|
rootPrefixCls={prefixCls}
|
|
|
|
|
onClick={this.handleChange}
|
|
|
|
|
onKeypress={this.runIfEnter}
|
|
|
|
|
key={allPages}
|
|
|
|
|
page={allPages}
|
|
|
|
|
active={false}
|
|
|
|
|
showTitle={this.showTitle}
|
|
|
|
|
itemRender={this.itemRender}
|
|
|
|
|
/>
|
2019-01-12 03:33:27 +00:00
|
|
|
|
);
|
2018-03-05 11:06:44 +00:00
|
|
|
|
firstPager = (
|
|
|
|
|
<Pager
|
|
|
|
|
locale={locale}
|
|
|
|
|
rootPrefixCls={prefixCls}
|
|
|
|
|
onClick={this.handleChange}
|
|
|
|
|
onKeypress={this.runIfEnter}
|
|
|
|
|
key={1}
|
|
|
|
|
page={1}
|
|
|
|
|
active={false}
|
|
|
|
|
showTitle={this.showTitle}
|
|
|
|
|
itemRender={this.itemRender}
|
|
|
|
|
/>
|
2019-01-12 03:33:27 +00:00
|
|
|
|
);
|
2018-03-05 11:06:44 +00:00
|
|
|
|
|
2019-01-12 03:33:27 +00:00
|
|
|
|
let left = Math.max(1, stateCurrent - pageBufferSize);
|
|
|
|
|
let right = Math.min(stateCurrent + pageBufferSize, allPages);
|
2018-03-05 11:06:44 +00:00
|
|
|
|
|
|
|
|
|
if (stateCurrent - 1 <= pageBufferSize) {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
right = 1 + pageBufferSize * 2;
|
2018-03-05 11:06:44 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (allPages - stateCurrent <= pageBufferSize) {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
left = allPages - pageBufferSize * 2;
|
2018-03-05 11:06:44 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for (let i = left; i <= right; i++) {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
const active = stateCurrent === i;
|
2018-03-05 11:06:44 +00:00
|
|
|
|
pagerList.push(
|
|
|
|
|
<Pager
|
|
|
|
|
locale={locale}
|
|
|
|
|
rootPrefixCls={prefixCls}
|
|
|
|
|
onClick={this.handleChange}
|
|
|
|
|
onKeypress={this.runIfEnter}
|
|
|
|
|
key={i}
|
|
|
|
|
page={i}
|
|
|
|
|
active={active}
|
|
|
|
|
showTitle={this.showTitle}
|
|
|
|
|
itemRender={this.itemRender}
|
2019-01-12 03:33:27 +00:00
|
|
|
|
/>,
|
|
|
|
|
);
|
2018-03-05 11:06:44 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (stateCurrent - 1 >= pageBufferSize * 2 && stateCurrent !== 1 + 2) {
|
|
|
|
|
pagerList[0] = (
|
|
|
|
|
<Pager
|
|
|
|
|
locale={locale}
|
|
|
|
|
rootPrefixCls={prefixCls}
|
|
|
|
|
onClick={this.handleChange}
|
|
|
|
|
onKeypress={this.runIfEnter}
|
|
|
|
|
key={left}
|
|
|
|
|
page={left}
|
|
|
|
|
class={`${prefixCls}-item-after-jump-prev`}
|
|
|
|
|
active={false}
|
|
|
|
|
showTitle={this.showTitle}
|
|
|
|
|
itemRender={this.itemRender}
|
|
|
|
|
/>
|
2019-01-12 03:33:27 +00:00
|
|
|
|
);
|
|
|
|
|
pagerList.unshift(jumpPrev);
|
2018-03-05 11:06:44 +00:00
|
|
|
|
}
|
|
|
|
|
if (allPages - stateCurrent >= pageBufferSize * 2 && stateCurrent !== allPages - 2) {
|
|
|
|
|
pagerList[pagerList.length - 1] = (
|
|
|
|
|
<Pager
|
|
|
|
|
locale={locale}
|
|
|
|
|
rootPrefixCls={prefixCls}
|
|
|
|
|
onClick={this.handleChange}
|
|
|
|
|
onKeypress={this.runIfEnter}
|
|
|
|
|
key={right}
|
|
|
|
|
page={right}
|
|
|
|
|
class={`${prefixCls}-item-before-jump-next`}
|
|
|
|
|
active={false}
|
|
|
|
|
showTitle={this.showTitle}
|
|
|
|
|
itemRender={this.itemRender}
|
|
|
|
|
/>
|
2019-01-12 03:33:27 +00:00
|
|
|
|
);
|
|
|
|
|
pagerList.push(jumpNext);
|
2018-03-05 11:06:44 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (left !== 1) {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
pagerList.unshift(firstPager);
|
2018-03-05 11:06:44 +00:00
|
|
|
|
}
|
|
|
|
|
if (right !== allPages) {
|
2019-01-12 03:33:27 +00:00
|
|
|
|
pagerList.push(lastPager);
|
2018-03-05 11:06:44 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2019-01-12 03:33:27 +00:00
|
|
|
|
let totalText = null;
|
2018-03-05 11:06:44 +00:00
|
|
|
|
|
|
|
|
|
if (this.showTotal) {
|
|
|
|
|
totalText = (
|
|
|
|
|
<li class={`${prefixCls}-total-text`}>
|
2019-01-12 03:33:27 +00:00
|
|
|
|
{this.showTotal(this.total, [
|
2019-08-27 15:11:12 +00:00
|
|
|
|
this.total === 0 ? 0 : (stateCurrent - 1) * statePageSize + 1,
|
2019-01-12 03:33:27 +00:00
|
|
|
|
stateCurrent * statePageSize > this.total ? this.total : stateCurrent * statePageSize,
|
|
|
|
|
])}
|
2018-03-05 11:06:44 +00:00
|
|
|
|
</li>
|
2019-01-12 03:33:27 +00:00
|
|
|
|
);
|
2018-03-05 11:06:44 +00:00
|
|
|
|
}
|
2019-01-12 03:33:27 +00:00
|
|
|
|
const prevDisabled = !this.hasPrev() || !allPages;
|
|
|
|
|
const nextDisabled = !this.hasNext() || !allPages;
|
|
|
|
|
const buildOptionText = this.buildOptionText || this.$scopedSlots.buildOptionText;
|
2018-03-05 11:06:44 +00:00
|
|
|
|
return (
|
2019-08-27 15:11:12 +00:00
|
|
|
|
<ul
|
|
|
|
|
class={{ [`${prefixCls}`]: true, [`${prefixCls}-disabled`]: disabled }}
|
|
|
|
|
unselectable="unselectable"
|
|
|
|
|
ref="paginationNode"
|
|
|
|
|
>
|
2018-03-05 11:06:44 +00:00
|
|
|
|
{totalText}
|
|
|
|
|
<li
|
|
|
|
|
title={this.showTitle ? locale.prev_page : null}
|
|
|
|
|
onClick={this.prev}
|
2018-03-09 04:20:21 +00:00
|
|
|
|
tabIndex={prevDisabled ? null : 0}
|
2018-03-05 11:06:44 +00:00
|
|
|
|
onKeypress={this.runIfEnterPrev}
|
|
|
|
|
class={`${!prevDisabled ? '' : `${prefixCls}-disabled`} ${prefixCls}-prev`}
|
|
|
|
|
aria-disabled={prevDisabled}
|
|
|
|
|
>
|
2019-01-12 03:33:27 +00:00
|
|
|
|
{this.itemRender(prevPage, 'prev', this.getItemIcon('prevIcon'))}
|
2018-03-05 11:06:44 +00:00
|
|
|
|
</li>
|
|
|
|
|
{pagerList}
|
|
|
|
|
<li
|
|
|
|
|
title={this.showTitle ? locale.next_page : null}
|
|
|
|
|
onClick={this.next}
|
2018-03-09 04:20:21 +00:00
|
|
|
|
tabIndex={nextDisabled ? null : 0}
|
2018-03-05 11:06:44 +00:00
|
|
|
|
onKeypress={this.runIfEnterNext}
|
|
|
|
|
class={`${!nextDisabled ? '' : `${prefixCls}-disabled`} ${prefixCls}-next`}
|
|
|
|
|
aria-disabled={nextDisabled}
|
|
|
|
|
>
|
2019-01-12 03:33:27 +00:00
|
|
|
|
{this.itemRender(nextPage, 'next', this.getItemIcon('nextIcon'))}
|
2018-03-05 11:06:44 +00:00
|
|
|
|
</li>
|
|
|
|
|
<Options
|
2019-08-27 15:11:12 +00:00
|
|
|
|
disabled={disabled}
|
2018-03-05 11:06:44 +00:00
|
|
|
|
locale={locale}
|
|
|
|
|
rootPrefixCls={prefixCls}
|
|
|
|
|
selectComponentClass={this.selectComponentClass}
|
|
|
|
|
selectPrefixCls={this.selectPrefixCls}
|
|
|
|
|
changeSize={this.showSizeChanger ? this.changePageSize : null}
|
|
|
|
|
current={stateCurrent}
|
|
|
|
|
pageSize={statePageSize}
|
|
|
|
|
pageSizeOptions={this.pageSizeOptions}
|
2018-03-06 07:40:42 +00:00
|
|
|
|
buildOptionText={buildOptionText || null}
|
2019-08-27 15:11:12 +00:00
|
|
|
|
quickGo={this.shouldDisplayQuickJumper() ? this.handleChange : null}
|
2018-03-05 11:06:44 +00:00
|
|
|
|
goButton={goButton}
|
|
|
|
|
/>
|
|
|
|
|
</ul>
|
2019-01-12 03:33:27 +00:00
|
|
|
|
);
|
2018-03-05 11:06:44 +00:00
|
|
|
|
},
|
2019-01-12 03:33:27 +00:00
|
|
|
|
};
|