UNPKG

ngx-materialize

Version:

An Angular wrap around Materialize library

175 lines (174 loc) 15.3 kB
/** * @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"]}