ngx-materialize
Version:
An Angular wrap around Materialize library
175 lines (174 loc) • 15.3 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Component, EventEmitter, Input, Output } from '@angular/core';
import { HandlePropChanges } from '../shared/index';
var MzPaginationComponent = /** @class */ (function (_super) {
tslib_1.__extends(MzPaginationComponent, _super);
function MzPaginationComponent() {
var _this = _super.call(this) || this;
_this.currentPage = 1;
_this.enableFirstAndLastPageButtons = false;
_this.maxPageButtons = 5;
_this.pageChange = new EventEmitter();
return _this;
}
Object.defineProperty(MzPaginationComponent.prototype, "totalPages", {
get: /**
* @return {?}
*/
function () {
return Math.ceil(this.totalItems / this.itemsPerPage);
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
MzPaginationComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
this.initHandlers();
this.renderButtons();
};
/**
* @param {?} pageNumber
* @return {?}
*/
MzPaginationComponent.prototype.changeCurrentPage = /**
* @param {?} pageNumber
* @return {?}
*/
function (pageNumber) {
this.currentPage = pageNumber;
this.pageChange.emit(pageNumber);
this.renderButtons();
};
/**
* @return {?}
*/
MzPaginationComponent.prototype.firstPage = /**
* @return {?}
*/
function () {
this.changeCurrentPage(1);
};
/**
* @return {?}
*/
MzPaginationComponent.prototype.initHandlers = /**
* @return {?}
*/
function () {
var _this = this;
this.handlers = {
currentPage: function () { return _this.renderButtons(); },
itemsPerPage: function () { return _this.renderButtons(); },
maxPageButtons: function () { return _this.renderButtons(); },
totalItems: function () { return _this.renderButtons(); },
};
};
/**
* @return {?}
*/
MzPaginationComponent.prototype.lastPage = /**
* @return {?}
*/
function () {
this.changeCurrentPage(this.totalPages);
};
/**
* @return {?}
*/
MzPaginationComponent.prototype.nextPage = /**
* @return {?}
*/
function () {
if (this.currentPage < this.totalPages) {
var /** @type {?} */ nextPage = this.currentPage + 1;
this.changeCurrentPage(nextPage);
}
};
/**
* @return {?}
*/
MzPaginationComponent.prototype.previousPage = /**
* @return {?}
*/
function () {
if (this.currentPage !== 1) {
var /** @type {?} */ previousPage = this.currentPage - 1;
this.changeCurrentPage(previousPage);
}
};
/**
* @return {?}
*/
MzPaginationComponent.prototype.renderButtons = /**
* @return {?}
*/
function () {
var /** @type {?} */ buttonsCount = Math.min(this.maxPageButtons, this.totalPages);
var /** @type {?} */ maxPosition = this.totalPages - buttonsCount;
var /** @type {?} */ halfButtons = Math.floor(buttonsCount / 2);
var /** @type {?} */ hiddenPagesBefore = (this.currentPage - halfButtons);
if (hiddenPagesBefore > maxPosition) {
hiddenPagesBefore = maxPosition + 1;
}
var /** @type {?} */ from = Math.max(hiddenPagesBefore, 1);
var /** @type {?} */ to = Math.min(this.totalPages, from + this.maxPageButtons - 1);
this.pages = Array(buttonsCount).fill(0).map(function (x, i) { return from + i; });
if (this.currentPage > this.totalPages) {
this.currentPage = this.pages[0];
}
};
MzPaginationComponent.decorators = [
{ type: Component, args: [{
selector: 'mz-pagination',
template: "\n <ul class=\"pagination\">\n <mz-pagination-page-button [disabled]=\"currentPage === 1\" *ngIf=\"enableFirstAndLastPageButtons\">\n <a (click)=\"firstPage()\"><i mz-icon [icon]=\"'first_page'\"></i></a>\n </mz-pagination-page-button>\n <mz-pagination-page-button [disabled]=\"currentPage === 1\">\n <a (click)=\"previousPage()\"><i mz-icon [icon]=\"'chevron_left'\"></i></a>\n </mz-pagination-page-button>\n <mz-pagination-page-button *ngFor=\"let page of pages\"\n [active]=\"page === currentPage\"\n >\n <a (click)=\"changeCurrentPage(page)\">{{ page }}</a>\n </mz-pagination-page-button>\n <mz-pagination-page-button [disabled]=\"currentPage === totalPages\">\n <a (click)=\"nextPage()\"><i mz-icon [icon]=\"'chevron_right'\"></i></a>\n </mz-pagination-page-button>\n <mz-pagination-page-button [disabled]=\"currentPage === totalPages\" *ngIf=\"enableFirstAndLastPageButtons\">\n <a (click)=\"lastPage()\"><i mz-icon [icon]=\"'last_page'\"></i></a>\n </mz-pagination-page-button>\n </ul>",
styles: [""],
},] },
];
/** @nocollapse */
MzPaginationComponent.ctorParameters = function () { return []; };
MzPaginationComponent.propDecorators = {
"currentPage": [{ type: Input },],
"enableFirstAndLastPageButtons": [{ type: Input },],
"itemsPerPage": [{ type: Input },],
"maxPageButtons": [{ type: Input },],
"totalItems": [{ type: Input },],
"pageChange": [{ type: Output },],
};
return MzPaginationComponent;
}(HandlePropChanges));
export { MzPaginationComponent };
function MzPaginationComponent_tsickle_Closure_declarations() {
/** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */
MzPaginationComponent.decorators;
/**
* @nocollapse
* @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>}
*/
MzPaginationComponent.ctorParameters;
/** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */
MzPaginationComponent.propDecorators;
/** @type {?} */
MzPaginationComponent.prototype.currentPage;
/** @type {?} */
MzPaginationComponent.prototype.enableFirstAndLastPageButtons;
/** @type {?} */
MzPaginationComponent.prototype.itemsPerPage;
/** @type {?} */
MzPaginationComponent.prototype.maxPageButtons;
/** @type {?} */
MzPaginationComponent.prototype.totalItems;
/** @type {?} */
MzPaginationComponent.prototype.pageChange;
/** @type {?} */
MzPaginationComponent.prototype.pages;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pagination.component.js","sourceRoot":"ng://ngx-materialize/","sources":["src/pagination/pagination.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\n\r\nimport { HandlePropChanges } from '../shared/index';\r\nimport { MzPaginationPageButtonComponent } from './pagination-page-button/index';\r\n\r\n@Component({\r\n  selector: 'mz-pagination',\r\n  template: `\r\n  <ul class=\"pagination\">\r\n    <mz-pagination-page-button [disabled]=\"currentPage === 1\" *ngIf=\"enableFirstAndLastPageButtons\">\r\n      <a (click)=\"firstPage()\"><i mz-icon [icon]=\"'first_page'\"></i></a>\r\n    </mz-pagination-page-button>\r\n    <mz-pagination-page-button [disabled]=\"currentPage === 1\">\r\n      <a (click)=\"previousPage()\"><i mz-icon [icon]=\"'chevron_left'\"></i></a>\r\n    </mz-pagination-page-button>\r\n    <mz-pagination-page-button *ngFor=\"let page of pages\"\r\n      [active]=\"page === currentPage\"\r\n    >\r\n      <a (click)=\"changeCurrentPage(page)\">{{ page }}</a>\r\n    </mz-pagination-page-button>\r\n    <mz-pagination-page-button [disabled]=\"currentPage === totalPages\">\r\n      <a (click)=\"nextPage()\"><i mz-icon [icon]=\"'chevron_right'\"></i></a>\r\n    </mz-pagination-page-button>\r\n    <mz-pagination-page-button [disabled]=\"currentPage === totalPages\" *ngIf=\"enableFirstAndLastPageButtons\">\r\n      <a (click)=\"lastPage()\"><i mz-icon [icon]=\"'last_page'\"></i></a>\r\n    </mz-pagination-page-button>\r\n  </ul>`,\r\n  styles: [``],\r\n})\r\nexport class MzPaginationComponent extends HandlePropChanges implements OnInit {\r\n  @Input() currentPage = 1;\r\n  @Input() enableFirstAndLastPageButtons = false;\r\n  @Input() itemsPerPage: number;\r\n  @Input() maxPageButtons = 5;\r\n  @Input() totalItems: number;\r\n  @Output() pageChange = new EventEmitter<number>();\r\n\r\n  pages: number[];\r\n  get totalPages(): number {\r\n    return Math.ceil(this.totalItems / this.itemsPerPage);\r\n  }\r\n\r\n  constructor() {\r\n    super();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.initHandlers();\r\n    this.renderButtons();\r\n  }\r\n\r\n  changeCurrentPage(pageNumber: number) {\r\n    this.currentPage = pageNumber;\r\n    this.pageChange.emit(pageNumber);\r\n    this.renderButtons();\r\n  }\r\n\r\n  firstPage() {\r\n    this.changeCurrentPage(1);\r\n  }\r\n\r\n  initHandlers() {\r\n    this.handlers = {\r\n      currentPage: () => this.renderButtons(),\r\n      itemsPerPage: () => this.renderButtons(),\r\n      maxPageButtons: () => this.renderButtons(),\r\n      totalItems: () => this.renderButtons(),\r\n    };\r\n  }\r\n\r\n  lastPage() {\r\n    this.changeCurrentPage(this.totalPages);\r\n  }\r\n\r\n  nextPage() {\r\n    if (this.currentPage < this.totalPages) {\r\n      const nextPage = this.currentPage + 1;\r\n      this.changeCurrentPage(nextPage);\r\n    }\r\n  }\r\n\r\n  previousPage() {\r\n    if (this.currentPage !== 1) {\r\n      const previousPage = this.currentPage - 1;\r\n      this.changeCurrentPage(previousPage);\r\n    }\r\n  }\r\n\r\n  renderButtons() {\r\n    const buttonsCount = Math.min(this.maxPageButtons, this.totalPages);\r\n    const maxPosition = this.totalPages - buttonsCount;\r\n    const halfButtons = Math.floor(buttonsCount / 2);\r\n\r\n    let hiddenPagesBefore = (this.currentPage - halfButtons);\r\n    if (hiddenPagesBefore > maxPosition) {\r\n      hiddenPagesBefore = maxPosition + 1;\r\n    }\r\n\r\n    const from = Math.max(hiddenPagesBefore, 1);\r\n    const to = Math.min(this.totalPages, from + this.maxPageButtons - 1);\r\n\r\n    this.pages = Array(buttonsCount).fill(0).map((x, i) => from + i);\r\n\r\n    if (this.currentPage > this.totalPages) {\r\n      this.currentPage = this.pages[0];\r\n    }\r\n  }\r\n}\r\n"]}