ng-zorro-antd
Version:
An enterprise-class UI components based on Ant Design and Angular
424 lines • 34.6 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
/**
* @license
* Copyright Alibaba.com All Rights Reserved.
*
* Use of this source code is governed by an MIT-style license that can be
* found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE
*/
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Input, Output, TemplateRef, ViewChild, ViewEncapsulation } from '@angular/core';
import { Subject } from 'rxjs';
import { takeUntil } from 'rxjs/operators';
import { isInteger, toNumber, InputBoolean, InputNumber } from 'ng-zorro-antd/core';
import { NzI18nService } from 'ng-zorro-antd/i18n';
/**
* @record
*/
export function PaginationItemRenderContext() { }
if (false) {
/** @type {?} */
PaginationItemRenderContext.prototype.$implicit;
/** @type {?} */
PaginationItemRenderContext.prototype.page;
}
var NzPaginationComponent = /** @class */ (function () {
function NzPaginationComponent(i18n, cdr) {
this.i18n = i18n;
this.cdr = cdr;
// tslint:disable-next-line:no-any
this.locale = {};
this.firstIndex = 1;
this.pages = [];
this.$destroy = new Subject();
this.nzPageSizeChange = new EventEmitter();
this.nzPageIndexChange = new EventEmitter();
this.nzInTable = false;
this.nzSize = 'default';
this.nzPageSizeOptions = [10, 20, 30, 40];
this.nzDisabled = false;
this.nzShowSizeChanger = false;
this.nzHideOnSinglePage = false;
this.nzShowQuickJumper = false;
this.nzSimple = false;
this.nzTotal = 0;
this.nzPageIndex = 1;
this.nzPageSize = 10;
}
Object.defineProperty(NzPaginationComponent.prototype, "itemRender", {
get: /**
* @return {?}
*/
function () {
return this.nzItemRender || this.nzItemRenderChild;
},
enumerable: true,
configurable: true
});
/**
* @param {?} value
* @return {?}
*/
NzPaginationComponent.prototype.validatePageIndex = /**
* @param {?} value
* @return {?}
*/
function (value) {
if (value > this.lastIndex) {
return this.lastIndex;
}
else if (value < this.firstIndex) {
return this.firstIndex;
}
else {
return value;
}
};
/**
* @param {?} page
* @return {?}
*/
NzPaginationComponent.prototype.updatePageIndexValue = /**
* @param {?} page
* @return {?}
*/
function (page) {
this.nzPageIndex = page;
this.nzPageIndexChange.emit(this.nzPageIndex);
this.buildIndexes();
};
/**
* @param {?} value
* @return {?}
*/
NzPaginationComponent.prototype.isPageIndexValid = /**
* @param {?} value
* @return {?}
*/
function (value) {
return this.validatePageIndex(value) === value;
};
/**
* @param {?} index
* @return {?}
*/
NzPaginationComponent.prototype.jumpPage = /**
* @param {?} index
* @return {?}
*/
function (index) {
if (index !== this.nzPageIndex && !this.nzDisabled) {
/** @type {?} */
var pageIndex = this.validatePageIndex(index);
if (pageIndex !== this.nzPageIndex) {
this.updatePageIndexValue(pageIndex);
}
}
};
/**
* @param {?} diff
* @return {?}
*/
NzPaginationComponent.prototype.jumpDiff = /**
* @param {?} diff
* @return {?}
*/
function (diff) {
this.jumpPage(this.nzPageIndex + diff);
};
/**
* @param {?} $event
* @return {?}
*/
NzPaginationComponent.prototype.onPageSizeChange = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
this.nzPageSize = $event;
this.nzPageSizeChange.emit($event);
this.buildIndexes();
if (this.nzPageIndex > this.lastIndex) {
this.updatePageIndexValue(this.lastIndex);
}
};
/**
* @param {?} _
* @param {?} input
* @param {?} clearInputValue
* @return {?}
*/
NzPaginationComponent.prototype.handleKeyDown = /**
* @param {?} _
* @param {?} input
* @param {?} clearInputValue
* @return {?}
*/
function (_, input, clearInputValue) {
/** @type {?} */
var target = input;
/** @type {?} */
var page = toNumber(target.value, this.nzPageIndex);
if (isInteger(page) && this.isPageIndexValid(page) && page !== this.nzPageIndex) {
this.updatePageIndexValue(page);
}
if (clearInputValue) {
target.value = '';
}
else {
target.value = "" + this.nzPageIndex;
}
};
/** generate indexes list */
/**
* generate indexes list
* @return {?}
*/
NzPaginationComponent.prototype.buildIndexes = /**
* generate indexes list
* @return {?}
*/
function () {
/** @type {?} */
var pages = [];
if (this.lastIndex <= 9) {
for (var i = 2; i <= this.lastIndex - 1; i++) {
pages.push(i);
}
}
else {
/** @type {?} */
var current = +this.nzPageIndex;
/** @type {?} */
var left = Math.max(2, current - 2);
/** @type {?} */
var right = Math.min(current + 2, this.lastIndex - 1);
if (current - 1 <= 2) {
right = 5;
}
if (this.lastIndex - current <= 2) {
left = this.lastIndex - 4;
}
for (var i = left; i <= right; i++) {
pages.push(i);
}
}
this.pages = pages;
this.cdr.markForCheck();
};
Object.defineProperty(NzPaginationComponent.prototype, "lastIndex", {
get: /**
* @return {?}
*/
function () {
return Math.ceil(this.nzTotal / this.nzPageSize);
},
enumerable: true,
configurable: true
});
Object.defineProperty(NzPaginationComponent.prototype, "isLastIndex", {
get: /**
* @return {?}
*/
function () {
return this.nzPageIndex === this.lastIndex;
},
enumerable: true,
configurable: true
});
Object.defineProperty(NzPaginationComponent.prototype, "isFirstIndex", {
get: /**
* @return {?}
*/
function () {
return this.nzPageIndex === this.firstIndex;
},
enumerable: true,
configurable: true
});
Object.defineProperty(NzPaginationComponent.prototype, "ranges", {
get: /**
* @return {?}
*/
function () {
return [(this.nzPageIndex - 1) * this.nzPageSize + 1, Math.min(this.nzPageIndex * this.nzPageSize, this.nzTotal)];
},
enumerable: true,
configurable: true
});
Object.defineProperty(NzPaginationComponent.prototype, "showAddOption", {
get: /**
* @return {?}
*/
function () {
return this.nzPageSizeOptions.indexOf(this.nzPageSize) === -1;
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
NzPaginationComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
var _this = this;
this.i18n.localeChange.pipe(takeUntil(this.$destroy)).subscribe((/**
* @return {?}
*/
function () {
_this.locale = _this.i18n.getLocaleData('Pagination');
_this.cdr.markForCheck();
}));
};
/**
* @return {?}
*/
NzPaginationComponent.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
this.$destroy.next();
this.$destroy.complete();
};
/**
* @param {?} changes
* @return {?}
*/
NzPaginationComponent.prototype.ngOnChanges = /**
* @param {?} changes
* @return {?}
*/
function (changes) {
if (changes.nzTotal || changes.nzPageSize || changes.nzPageIndex) {
this.buildIndexes();
}
};
NzPaginationComponent.decorators = [
{ type: Component, args: [{
selector: 'nz-pagination',
exportAs: 'nzPagination',
preserveWhitespaces: false,
encapsulation: ViewEncapsulation.None,
changeDetection: ChangeDetectionStrategy.OnPush,
template: "<ng-template #renderItemTemplate let-type let-page=\"page\">\n <a class=\"ant-pagination-item-link\" *ngIf=\"type==='pre'\">\n <i nz-icon nzType=\"left\"></i>\n </a>\n <a class=\"ant-pagination-item-link\" *ngIf=\"type==='next'\">\n <i nz-icon nzType=\"right\"></i>\n </a>\n <a *ngIf=\"type=='page'\">{{ page }}</a>\n</ng-template>\n<ng-container *ngIf=\"(nzHideOnSinglePage && (nzTotal > nzPageSize)) || (nzTotal && !nzHideOnSinglePage)\">\n <ul class=\"ant-pagination\"\n [class.ant-table-pagination]=\"nzInTable\"\n [class.ant-pagination-simple]=\"nzSimple\"\n [class.ant-pagination-disabled]=\"nzDisabled\"\n [class.mini]=\"(nzSize === 'small') && !nzSimple\">\n <ng-container *ngIf=\"nzSimple; else normalTemplate\">\n <li class=\"ant-pagination-prev\"\n [attr.title]=\"locale.prev_page\"\n [class.ant-pagination-disabled]=\"isFirstIndex\"\n (click)=\"jumpDiff(-1)\">\n <ng-template [ngTemplateOutlet]=\"itemRender\" [ngTemplateOutletContext]=\"{ $implicit: 'pre'}\"></ng-template>\n </li>\n <li [attr.title]=\"nzPageIndex+'/'+lastIndex\" class=\"ant-pagination-simple-pager\">\n <input #simplePagerInput\n [disabled]=\"nzDisabled\"\n [value]=\"nzPageIndex\"\n (keydown.enter)=\"handleKeyDown($event,simplePagerInput,false)\"\n size=\"3\">\n <span class=\"ant-pagination-slash\">\uFF0F</span>\n {{ lastIndex }}\n </li>\n <li class=\"ant-pagination-next\"\n [attr.title]=\"locale.next_page\"\n [class.ant-pagination-disabled]=\"isLastIndex\"\n (click)=\"jumpDiff(1)\">\n <ng-template [ngTemplateOutlet]=\"itemRender\" [ngTemplateOutletContext]=\"{ $implicit: 'next'}\"></ng-template>\n </li>\n </ng-container>\n <ng-template #normalTemplate>\n <li class=\"ant-pagination-total-text\" *ngIf=\"nzShowTotal\">\n <ng-template [ngTemplateOutlet]=\"nzShowTotal\"\n [ngTemplateOutletContext]=\"{ $implicit: nzTotal,range:ranges }\"></ng-template>\n </li>\n <li class=\"ant-pagination-prev\"\n [attr.title]=\"locale.prev_page\"\n [class.ant-pagination-disabled]=\"isFirstIndex\"\n (click)=\"jumpDiff(-1)\">\n <ng-template [ngTemplateOutlet]=\"itemRender\" [ngTemplateOutletContext]=\"{ $implicit: 'pre'}\"></ng-template>\n </li>\n <li class=\"ant-pagination-item\"\n [attr.title]=\"firstIndex\"\n [class.ant-pagination-item-active]=\"isFirstIndex\"\n (click)=\"jumpPage(firstIndex)\">\n <ng-template [ngTemplateOutlet]=\"itemRender\"\n [ngTemplateOutletContext]=\"{ $implicit: 'page',page: firstIndex }\"></ng-template>\n </li>\n <li class=\"ant-pagination-jump-prev\"\n *ngIf=\"(lastIndex > 9) && (nzPageIndex - 3 > firstIndex)\"\n [attr.title]=\"locale.prev_5\"\n (click)=\"jumpDiff(-5)\">\n <a class=\"ant-pagination-item-link\">\n <div class=\"ant-pagination-item-container\">\n <i nz-icon nzType=\"double-left\" class=\"ant-pagination-item-link-icon\"></i>\n <span class=\"ant-pagination-item-ellipsis\">\u2022\u2022\u2022</span>\n </div>\n </a>\n </li>\n <li class=\"ant-pagination-item\"\n *ngFor=\"let page of pages\"\n [attr.title]=\"page\"\n [class.ant-pagination-item-active]=\"nzPageIndex === page\"\n (click)=\"jumpPage(page)\">\n <ng-template [ngTemplateOutlet]=\"itemRender\"\n [ngTemplateOutletContext]=\"{ $implicit: 'page',page: page }\"></ng-template>\n </li>\n <li class=\"ant-pagination-jump-next ant-pagination-item-link-icon\"\n [attr.title]=\"locale.next_5\"\n (click)=\"jumpDiff(5)\"\n *ngIf=\"(lastIndex > 9) && (nzPageIndex + 3 < lastIndex)\">\n <a class=\"ant-pagination-item-link\">\n <div class=\"ant-pagination-item-container\">\n <i nz-icon nzType=\"double-right\" class=\"ant-pagination-item-link-icon\"></i>\n <span class=\"ant-pagination-item-ellipsis\">\u2022\u2022\u2022</span>\n </div>\n </a>\n </li>\n <li class=\"ant-pagination-item\"\n [attr.title]=\"lastIndex\"\n (click)=\"jumpPage(lastIndex)\"\n *ngIf=\"(lastIndex > 0) && (lastIndex !== firstIndex)\"\n [class.ant-pagination-item-active]=\"isLastIndex\">\n <ng-template [ngTemplateOutlet]=\"itemRender\"\n [ngTemplateOutletContext]=\"{ $implicit: 'page',page: lastIndex }\"></ng-template>\n </li>\n <li class=\"ant-pagination-next\"\n [title]=\"locale.next_page\"\n [class.ant-pagination-disabled]=\"isLastIndex\"\n (click)=\"jumpDiff(1)\">\n <ng-template [ngTemplateOutlet]=\"itemRender\" [ngTemplateOutletContext]=\"{ $implicit: 'next'}\"></ng-template>\n </li>\n <div class=\"ant-pagination-options\" *ngIf=\"nzShowQuickJumper || nzShowSizeChanger\">\n <nz-select class=\"ant-pagination-options-size-changer\"\n *ngIf=\"nzShowSizeChanger\"\n [nzDisabled]=\"nzDisabled\"\n [nzSize]=\"nzSize\"\n [ngModel]=\"nzPageSize\"\n (ngModelChange)=\"onPageSizeChange($event)\">\n <nz-option *ngFor=\"let option of nzPageSizeOptions\"\n [nzLabel]=\"option + ' ' + locale.items_per_page\"\n [nzValue]=\"option\">\n </nz-option>\n <nz-option *ngIf=\"showAddOption\"\n [nzLabel]=\"nzPageSize + ' ' + locale.items_per_page\"\n [nzValue]=\"nzPageSize\">\n </nz-option>\n </nz-select>\n <div class=\"ant-pagination-options-quick-jumper\" *ngIf=\"nzShowQuickJumper\">\n {{ locale.jump_to }}\n <input #quickJumperInput\n [disabled]=\"nzDisabled\"\n (keydown.enter)=\"handleKeyDown($event,quickJumperInput,true)\">\n {{ locale.page }}\n </div>\n </div>\n </ng-template>\n </ul>\n</ng-container>\n"
}] }
];
/** @nocollapse */
NzPaginationComponent.ctorParameters = function () { return [
{ type: NzI18nService },
{ type: ChangeDetectorRef }
]; };
NzPaginationComponent.propDecorators = {
nzPageSizeChange: [{ type: Output }],
nzPageIndexChange: [{ type: Output }],
nzShowTotal: [{ type: Input }],
nzInTable: [{ type: Input }],
nzSize: [{ type: Input }],
nzPageSizeOptions: [{ type: Input }],
nzItemRender: [{ type: Input }],
nzItemRenderChild: [{ type: ViewChild, args: ['renderItemTemplate', { static: true },] }],
nzDisabled: [{ type: Input }],
nzShowSizeChanger: [{ type: Input }],
nzHideOnSinglePage: [{ type: Input }],
nzShowQuickJumper: [{ type: Input }],
nzSimple: [{ type: Input }],
nzTotal: [{ type: Input }],
nzPageIndex: [{ type: Input }],
nzPageSize: [{ type: Input }]
};
tslib_1.__decorate([
InputBoolean(),
tslib_1.__metadata("design:type", Object)
], NzPaginationComponent.prototype, "nzDisabled", void 0);
tslib_1.__decorate([
InputBoolean(),
tslib_1.__metadata("design:type", Object)
], NzPaginationComponent.prototype, "nzShowSizeChanger", void 0);
tslib_1.__decorate([
InputBoolean(),
tslib_1.__metadata("design:type", Object)
], NzPaginationComponent.prototype, "nzHideOnSinglePage", void 0);
tslib_1.__decorate([
InputBoolean(),
tslib_1.__metadata("design:type", Object)
], NzPaginationComponent.prototype, "nzShowQuickJumper", void 0);
tslib_1.__decorate([
InputBoolean(),
tslib_1.__metadata("design:type", Object)
], NzPaginationComponent.prototype, "nzSimple", void 0);
tslib_1.__decorate([
InputNumber(),
tslib_1.__metadata("design:type", Object)
], NzPaginationComponent.prototype, "nzTotal", void 0);
tslib_1.__decorate([
InputNumber(),
tslib_1.__metadata("design:type", Object)
], NzPaginationComponent.prototype, "nzPageIndex", void 0);
tslib_1.__decorate([
InputNumber(),
tslib_1.__metadata("design:type", Object)
], NzPaginationComponent.prototype, "nzPageSize", void 0);
return NzPaginationComponent;
}());
export { NzPaginationComponent };
if (false) {
/** @type {?} */
NzPaginationComponent.prototype.locale;
/** @type {?} */
NzPaginationComponent.prototype.firstIndex;
/** @type {?} */
NzPaginationComponent.prototype.pages;
/**
* @type {?}
* @private
*/
NzPaginationComponent.prototype.$destroy;
/** @type {?} */
NzPaginationComponent.prototype.nzPageSizeChange;
/** @type {?} */
NzPaginationComponent.prototype.nzPageIndexChange;
/** @type {?} */
NzPaginationComponent.prototype.nzShowTotal;
/** @type {?} */
NzPaginationComponent.prototype.nzInTable;
/** @type {?} */
NzPaginationComponent.prototype.nzSize;
/** @type {?} */
NzPaginationComponent.prototype.nzPageSizeOptions;
/** @type {?} */
NzPaginationComponent.prototype.nzItemRender;
/** @type {?} */
NzPaginationComponent.prototype.nzItemRenderChild;
/** @type {?} */
NzPaginationComponent.prototype.nzDisabled;
/** @type {?} */
NzPaginationComponent.prototype.nzShowSizeChanger;
/** @type {?} */
NzPaginationComponent.prototype.nzHideOnSinglePage;
/** @type {?} */
NzPaginationComponent.prototype.nzShowQuickJumper;
/** @type {?} */
NzPaginationComponent.prototype.nzSimple;
/** @type {?} */
NzPaginationComponent.prototype.nzTotal;
/** @type {?} */
NzPaginationComponent.prototype.nzPageIndex;
/** @type {?} */
NzPaginationComponent.prototype.nzPageSize;
/**
* @type {?}
* @private
*/
NzPaginationComponent.prototype.i18n;
/**
* @type {?}
* @private
*/
NzPaginationComponent.prototype.cdr;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nz-pagination.component.js","sourceRoot":"ng://ng-zorro-antd/pagination/","sources":["nz-pagination.component.ts"],"names":[],"mappings":";;;;;;;;;;;;AAQA,OAAO,EACL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,YAAY,EACZ,KAAK,EAIL,MAAM,EAEN,WAAW,EACX,SAAS,EACT,iBAAiB,EAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAE3C,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AACpF,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;;;;AAEnD,iDAGC;;;IAFC,gDAAoC;;IACpC,2CAAa;;AAGf;IAwIE,+BAAoB,IAAmB,EAAU,GAAsB;QAAnD,SAAI,GAAJ,IAAI,CAAe;QAAU,QAAG,GAAH,GAAG,CAAmB;;QA9HvE,WAAM,GAAQ,EAAE,CAAC;QACjB,eAAU,GAAG,CAAC,CAAC;QACf,UAAK,GAAa,EAAE,CAAC;QACb,aAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;QACpB,qBAAgB,GAAyB,IAAI,YAAY,EAAE,CAAC;QAC5D,sBAAiB,GAAyB,IAAI,YAAY,EAAE,CAAC;QAEvE,cAAS,GAAG,KAAK,CAAC;QAClB,WAAM,GAAwB,SAAS,CAAC;QACxC,sBAAiB,GAAG,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;QAQrB,eAAU,GAAG,KAAK,CAAC;QACnB,sBAAiB,GAAG,KAAK,CAAC;QAC1B,uBAAkB,GAAG,KAAK,CAAC;QAC3B,sBAAiB,GAAG,KAAK,CAAC;QAC1B,aAAQ,GAAG,KAAK,CAAC;QAClB,YAAO,GAAG,CAAC,CAAC;QACZ,gBAAW,GAAG,CAAC,CAAC;QAChB,eAAU,GAAG,EAAE,CAAC;IAsGkC,CAAC;IAjH3E,sBAAI,6CAAU;;;;QAAd;YACE,OAAO,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,iBAAiB,CAAC;QACrD,CAAC;;;OAAA;;;;;IAWD,iDAAiB;;;;IAAjB,UAAkB,KAAa;QAC7B,IAAI,KAAK,GAAG,IAAI,CAAC,SAAS,EAAE;YAC1B,OAAO,IAAI,CAAC,SAAS,CAAC;SACvB;aAAM,IAAI,KAAK,GAAG,IAAI,CAAC,UAAU,EAAE;YAClC,OAAO,IAAI,CAAC,UAAU,CAAC;SACxB;aAAM;YACL,OAAO,KAAK,CAAC;SACd;IACH,CAAC;;;;;IAED,oDAAoB;;;;IAApB,UAAqB,IAAY;QAC/B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAC9C,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;;;;;IAED,gDAAgB;;;;IAAhB,UAAiB,KAAa;QAC5B,OAAO,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,KAAK,KAAK,CAAC;IACjD,CAAC;;;;;IAED,wCAAQ;;;;IAAR,UAAS,KAAa;QACpB,IAAI,KAAK,KAAK,IAAI,CAAC,WAAW,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;;gBAC5C,SAAS,GAAG,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC;YAC/C,IAAI,SAAS,KAAK,IAAI,CAAC,WAAW,EAAE;gBAClC,IAAI,CAAC,oBAAoB,CAAC,SAAS,CAAC,CAAC;aACtC;SACF;IACH,CAAC;;;;;IAED,wCAAQ;;;;IAAR,UAAS,IAAY;QACnB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,CAAC;IACzC,CAAC;;;;;IAED,gDAAgB;;;;IAAhB,UAAiB,MAAc;QAC7B,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC;QACzB,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACnC,IAAI,CAAC,YAAY,EAAE,CAAC;QACpB,IAAI,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,SAAS,EAAE;YACrC,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;SAC3C;IACH,CAAC;;;;;;;IAED,6CAAa;;;;;;IAAb,UAAc,CAAgB,EAAE,KAAuB,EAAE,eAAwB;;YACzE,MAAM,GAAG,KAAK;;YACd,IAAI,GAAG,QAAQ,CAAC,MAAM,CAAC,KAAK,EAAE,IAAI,CAAC,WAAW,CAAC;QACrD,IAAI,SAAS,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,IAAI,KAAK,IAAI,CAAC,WAAW,EAAE;YAC/E,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,CAAC;SACjC;QACD,IAAI,eAAe,EAAE;YACnB,MAAM,CAAC,KAAK,GAAG,EAAE,CAAC;SACnB;aAAM;YACL,MAAM,CAAC,KAAK,GAAG,KAAG,IAAI,CAAC,WAAa,CAAC;SACtC;IACH,CAAC;IAED,4BAA4B;;;;;IAC5B,4CAAY;;;;IAAZ;;YACQ,KAAK,GAAa,EAAE;QAC1B,IAAI,IAAI,CAAC,SAAS,IAAI,CAAC,EAAE;YACvB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,IAAI,CAAC,SAAS,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE;gBAC5C,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;aACf;SACF;aAAM;;gBACC,OAAO,GAAG,CAAC,IAAI,CAAC,WAAW;;gBAC7B,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,OAAO,GAAG,CAAC,CAAC;;gBAC/B,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,OAAO,GAAG,CAAC,EAAE,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC;YACrD,IAAI,OAAO,GAAG,CAAC,IAAI,CAAC,EAAE;gBACpB,KAAK,GAAG,CAAC,CAAC;aACX;YACD,IAAI,IAAI,CAAC,SAAS,GAAG,OAAO,IAAI,CAAC,EAAE;gBACjC,IAAI,GAAG,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC;aAC3B;YACD,KAAK,IAAI,CAAC,GAAG,IAAI,EAAE,CAAC,IAAI,KAAK,EAAE,CAAC,EAAE,EAAE;gBAClC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;aACf;SACF;QACD,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC1B,CAAC;IAED,sBAAI,4CAAS;;;;QAAb;YACE,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC;QACnD,CAAC;;;OAAA;IAED,sBAAI,8CAAW;;;;QAAf;YACE,OAAO,IAAI,CAAC,WAAW,KAAK,IAAI,CAAC,SAAS,CAAC;QAC7C,CAAC;;;OAAA;IAED,sBAAI,+CAAY;;;;QAAhB;YACE,OAAO,IAAI,CAAC,WAAW,KAAK,IAAI,CAAC,UAAU,CAAC;QAC9C,CAAC;;;OAAA;IAED,sBAAI,yCAAM;;;;QAAV;YACE,OAAO,CAAC,CAAC,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,UAAU,GAAG,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;QACpH,CAAC;;;OAAA;IAED,sBAAI,gDAAa;;;;QAAjB;YACE,OAAO,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC;QAChE,CAAC;;;OAAA;;;;IAID,wCAAQ;;;IAAR;QAAA,iBAKC;QAJC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS;;;QAAC;YAC9D,KAAI,CAAC,MAAM,GAAG,KAAI,CAAC,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC;YACpD,KAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;QAC1B,CAAC,EAAC,CAAC;IACL,CAAC;;;;IAED,2CAAW;;;IAAX;QACE,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;;;;;IAED,2CAAW;;;;IAAX,UAAY,OAAsB;QAChC,IAAI,OAAO,CAAC,OAAO,IAAI,OAAO,CAAC,UAAU,IAAI,OAAO,CAAC,WAAW,EAAE;YAChE,IAAI,CAAC,YAAY,EAAE,CAAC;SACrB;IACH,CAAC;;gBA1JF,SAAS,SAAC;oBACT,QAAQ,EAAE,eAAe;oBACzB,QAAQ,EAAE,cAAc;oBACxB,mBAAmB,EAAE,KAAK;oBAC1B,aAAa,EAAE,iBAAiB,CAAC,IAAI;oBACrC,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,6kMAA6C;iBAC9C;;;;gBAdQ,aAAa;gBAjBpB,iBAAiB;;;mCAsChB,MAAM;oCACN,MAAM;8BACN,KAAK;4BACL,KAAK;yBACL,KAAK;oCACL,KAAK;+BAEL,KAAK;oCACL,SAAS,SAAC,oBAAoB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;6BAKhD,KAAK;oCACL,KAAK;qCACL,KAAK;oCACL,KAAK;2BACL,KAAK;0BACL,KAAK;8BACL,KAAK;6BACL,KAAK;;IAPmB;QAAf,YAAY,EAAE;;6DAAoB;IACnB;QAAf,YAAY,EAAE;;oEAA2B;IAC1B;QAAf,YAAY,EAAE;;qEAA4B;IAC3B;QAAf,YAAY,EAAE;;oEAA2B;IAC1B;QAAf,YAAY,EAAE;;2DAAkB;IAClB;QAAd,WAAW,EAAE;;0DAAa;IACZ;QAAd,WAAW,EAAE;;8DAAiB;IAChB;QAAd,WAAW,EAAE;;6DAAiB;IAyH1C,4BAAC;CAAA,AA3JD,IA2JC;SAnJY,qBAAqB;;;IAEhC,uCAAiB;;IACjB,2CAAe;;IACf,sCAAqB;;;;;IACrB,yCAAuC;;IACvC,iDAA+E;;IAC/E,kDAAgF;;IAChF,4CAAkF;;IAClF,0CAA2B;;IAC3B,uCAAiD;;IACjD,kDAA8C;;IAE9C,6CAAgE;;IAChE,kDAA+G;;IAK/G,2CAA4C;;IAC5C,kDAAmD;;IACnD,mDAAoD;;IACpD,kDAAmD;;IACnD,yCAA0C;;IAC1C,wCAAoC;;IACpC,4CAAwC;;IACxC,2CAAwC;;;;;IAsG5B,qCAA2B;;;;;IAAE,oCAA8B","sourcesContent":["/**\n * @license\n * Copyright Alibaba.com All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE\n */\n\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { isInteger, toNumber, InputBoolean, InputNumber } from 'ng-zorro-antd/core';\nimport { NzI18nService } from 'ng-zorro-antd/i18n';\n\nexport interface PaginationItemRenderContext {\n  $implicit: 'page' | 'prev' | 'next';\n  page: number;\n}\n\n@Component({\n  selector: 'nz-pagination',\n  exportAs: 'nzPagination',\n  preserveWhitespaces: false,\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  templateUrl: './nz-pagination.component.html'\n})\nexport class NzPaginationComponent implements OnInit, OnDestroy, OnChanges {\n  // tslint:disable-next-line:no-any\n  locale: any = {};\n  firstIndex = 1;\n  pages: number[] = [];\n  private $destroy = new Subject<void>();\n  @Output() readonly nzPageSizeChange: EventEmitter<number> = new EventEmitter();\n  @Output() readonly nzPageIndexChange: EventEmitter<number> = new EventEmitter();\n  @Input() nzShowTotal: TemplateRef<{ $implicit: number; range: [number, number] }>;\n  @Input() nzInTable = false;\n  @Input() nzSize: 'default' | 'small' = 'default';\n  @Input() nzPageSizeOptions = [10, 20, 30, 40];\n\n  @Input() nzItemRender: TemplateRef<PaginationItemRenderContext>;\n  @ViewChild('renderItemTemplate', { static: true }) nzItemRenderChild: TemplateRef<PaginationItemRenderContext>;\n  get itemRender(): TemplateRef<PaginationItemRenderContext> {\n    return this.nzItemRender || this.nzItemRenderChild;\n  }\n\n  @Input() @InputBoolean() nzDisabled = false;\n  @Input() @InputBoolean() nzShowSizeChanger = false;\n  @Input() @InputBoolean() nzHideOnSinglePage = false;\n  @Input() @InputBoolean() nzShowQuickJumper = false;\n  @Input() @InputBoolean() nzSimple = false;\n  @Input() @InputNumber() nzTotal = 0;\n  @Input() @InputNumber() nzPageIndex = 1;\n  @Input() @InputNumber() nzPageSize = 10;\n\n  validatePageIndex(value: number): number {\n    if (value > this.lastIndex) {\n      return this.lastIndex;\n    } else if (value < this.firstIndex) {\n      return this.firstIndex;\n    } else {\n      return value;\n    }\n  }\n\n  updatePageIndexValue(page: number): void {\n    this.nzPageIndex = page;\n    this.nzPageIndexChange.emit(this.nzPageIndex);\n    this.buildIndexes();\n  }\n\n  isPageIndexValid(value: number): boolean {\n    return this.validatePageIndex(value) === value;\n  }\n\n  jumpPage(index: number): void {\n    if (index !== this.nzPageIndex && !this.nzDisabled) {\n      const pageIndex = this.validatePageIndex(index);\n      if (pageIndex !== this.nzPageIndex) {\n        this.updatePageIndexValue(pageIndex);\n      }\n    }\n  }\n\n  jumpDiff(diff: number): void {\n    this.jumpPage(this.nzPageIndex + diff);\n  }\n\n  onPageSizeChange($event: number): void {\n    this.nzPageSize = $event;\n    this.nzPageSizeChange.emit($event);\n    this.buildIndexes();\n    if (this.nzPageIndex > this.lastIndex) {\n      this.updatePageIndexValue(this.lastIndex);\n    }\n  }\n\n  handleKeyDown(_: KeyboardEvent, input: HTMLInputElement, clearInputValue: boolean): void {\n    const target = input;\n    const page = toNumber(target.value, this.nzPageIndex);\n    if (isInteger(page) && this.isPageIndexValid(page) && page !== this.nzPageIndex) {\n      this.updatePageIndexValue(page);\n    }\n    if (clearInputValue) {\n      target.value = '';\n    } else {\n      target.value = `${this.nzPageIndex}`;\n    }\n  }\n\n  /** generate indexes list */\n  buildIndexes(): void {\n    const pages: number[] = [];\n    if (this.lastIndex <= 9) {\n      for (let i = 2; i <= this.lastIndex - 1; i++) {\n        pages.push(i);\n      }\n    } else {\n      const current = +this.nzPageIndex;\n      let left = Math.max(2, current - 2);\n      let right = Math.min(current + 2, this.lastIndex - 1);\n      if (current - 1 <= 2) {\n        right = 5;\n      }\n      if (this.lastIndex - current <= 2) {\n        left = this.lastIndex - 4;\n      }\n      for (let i = left; i <= right; i++) {\n        pages.push(i);\n      }\n    }\n    this.pages = pages;\n    this.cdr.markForCheck();\n  }\n\n  get lastIndex(): number {\n    return Math.ceil(this.nzTotal / this.nzPageSize);\n  }\n\n  get isLastIndex(): boolean {\n    return this.nzPageIndex === this.lastIndex;\n  }\n\n  get isFirstIndex(): boolean {\n    return this.nzPageIndex === this.firstIndex;\n  }\n\n  get ranges(): number[] {\n    return [(this.nzPageIndex - 1) * this.nzPageSize + 1, Math.min(this.nzPageIndex * this.nzPageSize, this.nzTotal)];\n  }\n\n  get showAddOption(): boolean {\n    return this.nzPageSizeOptions.indexOf(this.nzPageSize) === -1;\n  }\n\n  constructor(private i18n: NzI18nService, private cdr: ChangeDetectorRef) {}\n\n  ngOnInit(): void {\n    this.i18n.localeChange.pipe(takeUntil(this.$destroy)).subscribe(() => {\n      this.locale = this.i18n.getLocaleData('Pagination');\n      this.cdr.markForCheck();\n    });\n  }\n\n  ngOnDestroy(): void {\n    this.$destroy.next();\n    this.$destroy.complete();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.nzTotal || changes.nzPageSize || changes.nzPageIndex) {\n      this.buildIndexes();\n    }\n  }\n}\n"]}