/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, Input, Output, EventEmitter, ChangeDetectionStrategy } from '@angular/core';
var DataTablePagerComponent = /** @class */ (function () {
function DataTablePagerComponent() {
this.change = new EventEmitter();
this._count = 0;
this._page = 1;
this._size = 0;
}
Object.defineProperty(DataTablePagerComponent.prototype, "size", {
get: /**
* @return {?}
*/
function () {
return this._size;
},
set: /**
* @param {?} val
* @return {?}
*/
function (val) {
this._size = val;
this.pages = this.calcPages();
},
enumerable: true,
configurable: true
});
Object.defineProperty(DataTablePagerComponent.prototype, "count", {
get: /**
* @return {?}
*/
function () {
return this._count;
},
set: /**
* @param {?} val
* @return {?}
*/
function (val) {
this._count = val;
this.pages = this.calcPages();
},
enumerable: true,
configurable: true
});
Object.defineProperty(DataTablePagerComponent.prototype, "page", {
get: /**
* @return {?}
*/
function () {
return this._page;
},
set: /**
* @param {?} val
* @return {?}
*/
function (val) {
this._page = val;
this.pages = this.calcPages();
},
enumerable: true,
configurable: true
});
Object.defineProperty(DataTablePagerComponent.prototype, "totalPages", {
get: /**
* @return {?}
*/
function () {
/** @type {?} */
var count = this.size < 1 ? 1 : Math.ceil(this.count / this.size);
return Math.max(count || 0, 1);
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
DataTablePagerComponent.prototype.canPrevious = /**
* @return {?}
*/
function () {
return this.page > 1;
};
/**
* @return {?}
*/
DataTablePagerComponent.prototype.canNext = /**
* @return {?}
*/
function () {
return this.page < this.totalPages;
};
/**
* @return {?}
*/
DataTablePagerComponent.prototype.prevPage = /**
* @return {?}
*/
function () {
this.selectPage(this.page - 1);
};
/**
* @return {?}
*/
DataTablePagerComponent.prototype.nextPage = /**
* @return {?}
*/
function () {
this.selectPage(this.page + 1);
};
/**
* @param {?} page
* @return {?}
*/
DataTablePagerComponent.prototype.selectPage = /**
* @param {?} page
* @return {?}
*/
function (page) {
if (page > 0 && page <= this.totalPages && page !== this.page) {
this.page = page;
this.change.emit({
page: page
});
}
};
/**
* @param {?=} page
* @return {?}
*/
DataTablePagerComponent.prototype.calcPages = /**
* @param {?=} page
* @return {?}
*/
function (page) {
/** @type {?} */
var pages = [];
/** @type {?} */
var startPage = 1;
/** @type {?} */
var endPage = this.totalPages;
/** @type {?} */
var maxSize = 5;
/** @type {?} */
var isMaxSized = maxSize < this.totalPages;
page = page || this.page;
if (isMaxSized) {
startPage = page - Math.floor(maxSize / 2);
endPage = page + Math.floor(maxSize / 2);
if (startPage < 1) {
startPage = 1;
endPage = Math.min(startPage + maxSize - 1, this.totalPages);
}
else if (endPage > this.totalPages) {
startPage = Math.max(this.totalPages - maxSize + 1, 1);
endPage = this.totalPages;
}
}
for (var num = startPage; num <= endPage; num++) {
pages.push({
number: num,
text: (/** @type {?} */ (((/** @type {?} */ (num)))))
});
}
return pages;
};
DataTablePagerComponent.decorators = [
{ type: Component, args: [{
selector: 'datatable-pager',
template: "\n
\n ",
host: {
class: 'datatable-pager'
},
changeDetection: ChangeDetectionStrategy.OnPush
}] }
];
DataTablePagerComponent.propDecorators = {
pagerLeftArrowIcon: [{ type: Input }],
pagerRightArrowIcon: [{ type: Input }],
pagerPreviousIcon: [{ type: Input }],
pagerNextIcon: [{ type: Input }],
size: [{ type: Input }],
count: [{ type: Input }],
page: [{ type: Input }],
change: [{ type: Output }]
};
return DataTablePagerComponent;
}());
export { DataTablePagerComponent };
if (false) {
/** @type {?} */
DataTablePagerComponent.prototype.pagerLeftArrowIcon;
/** @type {?} */
DataTablePagerComponent.prototype.pagerRightArrowIcon;
/** @type {?} */
DataTablePagerComponent.prototype.pagerPreviousIcon;
/** @type {?} */
DataTablePagerComponent.prototype.pagerNextIcon;
/** @type {?} */
DataTablePagerComponent.prototype.change;
/** @type {?} */
DataTablePagerComponent.prototype._count;
/** @type {?} */
DataTablePagerComponent.prototype._page;
/** @type {?} */
DataTablePagerComponent.prototype._size;
/** @type {?} */
DataTablePagerComponent.prototype.pages;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pager.component.js","sourceRoot":"ng://@swimlane/ngx-datatable/","sources":["lib/components/footer/pager.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, ChangeDetectionStrategy } from '@angular/core';\n\n@Component({\n  selector: 'datatable-pager',\n  template: `\n    <ul class=\"pager\">\n      <li [class.disabled]=\"!canPrevious()\">\n        <a role=\"button\" aria-label=\"go to first page\" href=\"javascript:void(0)\" (click)=\"selectPage(1)\">\n          <i class=\"{{ pagerPreviousIcon }}\"></i>\n        </a>\n      </li>\n      <li [class.disabled]=\"!canPrevious()\">\n        <a role=\"button\" aria-label=\"go to previous page\" href=\"javascript:void(0)\" (click)=\"prevPage()\">\n          <i class=\"{{ pagerLeftArrowIcon }}\"></i>\n        </a>\n      </li>\n      <li\n        role=\"button\"\n        [attr.aria-label]=\"'page ' + pg.number\"\n        class=\"pages\"\n        *ngFor=\"let pg of pages\"\n        [class.active]=\"pg.number === page\"\n      >\n        <a href=\"javascript:void(0)\" (click)=\"selectPage(pg.number)\">\n          {{ pg.text }}\n        </a>\n      </li>\n      <li [class.disabled]=\"!canNext()\">\n        <a role=\"button\" aria-label=\"go to next page\" href=\"javascript:void(0)\" (click)=\"nextPage()\">\n          <i class=\"{{ pagerRightArrowIcon }}\"></i>\n        </a>\n      </li>\n      <li [class.disabled]=\"!canNext()\">\n        <a role=\"button\" aria-label=\"go to last page\" href=\"javascript:void(0)\" (click)=\"selectPage(totalPages)\">\n          <i class=\"{{ pagerNextIcon }}\"></i>\n        </a>\n      </li>\n    </ul>\n  `,\n  host: {\n    class: 'datatable-pager'\n  },\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DataTablePagerComponent {\n  @Input() pagerLeftArrowIcon: string;\n  @Input() pagerRightArrowIcon: string;\n  @Input() pagerPreviousIcon: string;\n  @Input() pagerNextIcon: string;\n\n  @Input()\n  set size(val: number) {\n    this._size = val;\n    this.pages = this.calcPages();\n  }\n\n  get size(): number {\n    return this._size;\n  }\n\n  @Input()\n  set count(val: number) {\n    this._count = val;\n    this.pages = this.calcPages();\n  }\n\n  get count(): number {\n    return this._count;\n  }\n\n  @Input()\n  set page(val: number) {\n    this._page = val;\n    this.pages = this.calcPages();\n  }\n\n  get page(): number {\n    return this._page;\n  }\n\n  get totalPages(): number {\n    const count = this.size < 1 ? 1 : Math.ceil(this.count / this.size);\n    return Math.max(count || 0, 1);\n  }\n\n  @Output() change: EventEmitter<any> = new EventEmitter();\n\n  _count: number = 0;\n  _page: number = 1;\n  _size: number = 0;\n  pages: any;\n\n  canPrevious(): boolean {\n    return this.page > 1;\n  }\n\n  canNext(): boolean {\n    return this.page < this.totalPages;\n  }\n\n  prevPage(): void {\n    this.selectPage(this.page - 1);\n  }\n\n  nextPage(): void {\n    this.selectPage(this.page + 1);\n  }\n\n  selectPage(page: number): void {\n    if (page > 0 && page <= this.totalPages && page !== this.page) {\n      this.page = page;\n\n      this.change.emit({\n        page\n      });\n    }\n  }\n\n  calcPages(page?: number): any[] {\n    const pages = [];\n    let startPage = 1;\n    let endPage = this.totalPages;\n    const maxSize = 5;\n    const isMaxSized = maxSize < this.totalPages;\n\n    page = page || this.page;\n\n    if (isMaxSized) {\n      startPage = page - Math.floor(maxSize / 2);\n      endPage = page + Math.floor(maxSize / 2);\n\n      if (startPage < 1) {\n        startPage = 1;\n        endPage = Math.min(startPage + maxSize - 1, this.totalPages);\n      } else if (endPage > this.totalPages) {\n        startPage = Math.max(this.totalPages - maxSize + 1, 1);\n        endPage = this.totalPages;\n      }\n    }\n\n    for (let num = startPage; num <= endPage; num++) {\n      pages.push({\n        number: num,\n        text: <string>(<any>num)\n      });\n    }\n\n    return pages;\n  }\n}\n"]}