import { Component, ContentChild, Directive, EventEmitter, Input, Output, ChangeDetectionStrategy, } from '@angular/core';
import { getValueInRange, isNumber } from '../util/util';
import * as i0 from "@angular/core";
import * as i1 from "./pagination-config";
import * as i2 from "@angular/common";
/**
* A directive to match the 'ellipsis' link template
*
* @since 4.1.0
*/
export class NgbPaginationEllipsis {
constructor(templateRef) {
this.templateRef = templateRef;
}
}
NgbPaginationEllipsis.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.6", ngImport: i0, type: NgbPaginationEllipsis, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive });
NgbPaginationEllipsis.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.6", type: NgbPaginationEllipsis, selector: "ng-template[ngbPaginationEllipsis]", ngImport: i0 });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.6", ngImport: i0, type: NgbPaginationEllipsis, decorators: [{
type: Directive,
args: [{ selector: 'ng-template[ngbPaginationEllipsis]' }]
}], ctorParameters: function () { return [{ type: i0.TemplateRef }]; } });
/**
* A directive to match the 'first' link template
*
* @since 4.1.0
*/
export class NgbPaginationFirst {
constructor(templateRef) {
this.templateRef = templateRef;
}
}
NgbPaginationFirst.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.6", ngImport: i0, type: NgbPaginationFirst, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive });
NgbPaginationFirst.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.6", type: NgbPaginationFirst, selector: "ng-template[ngbPaginationFirst]", ngImport: i0 });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.6", ngImport: i0, type: NgbPaginationFirst, decorators: [{
type: Directive,
args: [{ selector: 'ng-template[ngbPaginationFirst]' }]
}], ctorParameters: function () { return [{ type: i0.TemplateRef }]; } });
/**
* A directive to match the 'last' link template
*
* @since 4.1.0
*/
export class NgbPaginationLast {
constructor(templateRef) {
this.templateRef = templateRef;
}
}
NgbPaginationLast.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.6", ngImport: i0, type: NgbPaginationLast, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive });
NgbPaginationLast.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.6", type: NgbPaginationLast, selector: "ng-template[ngbPaginationLast]", ngImport: i0 });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.6", ngImport: i0, type: NgbPaginationLast, decorators: [{
type: Directive,
args: [{ selector: 'ng-template[ngbPaginationLast]' }]
}], ctorParameters: function () { return [{ type: i0.TemplateRef }]; } });
/**
* A directive to match the 'next' link template
*
* @since 4.1.0
*/
export class NgbPaginationNext {
constructor(templateRef) {
this.templateRef = templateRef;
}
}
NgbPaginationNext.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.6", ngImport: i0, type: NgbPaginationNext, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive });
NgbPaginationNext.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.6", type: NgbPaginationNext, selector: "ng-template[ngbPaginationNext]", ngImport: i0 });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.6", ngImport: i0, type: NgbPaginationNext, decorators: [{
type: Directive,
args: [{ selector: 'ng-template[ngbPaginationNext]' }]
}], ctorParameters: function () { return [{ type: i0.TemplateRef }]; } });
/**
* A directive to match the page 'number' link template
*
* @since 4.1.0
*/
export class NgbPaginationNumber {
constructor(templateRef) {
this.templateRef = templateRef;
}
}
NgbPaginationNumber.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.6", ngImport: i0, type: NgbPaginationNumber, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive });
NgbPaginationNumber.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.6", type: NgbPaginationNumber, selector: "ng-template[ngbPaginationNumber]", ngImport: i0 });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.6", ngImport: i0, type: NgbPaginationNumber, decorators: [{
type: Directive,
args: [{ selector: 'ng-template[ngbPaginationNumber]' }]
}], ctorParameters: function () { return [{ type: i0.TemplateRef }]; } });
/**
* A directive to match the 'previous' link template
*
* @since 4.1.0
*/
export class NgbPaginationPrevious {
constructor(templateRef) {
this.templateRef = templateRef;
}
}
NgbPaginationPrevious.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.6", ngImport: i0, type: NgbPaginationPrevious, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive });
NgbPaginationPrevious.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.6", type: NgbPaginationPrevious, selector: "ng-template[ngbPaginationPrevious]", ngImport: i0 });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.6", ngImport: i0, type: NgbPaginationPrevious, decorators: [{
type: Directive,
args: [{ selector: 'ng-template[ngbPaginationPrevious]' }]
}], ctorParameters: function () { return [{ type: i0.TemplateRef }]; } });
/**
* A directive to match the 'pages' whole content
*
* @since 9.1.0
*/
export class NgbPaginationPages {
constructor(templateRef) {
this.templateRef = templateRef;
}
}
NgbPaginationPages.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.6", ngImport: i0, type: NgbPaginationPages, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive });
NgbPaginationPages.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.6", type: NgbPaginationPages, selector: "ng-template[ngbPaginationPages]", ngImport: i0 });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.6", ngImport: i0, type: NgbPaginationPages, decorators: [{
type: Directive,
args: [{ selector: 'ng-template[ngbPaginationPages]' }]
}], ctorParameters: function () { return [{ type: i0.TemplateRef }]; } });
/**
* A component that displays page numbers and allows to customize them in several ways.
*/
export class NgbPagination {
constructor(config) {
this.pageCount = 0;
this.pages = [];
/**
* The current page.
*
* Page numbers start with `1`.
*/
this.page = 1;
/**
* An event fired when the page is changed. Will fire only if collection size is set and all values are valid.
*
* Event payload is the number of the newly selected page.
*
* Page numbers start with `1`.
*/
this.pageChange = new EventEmitter(true);
this.disabled = config.disabled;
this.boundaryLinks = config.boundaryLinks;
this.directionLinks = config.directionLinks;
this.ellipses = config.ellipses;
this.maxSize = config.maxSize;
this.pageSize = config.pageSize;
this.rotate = config.rotate;
this.size = config.size;
}
hasPrevious() {
return this.page > 1;
}
hasNext() {
return this.page < this.pageCount;
}
nextDisabled() {
return !this.hasNext() || this.disabled;
}
previousDisabled() {
return !this.hasPrevious() || this.disabled;
}
selectPage(pageNumber) {
this._updatePages(pageNumber);
}
ngOnChanges(changes) {
this._updatePages(this.page);
}
isEllipsis(pageNumber) {
return pageNumber === -1;
}
/**
* Appends ellipses and first/last page number to the displayed pages
*/
_applyEllipses(start, end) {
if (this.ellipses) {
if (start > 0) {
// The first page will always be included. If the displayed range
// starts after the third page, then add ellipsis. But if the range
// starts on the third page, then add the second page instead of
// an ellipsis, because the ellipsis would only hide a single page.
if (start > 2) {
this.pages.unshift(-1);
}
else if (start === 2) {
this.pages.unshift(2);
}
this.pages.unshift(1);
}
if (end < this.pageCount) {
// The last page will always be included. If the displayed range
// ends before the third-last page, then add ellipsis. But if the range
// ends on third-last page, then add the second-last page instead of
// an ellipsis, because the ellipsis would only hide a single page.
if (end < this.pageCount - 2) {
this.pages.push(-1);
}
else if (end === this.pageCount - 2) {
this.pages.push(this.pageCount - 1);
}
this.pages.push(this.pageCount);
}
}
}
/**
* Rotates page numbers based on maxSize items visible.
* Currently selected page stays in the middle:
*
* Ex. for selected page = 6:
* [5,*6*,7] for maxSize = 3
* [4,5,*6*,7] for maxSize = 4
*/
_applyRotation() {
let start = 0;
let end = this.pageCount;
let leftOffset = Math.floor(this.maxSize / 2);
let rightOffset = this.maxSize % 2 === 0 ? leftOffset - 1 : leftOffset;
if (this.page <= leftOffset) {
// very beginning, no rotation -> [0..maxSize]
end = this.maxSize;
}
else if (this.pageCount - this.page < leftOffset) {
// very end, no rotation -> [len-maxSize..len]
start = this.pageCount - this.maxSize;
}
else {
// rotate
start = this.page - leftOffset - 1;
end = this.page + rightOffset;
}
return [start, end];
}
/**
* Paginates page numbers based on maxSize items per page.
*/
_applyPagination() {
let page = Math.ceil(this.page / this.maxSize) - 1;
let start = page * this.maxSize;
let end = start + this.maxSize;
return [start, end];
}
_setPageInRange(newPageNo) {
const prevPageNo = this.page;
this.page = getValueInRange(newPageNo, this.pageCount, 1);
if (this.page !== prevPageNo && isNumber(this.collectionSize)) {
this.pageChange.emit(this.page);
}
}
_updatePages(newPage) {
this.pageCount = Math.ceil(this.collectionSize / this.pageSize);
if (!isNumber(this.pageCount)) {
this.pageCount = 0;
}
// fill-in model needed to render pages
this.pages.length = 0;
for (let i = 1; i <= this.pageCount; i++) {
this.pages.push(i);
}
// set page within 1..max range
this._setPageInRange(newPage);
// apply maxSize if necessary
if (this.maxSize > 0 && this.pageCount > this.maxSize) {
let start = 0;
let end = this.pageCount;
// either paginating or rotating page numbers
if (this.rotate) {
[start, end] = this._applyRotation();
}
else {
[start, end] = this._applyPagination();
}
this.pages = this.pages.slice(start, end);
// adding ellipses
this._applyEllipses(start, end);
}
}
}
NgbPagination.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.6", ngImport: i0, type: NgbPagination, deps: [{ token: i1.NgbPaginationConfig }], target: i0.ɵɵFactoryTarget.Component });
NgbPagination.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.6", type: NgbPagination, selector: "ngb-pagination", inputs: { disabled: "disabled", boundaryLinks: "boundaryLinks", directionLinks: "directionLinks", ellipses: "ellipses", rotate: "rotate", collectionSize: "collectionSize", maxSize: "maxSize", page: "page", pageSize: "pageSize", size: "size" }, outputs: { pageChange: "pageChange" }, host: { attributes: { "role": "navigation" } }, queries: [{ propertyName: "tplEllipsis", first: true, predicate: NgbPaginationEllipsis, descendants: true }, { propertyName: "tplFirst", first: true, predicate: NgbPaginationFirst, descendants: true }, { propertyName: "tplLast", first: true, predicate: NgbPaginationLast, descendants: true }, { propertyName: "tplNext", first: true, predicate: NgbPaginationNext, descendants: true }, { propertyName: "tplNumber", first: true, predicate: NgbPaginationNumber, descendants: true }, { propertyName: "tplPrevious", first: true, predicate: NgbPaginationPrevious, descendants: true }, { propertyName: "tplPages", first: true, predicate: NgbPaginationPages, descendants: true }], usesOnChanges: true, ngImport: i0, template: `
««
«
»
»»
...
{{ page }}
(current)
`, isInline: true, dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.6", ngImport: i0, type: NgbPagination, decorators: [{
type: Component,
args: [{
selector: 'ngb-pagination',
changeDetection: ChangeDetectionStrategy.OnPush,
host: { role: 'navigation' },
template: `
««
«
»
»»
...
{{ page }}
(current)
`,
}]
}], ctorParameters: function () { return [{ type: i1.NgbPaginationConfig }]; }, propDecorators: { tplEllipsis: [{
type: ContentChild,
args: [NgbPaginationEllipsis, { static: false }]
}], tplFirst: [{
type: ContentChild,
args: [NgbPaginationFirst, { static: false }]
}], tplLast: [{
type: ContentChild,
args: [NgbPaginationLast, { static: false }]
}], tplNext: [{
type: ContentChild,
args: [NgbPaginationNext, { static: false }]
}], tplNumber: [{
type: ContentChild,
args: [NgbPaginationNumber, { static: false }]
}], tplPrevious: [{
type: ContentChild,
args: [NgbPaginationPrevious, { static: false }]
}], tplPages: [{
type: ContentChild,
args: [NgbPaginationPages, { static: false }]
}], disabled: [{
type: Input
}], boundaryLinks: [{
type: Input
}], directionLinks: [{
type: Input
}], ellipses: [{
type: Input
}], rotate: [{
type: Input
}], collectionSize: [{
type: Input
}], maxSize: [{
type: Input
}], page: [{
type: Input
}], pageSize: [{
type: Input
}], pageChange: [{
type: Output
}], size: [{
type: Input
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pagination.js","sourceRoot":"","sources":["../../../../src/pagination/pagination.ts"],"names":[],"mappings":"AAAA,OAAO,EACN,SAAS,EACT,YAAY,EACZ,SAAS,EACT,YAAY,EACZ,KAAK,EACL,MAAM,EAEN,uBAAuB,GAGvB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,eAAe,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;;;;AAiEzD;;;;GAIG;AAEH,MAAM,OAAO,qBAAqB;IACjC,YAAmB,WAAkD;QAAlD,gBAAW,GAAX,WAAW,CAAuC;IAAG,CAAC;;kHAD7D,qBAAqB;sGAArB,qBAAqB;2FAArB,qBAAqB;kBADjC,SAAS;mBAAC,EAAE,QAAQ,EAAE,oCAAoC,EAAE;;AAK7D;;;;GAIG;AAEH,MAAM,OAAO,kBAAkB;IAC9B,YAAmB,WAAkD;QAAlD,gBAAW,GAAX,WAAW,CAAuC;IAAG,CAAC;;+GAD7D,kBAAkB;mGAAlB,kBAAkB;2FAAlB,kBAAkB;kBAD9B,SAAS;mBAAC,EAAE,QAAQ,EAAE,iCAAiC,EAAE;;AAK1D;;;;GAIG;AAEH,MAAM,OAAO,iBAAiB;IAC7B,YAAmB,WAAkD;QAAlD,gBAAW,GAAX,WAAW,CAAuC;IAAG,CAAC;;8GAD7D,iBAAiB;kGAAjB,iBAAiB;2FAAjB,iBAAiB;kBAD7B,SAAS;mBAAC,EAAE,QAAQ,EAAE,gCAAgC,EAAE;;AAKzD;;;;GAIG;AAEH,MAAM,OAAO,iBAAiB;IAC7B,YAAmB,WAAkD;QAAlD,gBAAW,GAAX,WAAW,CAAuC;IAAG,CAAC;;8GAD7D,iBAAiB;kGAAjB,iBAAiB;2FAAjB,iBAAiB;kBAD7B,SAAS;mBAAC,EAAE,QAAQ,EAAE,gCAAgC,EAAE;;AAKzD;;;;GAIG;AAEH,MAAM,OAAO,mBAAmB;IAC/B,YAAmB,WAAoD;QAApD,gBAAW,GAAX,WAAW,CAAyC;IAAG,CAAC;;gHAD/D,mBAAmB;oGAAnB,mBAAmB;2FAAnB,mBAAmB;kBAD/B,SAAS;mBAAC,EAAE,QAAQ,EAAE,kCAAkC,EAAE;;AAK3D;;;;GAIG;AAEH,MAAM,OAAO,qBAAqB;IACjC,YAAmB,WAAkD;QAAlD,gBAAW,GAAX,WAAW,CAAuC;IAAG,CAAC;;kHAD7D,qBAAqB;sGAArB,qBAAqB;2FAArB,qBAAqB;kBADjC,SAAS;mBAAC,EAAE,QAAQ,EAAE,oCAAoC,EAAE;;AAK7D;;;;GAIG;AAEH,MAAM,OAAO,kBAAkB;IAC9B,YAAmB,WAAmD;QAAnD,gBAAW,GAAX,WAAW,CAAwC;IAAG,CAAC;;+GAD9D,kBAAkB;mGAAlB,kBAAkB;2FAAlB,kBAAkB;kBAD9B,SAAS;mBAAC,EAAE,QAAQ,EAAE,iCAAiC,EAAE;;AAK1D;;GAEG;AAuHH,MAAM,OAAO,aAAa;IAmFzB,YAAY,MAA2B;QAlFvC,cAAS,GAAG,CAAC,CAAC;QACd,UAAK,GAAa,EAAE,CAAC;QAmDrB;;;;WAIG;QACM,SAAI,GAAG,CAAC,CAAC;QAOlB;;;;;;WAMG;QACO,eAAU,GAAG,IAAI,YAAY,CAAS,IAAI,CAAC,CAAC;QAYrD,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC;QAChC,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,aAAa,CAAC;QAC1C,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC,cAAc,CAAC;QAC5C,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC;QAChC,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC;QAC9B,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC;QAChC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC;QAC5B,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC;IACzB,CAAC;IAED,WAAW;QACV,OAAO,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;IACtB,CAAC;IAED,OAAO;QACN,OAAO,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC;IACnC,CAAC;IAED,YAAY;QACX,OAAO,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,IAAI,CAAC,QAAQ,CAAC;IACzC,CAAC;IAED,gBAAgB;QACf,OAAO,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,IAAI,CAAC,QAAQ,CAAC;IAC7C,CAAC;IAED,UAAU,CAAC,UAAkB;QAC5B,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC;IAC/B,CAAC;IAED,WAAW,CAAC,OAAsB;QACjC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC9B,CAAC;IAED,UAAU,CAAC,UAAU;QACpB,OAAO,UAAU,KAAK,CAAC,CAAC,CAAC;IAC1B,CAAC;IAED;;OAEG;IACK,cAAc,CAAC,KAAa,EAAE,GAAW;QAChD,IAAI,IAAI,CAAC,QAAQ,EAAE;YAClB,IAAI,KAAK,GAAG,CAAC,EAAE;gBACd,iEAAiE;gBACjE,mEAAmE;gBACnE,gEAAgE;gBAChE,mEAAmE;gBACnE,IAAI,KAAK,GAAG,CAAC,EAAE;oBACd,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;iBACvB;qBAAM,IAAI,KAAK,KAAK,CAAC,EAAE;oBACvB,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;iBACtB;gBACD,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;aACtB;YACD,IAAI,GAAG,GAAG,IAAI,CAAC,SAAS,EAAE;gBACzB,gEAAgE;gBAChE,uEAAuE;gBACvE,oEAAoE;gBACpE,mEAAmE;gBACnE,IAAI,GAAG,GAAG,IAAI,CAAC,SAAS,GAAG,CAAC,EAAE;oBAC7B,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;iBACpB;qBAAM,IAAI,GAAG,KAAK,IAAI,CAAC,SAAS,GAAG,CAAC,EAAE;oBACtC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC,CAAC;iBACpC;gBACD,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;aAChC;SACD;IACF,CAAC;IAED;;;;;;;OAOG;IACK,cAAc;QACrB,IAAI,KAAK,GAAG,CAAC,CAAC;QACd,IAAI,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC;QACzB,IAAI,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC,CAAC;QAC9C,IAAI,WAAW,GAAG,IAAI,CAAC,OAAO,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,UAAU,GAAG,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC;QAEvE,IAAI,IAAI,CAAC,IAAI,IAAI,UAAU,EAAE;YAC5B,8CAA8C;YAC9C,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC;SACnB;aAAM,IAAI,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,IAAI,GAAG,UAAU,EAAE;YACnD,8CAA8C;YAC9C,KAAK,GAAG,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC;SACtC;aAAM;YACN,SAAS;YACT,KAAK,GAAG,IAAI,CAAC,IAAI,GAAG,UAAU,GAAG,CAAC,CAAC;YACnC,GAAG,GAAG,IAAI,CAAC,IAAI,GAAG,WAAW,CAAC;SAC9B;QAED,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;IACrB,CAAC;IAED;;OAEG;IACK,gBAAgB;QACvB,IAAI,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;QACnD,IAAI,KAAK,GAAG,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC;QAChC,IAAI,GAAG,GAAG,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC;QAE/B,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;IACrB,CAAC;IAEO,eAAe,CAAC,SAAS;QAChC,MAAM,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC;QAC7B,IAAI,CAAC,IAAI,GAAG,eAAe,CAAC,SAAS,EAAE,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC;QAE1D,IAAI,IAAI,CAAC,IAAI,KAAK,UAAU,IAAI,QAAQ,CAAC,IAAI,CAAC,cAAc,CAAC,EAAE;YAC9D,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SAChC;IACF,CAAC;IAEO,YAAY,CAAC,OAAe;QACnC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC;QAEhE,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE;YAC9B,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC;SACnB;QAED,uCAAuC;QACvC,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;QACtB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC,EAAE,EAAE;YACzC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;SACnB;QAED,+BAA+B;QAC/B,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;QAE9B,6BAA6B;QAC7B,IAAI,IAAI,CAAC,OAAO,GAAG,CAAC,IAAI,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,OAAO,EAAE;YACtD,IAAI,KAAK,GAAG,CAAC,CAAC;YACd,IAAI,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC;YAEzB,6CAA6C;YAC7C,IAAI,IAAI,CAAC,MAAM,EAAE;gBAChB,CAAC,KAAK,EAAE,GAAG,CAAC,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;aACrC;iBAAM;gBACN,CAAC,KAAK,EAAE,GAAG,CAAC,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;aACvC;YAED,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;YAE1C,kBAAkB;YAClB,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;SAChC;IACF,CAAC;;0GA5OW,aAAa;8FAAb,aAAa,0aAIX,qBAAqB,2EACrB,kBAAkB,0EAClB,iBAAiB,0EACjB,iBAAiB,4EACjB,mBAAmB,8EACnB,qBAAqB,2EACrB,kBAAkB,qEA5HtB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAgHT;2FAEW,aAAa;kBAtHzB,SAAS;mBAAC;oBACV,QAAQ,EAAE,gBAAgB;oBAC1B,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,IAAI,EAAE,EAAE,IAAI,EAAE,YAAY,EAAE;oBAC5B,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAgHT;iBACD;0GAKwD,WAAW;sBAAlE,YAAY;uBAAC,qBAAqB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;gBACD,QAAQ;sBAA5D,YAAY;uBAAC,kBAAkB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;gBACC,OAAO;sBAA1D,YAAY;uBAAC,iBAAiB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;gBACE,OAAO;sBAA1D,YAAY;uBAAC,iBAAiB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;gBACI,SAAS;sBAA9D,YAAY;uBAAC,mBAAmB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;gBACI,WAAW;sBAAlE,YAAY;uBAAC,qBAAqB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;gBACD,QAAQ;sBAA5D,YAAY;uBAAC,kBAAkB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;gBAK1C,QAAQ;sBAAhB,KAAK;gBAKG,aAAa;sBAArB,KAAK;gBAKG,cAAc;sBAAtB,KAAK;gBAKG,QAAQ;sBAAhB,KAAK;gBAOG,MAAM;sBAAd,KAAK;gBASG,cAAc;sBAAtB,KAAK;gBAKG,OAAO;sBAAf,KAAK;gBAOG,IAAI;sBAAZ,KAAK;gBAKG,QAAQ;sBAAhB,KAAK;gBASI,UAAU;sBAAnB,MAAM;gBASE,IAAI;sBAAZ,KAAK","sourcesContent":["import {\n\tComponent,\n\tContentChild,\n\tDirective,\n\tEventEmitter,\n\tInput,\n\tOutput,\n\tOnChanges,\n\tChangeDetectionStrategy,\n\tSimpleChanges,\n\tTemplateRef,\n} from '@angular/core';\nimport { getValueInRange, isNumber } from '../util/util';\nimport { NgbPaginationConfig } from './pagination-config';\n\n/**\n * A context for the\n * * `NgbPaginationFirst`\n * * `NgbPaginationPrevious`\n * * `NgbPaginationNext`\n * * `NgbPaginationLast`\n * * `NgbPaginationEllipsis`\n * * `NgbPaginationPages`\n *\n * link templates in case you want to override one.\n *\n * @since 4.1.0\n */\nexport interface NgbPaginationLinkContext {\n\t/**\n\t * Page number displayed by the current link.\n\t */\n\tcurrentPage: number;\n\n\t/**\n\t * If `true`, the current link is disabled.\n\t */\n\tdisabled: boolean;\n}\n\n/**\n * A context for the `NgbPaginationNumber` link template in case you want to override one.\n *\n * Extends `NgbPaginationLinkContext`.\n *\n * @since 4.1.0\n */\nexport interface NgbPaginationNumberContext extends NgbPaginationLinkContext {\n\t/**\n\t * The page number, displayed by the current page link.\n\t */\n\t$implicit: number;\n}\n\n/**\n * A context for the `NgbPaginationPages` pages template in case you want to override\n * the way all pages are displayed.\n *\n * @since 9.1.0\n */\nexport interface NgbPaginationPagesContext {\n\t/**\n\t * The currently selected page number.\n\t */\n\t$implicit: number;\n\n\t/**\n\t * If `true`, pagination is disabled.\n\t */\n\tdisabled: boolean;\n\n\t/**\n\t * Pages numbers that should be rendered starting with 1.\n\t */\n\tpages: number[];\n}\n\n/**\n * A directive to match the 'ellipsis' link template\n *\n * @since 4.1.0\n */\n@Directive({ selector: 'ng-template[ngbPaginationEllipsis]' })\nexport class NgbPaginationEllipsis {\n\tconstructor(public templateRef: TemplateRef<NgbPaginationLinkContext>) {}\n}\n\n/**\n * A directive to match the 'first' link template\n *\n * @since 4.1.0\n */\n@Directive({ selector: 'ng-template[ngbPaginationFirst]' })\nexport class NgbPaginationFirst {\n\tconstructor(public templateRef: TemplateRef<NgbPaginationLinkContext>) {}\n}\n\n/**\n * A directive to match the 'last' link template\n *\n * @since 4.1.0\n */\n@Directive({ selector: 'ng-template[ngbPaginationLast]' })\nexport class NgbPaginationLast {\n\tconstructor(public templateRef: TemplateRef<NgbPaginationLinkContext>) {}\n}\n\n/**\n * A directive to match the 'next' link template\n *\n * @since 4.1.0\n */\n@Directive({ selector: 'ng-template[ngbPaginationNext]' })\nexport class NgbPaginationNext {\n\tconstructor(public templateRef: TemplateRef<NgbPaginationLinkContext>) {}\n}\n\n/**\n * A directive to match the page 'number' link template\n *\n * @since 4.1.0\n */\n@Directive({ selector: 'ng-template[ngbPaginationNumber]' })\nexport class NgbPaginationNumber {\n\tconstructor(public templateRef: TemplateRef<NgbPaginationNumberContext>) {}\n}\n\n/**\n * A directive to match the 'previous' link template\n *\n * @since 4.1.0\n */\n@Directive({ selector: 'ng-template[ngbPaginationPrevious]' })\nexport class NgbPaginationPrevious {\n\tconstructor(public templateRef: TemplateRef<NgbPaginationLinkContext>) {}\n}\n\n/**\n * A directive to match the 'pages' whole content\n *\n * @since 9.1.0\n */\n@Directive({ selector: 'ng-template[ngbPaginationPages]' })\nexport class NgbPaginationPages {\n\tconstructor(public templateRef: TemplateRef<NgbPaginationPagesContext>) {}\n}\n\n/**\n * A component that displays page numbers and allows to customize them in several ways.\n */\n@Component({\n\tselector: 'ngb-pagination',\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\thost: { role: 'navigation' },\n\ttemplate: `\n\t\t<ng-template #first><span aria-hidden=\"true\" i18n=\"@@ngb.pagination.first\">&laquo;&laquo;</span></ng-template>\n\t\t<ng-template #previous><span aria-hidden=\"true\" i18n=\"@@ngb.pagination.previous\">&laquo;</span></ng-template>\n\t\t<ng-template #next><span aria-hidden=\"true\" i18n=\"@@ngb.pagination.next\">&raquo;</span></ng-template>\n\t\t<ng-template #last><span aria-hidden=\"true\" i18n=\"@@ngb.pagination.last\">&raquo;&raquo;</span></ng-template>\n\t\t<ng-template #ellipsis>...</ng-template>\n\t\t<ng-template #defaultNumber let-page let-currentPage=\"currentPage\">\n\t\t\t{{ page }}\n\t\t\t<span *ngIf=\"page === currentPage\" class=\"visually-hidden\">(current)</span>\n\t\t</ng-template>\n\t\t<ng-template #defaultPages let-page let-pages=\"pages\" let-disabled=\"disabled\">\n\t\t\t<li\n\t\t\t\t*ngFor=\"let pageNumber of pages\"\n\t\t\t\tclass=\"page-item\"\n\t\t\t\t[class.active]=\"pageNumber === page\"\n\t\t\t\t[class.disabled]=\"isEllipsis(pageNumber) || disabled\"\n\t\t\t\t[attr.aria-current]=\"pageNumber === page ? 'page' : null\"\n\t\t\t>\n\t\t\t\t<a *ngIf=\"isEllipsis(pageNumber)\" class=\"page-link\" tabindex=\"-1\" aria-disabled=\"true\">\n\t\t\t\t\t<ng-template\n\t\t\t\t\t\t[ngTemplateOutlet]=\"tplEllipsis?.templateRef || ellipsis\"\n\t\t\t\t\t\t[ngTemplateOutletContext]=\"{ disabled: true, currentPage: page }\"\n\t\t\t\t\t></ng-template>\n\t\t\t\t</a>\n\t\t\t\t<a\n\t\t\t\t\t*ngIf=\"!isEllipsis(pageNumber)\"\n\t\t\t\t\tclass=\"page-link\"\n\t\t\t\t\thref\n\t\t\t\t\t(click)=\"selectPage(pageNumber); $event.preventDefault()\"\n\t\t\t\t\t[attr.tabindex]=\"disabled ? '-1' : null\"\n\t\t\t\t\t[attr.aria-disabled]=\"disabled ? 'true' : null\"\n\t\t\t\t>\n\t\t\t\t\t<ng-template\n\t\t\t\t\t\t[ngTemplateOutlet]=\"tplNumber?.templateRef || defaultNumber\"\n\t\t\t\t\t\t[ngTemplateOutletContext]=\"{ disabled: disabled, $implicit: pageNumber, currentPage: page }\"\n\t\t\t\t\t></ng-template>\n\t\t\t\t</a>\n\t\t\t</li>\n\t\t</ng-template>\n\t\t<ul [class]=\"'pagination' + (size ? ' pagination-' + size : '')\">\n\t\t\t<li *ngIf=\"boundaryLinks\" class=\"page-item\" [class.disabled]=\"previousDisabled()\">\n\t\t\t\t<a\n\t\t\t\t\taria-label=\"First\"\n\t\t\t\t\ti18n-aria-label=\"@@ngb.pagination.first-aria\"\n\t\t\t\t\tclass=\"page-link\"\n\t\t\t\t\thref\n\t\t\t\t\t(click)=\"selectPage(1); $event.preventDefault()\"\n\t\t\t\t\t[attr.tabindex]=\"previousDisabled() ? '-1' : null\"\n\t\t\t\t\t[attr.aria-disabled]=\"previousDisabled() ? 'true' : null\"\n\t\t\t\t>\n\t\t\t\t\t<ng-template\n\t\t\t\t\t\t[ngTemplateOutlet]=\"tplFirst?.templateRef || first\"\n\t\t\t\t\t\t[ngTemplateOutletContext]=\"{ disabled: previousDisabled(), currentPage: page }\"\n\t\t\t\t\t></ng-template>\n\t\t\t\t</a>\n\t\t\t</li>\n\n\t\t\t<li *ngIf=\"directionLinks\" class=\"page-item\" [class.disabled]=\"previousDisabled()\">\n\t\t\t\t<a\n\t\t\t\t\taria-label=\"Previous\"\n\t\t\t\t\ti18n-aria-label=\"@@ngb.pagination.previous-aria\"\n\t\t\t\t\tclass=\"page-link\"\n\t\t\t\t\thref\n\t\t\t\t\t(click)=\"selectPage(page - 1); $event.preventDefault()\"\n\t\t\t\t\t[attr.tabindex]=\"previousDisabled() ? '-1' : null\"\n\t\t\t\t\t[attr.aria-disabled]=\"previousDisabled() ? 'true' : null\"\n\t\t\t\t>\n\t\t\t\t\t<ng-template\n\t\t\t\t\t\t[ngTemplateOutlet]=\"tplPrevious?.templateRef || previous\"\n\t\t\t\t\t\t[ngTemplateOutletContext]=\"{ disabled: previousDisabled() }\"\n\t\t\t\t\t></ng-template>\n\t\t\t\t</a>\n\t\t\t</li>\n\t\t\t<ng-template\n\t\t\t\t[ngTemplateOutlet]=\"tplPages?.templateRef || defaultPages\"\n\t\t\t\t[ngTemplateOutletContext]=\"{ $implicit: page, pages: pages, disabled: disabled }\"\n\t\t\t>\n\t\t\t</ng-template>\n\t\t\t<li *ngIf=\"directionLinks\" class=\"page-item\" [class.disabled]=\"nextDisabled()\">\n\t\t\t\t<a\n\t\t\t\t\taria-label=\"Next\"\n\t\t\t\t\ti18n-aria-label=\"@@ngb.pagination.next-aria\"\n\t\t\t\t\tclass=\"page-link\"\n\t\t\t\t\thref\n\t\t\t\t\t(click)=\"selectPage(page + 1); $event.preventDefault()\"\n\t\t\t\t\t[attr.tabindex]=\"nextDisabled() ? '-1' : null\"\n\t\t\t\t\t[attr.aria-disabled]=\"nextDisabled() ? 'true' : null\"\n\t\t\t\t>\n\t\t\t\t\t<ng-template\n\t\t\t\t\t\t[ngTemplateOutlet]=\"tplNext?.templateRef || next\"\n\t\t\t\t\t\t[ngTemplateOutletContext]=\"{ disabled: nextDisabled(), currentPage: page }\"\n\t\t\t\t\t></ng-template>\n\t\t\t\t</a>\n\t\t\t</li>\n\n\t\t\t<li *ngIf=\"boundaryLinks\" class=\"page-item\" [class.disabled]=\"nextDisabled()\">\n\t\t\t\t<a\n\t\t\t\t\taria-label=\"Last\"\n\t\t\t\t\ti18n-aria-label=\"@@ngb.pagination.last-aria\"\n\t\t\t\t\tclass=\"page-link\"\n\t\t\t\t\thref\n\t\t\t\t\t(click)=\"selectPage(pageCount); $event.preventDefault()\"\n\t\t\t\t\t[attr.tabindex]=\"nextDisabled() ? '-1' : null\"\n\t\t\t\t\t[attr.aria-disabled]=\"nextDisabled() ? 'true' : null\"\n\t\t\t\t>\n\t\t\t\t\t<ng-template\n\t\t\t\t\t\t[ngTemplateOutlet]=\"tplLast?.templateRef || last\"\n\t\t\t\t\t\t[ngTemplateOutletContext]=\"{ disabled: nextDisabled(), currentPage: page }\"\n\t\t\t\t\t></ng-template>\n\t\t\t\t</a>\n\t\t\t</li>\n\t\t</ul>\n\t`,\n})\nexport class NgbPagination implements OnChanges {\n\tpageCount = 0;\n\tpages: number[] = [];\n\n\t@ContentChild(NgbPaginationEllipsis, { static: false }) tplEllipsis?: NgbPaginationEllipsis;\n\t@ContentChild(NgbPaginationFirst, { static: false }) tplFirst?: NgbPaginationFirst;\n\t@ContentChild(NgbPaginationLast, { static: false }) tplLast?: NgbPaginationLast;\n\t@ContentChild(NgbPaginationNext, { static: false }) tplNext?: NgbPaginationNext;\n\t@ContentChild(NgbPaginationNumber, { static: false }) tplNumber?: NgbPaginationNumber;\n\t@ContentChild(NgbPaginationPrevious, { static: false }) tplPrevious?: NgbPaginationPrevious;\n\t@ContentChild(NgbPaginationPages, { static: false }) tplPages?: NgbPaginationPages;\n\n\t/**\n\t * If `true`, pagination links will be disabled.\n\t */\n\t@Input() disabled: boolean;\n\n\t/**\n\t * If `true`, the \"First\" and \"Last\" page links are shown.\n\t */\n\t@Input() boundaryLinks: boolean;\n\n\t/**\n\t * If `true`, the \"Next\" and \"Previous\" page links are shown.\n\t */\n\t@Input() directionLinks: boolean;\n\n\t/**\n\t * If `true`, the ellipsis symbols and first/last page numbers will be shown when `maxSize` > number of pages.\n\t */\n\t@Input() ellipses: boolean;\n\n\t/**\n\t * Whether to rotate pages when `maxSize` > number of pages.\n\t *\n\t * The current page always stays in the middle if `true`.\n\t */\n\t@Input() rotate: boolean;\n\n\t/**\n\t *  The number of items in your paginated collection.\n\t *\n\t *  Note, that this is not the number of pages. Page numbers are calculated dynamically based on\n\t *  `collectionSize` and `pageSize`. Ex. if you have 100 items in your collection and displaying 20 items per page,\n\t *  you'll end up with 5 pages.\n\t */\n\t@Input() collectionSize: number;\n\n\t/**\n\t *  The maximum number of pages to display.\n\t */\n\t@Input() maxSize: number;\n\n\t/**\n\t *  The current page.\n\t *\n\t *  Page numbers start with `1`.\n\t */\n\t@Input() page = 1;\n\n\t/**\n\t *  The number of items per page.\n\t */\n\t@Input() pageSize: number;\n\n\t/**\n\t *  An event fired when the page is changed. Will fire only if collection size is set and all values are valid.\n\t *\n\t *  Event payload is the number of the newly selected page.\n\t *\n\t *  Page numbers start with `1`.\n\t */\n\t@Output() pageChange = new EventEmitter<number>(true);\n\n\t/**\n\t * The pagination display size.\n\t *\n\t * Bootstrap currently supports small and large sizes.\n\t *\n\t * If the passed value is a string (ex. 'custom'), it will just add the `pagination-custom` css class\n\t */\n\t@Input() size: 'sm' | 'lg' | string | null;\n\n\tconstructor(config: NgbPaginationConfig) {\n\t\tthis.disabled = config.disabled;\n\t\tthis.boundaryLinks = config.boundaryLinks;\n\t\tthis.directionLinks = config.directionLinks;\n\t\tthis.ellipses = config.ellipses;\n\t\tthis.maxSize = config.maxSize;\n\t\tthis.pageSize = config.pageSize;\n\t\tthis.rotate = config.rotate;\n\t\tthis.size = config.size;\n\t}\n\n\thasPrevious(): boolean {\n\t\treturn this.page > 1;\n\t}\n\n\thasNext(): boolean {\n\t\treturn this.page < this.pageCount;\n\t}\n\n\tnextDisabled(): boolean {\n\t\treturn !this.hasNext() || this.disabled;\n\t}\n\n\tpreviousDisabled(): boolean {\n\t\treturn !this.hasPrevious() || this.disabled;\n\t}\n\n\tselectPage(pageNumber: number): void {\n\t\tthis._updatePages(pageNumber);\n\t}\n\n\tngOnChanges(changes: SimpleChanges): void {\n\t\tthis._updatePages(this.page);\n\t}\n\n\tisEllipsis(pageNumber): boolean {\n\t\treturn pageNumber === -1;\n\t}\n\n\t/**\n\t * Appends ellipses and first/last page number to the displayed pages\n\t */\n\tprivate _applyEllipses(start: number, end: number) {\n\t\tif (this.ellipses) {\n\t\t\tif (start > 0) {\n\t\t\t\t// The first page will always be included. If the displayed range\n\t\t\t\t// starts after the third page, then add ellipsis. But if the range\n\t\t\t\t// starts on the third page, then add the second page instead of\n\t\t\t\t// an ellipsis, because the ellipsis would only hide a single page.\n\t\t\t\tif (start > 2) {\n\t\t\t\t\tthis.pages.unshift(-1);\n\t\t\t\t} else if (start === 2) {\n\t\t\t\t\tthis.pages.unshift(2);\n\t\t\t\t}\n\t\t\t\tthis.pages.unshift(1);\n\t\t\t}\n\t\t\tif (end < this.pageCount) {\n\t\t\t\t// The last page will always be included. If the displayed range\n\t\t\t\t// ends before the third-last page, then add ellipsis. But if the range\n\t\t\t\t// ends on third-last page, then add the second-last page instead of\n\t\t\t\t// an ellipsis, because the ellipsis would only hide a single page.\n\t\t\t\tif (end < this.pageCount - 2) {\n\t\t\t\t\tthis.pages.push(-1);\n\t\t\t\t} else if (end === this.pageCount - 2) {\n\t\t\t\t\tthis.pages.push(this.pageCount - 1);\n\t\t\t\t}\n\t\t\t\tthis.pages.push(this.pageCount);\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Rotates page numbers based on maxSize items visible.\n\t * Currently selected page stays in the middle:\n\t *\n\t * Ex. for selected page = 6:\n\t * [5,*6*,7] for maxSize = 3\n\t * [4,5,*6*,7] for maxSize = 4\n\t */\n\tprivate _applyRotation(): [number, number] {\n\t\tlet start = 0;\n\t\tlet end = this.pageCount;\n\t\tlet leftOffset = Math.floor(this.maxSize / 2);\n\t\tlet rightOffset = this.maxSize % 2 === 0 ? leftOffset - 1 : leftOffset;\n\n\t\tif (this.page <= leftOffset) {\n\t\t\t// very beginning, no rotation -> [0..maxSize]\n\t\t\tend = this.maxSize;\n\t\t} else if (this.pageCount - this.page < leftOffset) {\n\t\t\t// very end, no rotation -> [len-maxSize..len]\n\t\t\tstart = this.pageCount - this.maxSize;\n\t\t} else {\n\t\t\t// rotate\n\t\t\tstart = this.page - leftOffset - 1;\n\t\t\tend = this.page + rightOffset;\n\t\t}\n\n\t\treturn [start, end];\n\t}\n\n\t/**\n\t * Paginates page numbers based on maxSize items per page.\n\t */\n\tprivate _applyPagination(): [number, number] {\n\t\tlet page = Math.ceil(this.page / this.maxSize) - 1;\n\t\tlet start = page * this.maxSize;\n\t\tlet end = start + this.maxSize;\n\n\t\treturn [start, end];\n\t}\n\n\tprivate _setPageInRange(newPageNo) {\n\t\tconst prevPageNo = this.page;\n\t\tthis.page = getValueInRange(newPageNo, this.pageCount, 1);\n\n\t\tif (this.page !== prevPageNo && isNumber(this.collectionSize)) {\n\t\t\tthis.pageChange.emit(this.page);\n\t\t}\n\t}\n\n\tprivate _updatePages(newPage: number) {\n\t\tthis.pageCount = Math.ceil(this.collectionSize / this.pageSize);\n\n\t\tif (!isNumber(this.pageCount)) {\n\t\t\tthis.pageCount = 0;\n\t\t}\n\n\t\t// fill-in model needed to render pages\n\t\tthis.pages.length = 0;\n\t\tfor (let i = 1; i <= this.pageCount; i++) {\n\t\t\tthis.pages.push(i);\n\t\t}\n\n\t\t// set page within 1..max range\n\t\tthis._setPageInRange(newPage);\n\n\t\t// apply maxSize if necessary\n\t\tif (this.maxSize > 0 && this.pageCount > this.maxSize) {\n\t\t\tlet start = 0;\n\t\t\tlet end = this.pageCount;\n\n\t\t\t// either paginating or rotating page numbers\n\t\t\tif (this.rotate) {\n\t\t\t\t[start, end] = this._applyRotation();\n\t\t\t} else {\n\t\t\t\t[start, end] = this._applyPagination();\n\t\t\t}\n\n\t\t\tthis.pages = this.pages.slice(start, end);\n\n\t\t\t// adding ellipses\n\t\t\tthis._applyEllipses(start, end);\n\t\t}\n\t}\n}\n"]}