UNPKG

@stratio/egeo

Version:
380 lines 30.9 kB
/** * @fileoverview added by tsickle * Generated from: lib/st-pagination/st-pagination.component.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ /* * © 2017 Stratio Big Data Inc., Sucursal en España. * * This software is licensed under the Apache License, Version 2.0. * This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. * See the terms of the License for more details. * * SPDX-License-Identifier: Apache-2.0. */ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Input, Output, ElementRef } from '@angular/core'; /** * \@description {Component} [Table] * * The pagination component has been designed to allow content to be displayed per pages. This informs user about the * number of the current page, the items displayed per page and the total of items. Moreover, when there are a lot of * items, it allows user to customize the number of items displayed per page. * * It is made by two sub-components: * - A range selector, that allows the user provides a dropdown to set how many items he wants to be displayed per page. * - A page navigation control, in order to let the user where he is and where he can go to. * * \@example * * {html} * * ``` * <div class="pagination"> * <st-pagination [total]="items.length" [perPage]="perPage" [currentPage]="page" [id]="'pagination-demo'" * (change)="onChangePage($event)"> * </st-pagination> * </div> * ``` * */ var StPaginationComponent = /** @class */ (function () { function StPaginationComponent(_cd, _paginationElement) { this._cd = _cd; this._paginationElement = _paginationElement; /** * \@Input {number} [perPage=20] The maximum number of items displayed per page */ this.perPage = 20; /** * \@Input {PaginateTexts} [label={element: 'Rows', perPage: 'per page', of: 'of'}] Translated texts displayed at the pagination */ this.label = { element: 'Rows', perPage: 'per page', of: 'of' }; /** * \@Input {PaginateOptions[]} * [perPageOptions=Array( Object( value: 20, showFrom: 0 ),Object( value: 50, showFrom: 50 ), Object( value: 200, showFrom: 200 ))] * List of options displayed at a selector where user can change the number of items displayed per page */ this.perPageOptions = [ { value: 20, showFrom: 0 }, { value: 50, showFrom: 50 }, { value: 200, showFrom: 200 } ]; /** * \@Output {Paginate} [change=''] Event emitted when user interacts with some of the elements in the pagination. * This sends the new pagination status (current page and items per page) */ this.change = new EventEmitter(); /** * \@Output {PaginateOptions} [changePerPage=''] Event emitted when user interacts with some of the elements in the selector of items displayed per page. * This sends the current items per page. */ this.changePerPage = new EventEmitter(); this.disableNextButton = false; this.disablePrevButton = true; this.items = []; this._currentPage = 1; } Object.defineProperty(StPaginationComponent.prototype, "currentPage", { /** @Input {number} [currentPage=1] Number of the current page */ get: /** * \@Input {number} [currentPage=1] Number of the current page * @return {?} */ function () { return this._currentPage; }, set: /** * @param {?} currentPage * @return {?} */ function (currentPage) { this._currentPage = currentPage; }, enumerable: true, configurable: true }); Object.defineProperty(StPaginationComponent.prototype, "hasOptions", { get: /** * @return {?} */ function () { return this.items && this.items.length > 1; }, enumerable: true, configurable: true }); Object.defineProperty(StPaginationComponent.prototype, "paginationId", { get: /** * @return {?} */ function () { /** @type {?} */ var pagination = this._paginationElement.nativeElement; return pagination.getAttribute('id') !== null ? pagination.id : null; }, enumerable: true, configurable: true }); Object.defineProperty(StPaginationComponent.prototype, "selectId", { get: /** * @return {?} */ function () { return this.paginationId !== null ? this.paginationId + "-select" : null; }, enumerable: true, configurable: true }); Object.defineProperty(StPaginationComponent.prototype, "buttonPrevId", { get: /** * @return {?} */ function () { return this.paginationId !== null ? this.paginationId + "-prev" : null; }, enumerable: true, configurable: true }); Object.defineProperty(StPaginationComponent.prototype, "buttonNextId", { get: /** * @return {?} */ function () { return this.paginationId !== null ? this.paginationId + "-next" : null; }, enumerable: true, configurable: true }); /** * @return {?} */ StPaginationComponent.prototype.ngOnInit = /** * @return {?} */ function () { this.updatePages(false); this.generateItems(); }; /** * @param {?} changes * @return {?} */ StPaginationComponent.prototype.ngOnChanges = /** * @param {?} changes * @return {?} */ function (changes) { if (changes.total && changes.total.previousValue !== changes.total.currentValue && !changes.total.firstChange) { this.generateItems(); this.updatePages(false); } if (changes.currentPage && changes.currentPage.previousValue !== changes.currentPage.currentValue && !changes.currentPage.firstChange) { this._currentPage = changes.currentPage.currentValue; this.updatePages(false); } if (changes.perPage && changes.perPage.previousValue !== changes.perPage.currentValue && !changes.perPage.firstChange) { this.onChangePerPage(changes.perPage.currentValue); } }; /** * @return {?} */ StPaginationComponent.prototype.generateItems = /** * @return {?} */ function () { var _this = this; this.items = []; this.perPageOptions.forEach(this.addPageOption.bind(this)); if (this.items.length) { this.selectedItem = this.items.find((/** * @param {?} item * @return {?} */ function (item) { return item.value === _this.perPage; })) || this.items[0]; } this._cd.markForCheck(); }; /** * @return {?} */ StPaginationComponent.prototype.nextPage = /** * @return {?} */ function () { this.currentPage++; this.updatePages(); }; /** * @return {?} */ StPaginationComponent.prototype.prevPage = /** * @return {?} */ function () { this.currentPage--; this.updatePages(); }; /** * @param {?} perPage * @return {?} */ StPaginationComponent.prototype.onChangePerPage = /** * @param {?} perPage * @return {?} */ function (perPage) { var _this = this; this.currentPage = 1; this.perPage = perPage; this.updatePages(); this.selectedItem = this.items.find((/** * @param {?} item * @return {?} */ function (item) { return item.value === _this.perPage; })); this.changePerPage.emit(this.perPage); }; /** * @private * @param {?} option * @return {?} */ StPaginationComponent.prototype.addPageOption = /** * @private * @param {?} option * @return {?} */ function (option) { if (this.total && (!option.showFrom || option.showFrom <= this.total)) { this.items.push({ label: "" + option.value, value: option.value }); } }; /** * @private * @param {?=} emit * @return {?} */ StPaginationComponent.prototype.updatePages = /** * @private * @param {?=} emit * @return {?} */ function (emit) { if (emit === void 0) { emit = true; } this.lastItem = this.perPage * this._currentPage; if (this.currentPage === 1) { this.firstItem = this._currentPage; this.disablePrevButton = true; } else { this.firstItem = this.perPage * (this._currentPage - 1) + 1; this.disablePrevButton = false; } if (this.lastItem >= this.total) { this.lastItem = this.total; this.disableNextButton = true; } else { this.disableNextButton = false; } if (emit) { this.change.emit({ currentPage: this._currentPage, perPage: this.perPage }); } }; StPaginationComponent.decorators = [ { type: Component, args: [{ selector: 'st-pagination', template: "<!--\n\n \u00A9 2017 Stratio Big Data Inc., Sucursal en Espa\u00F1a.\n\n This software is licensed under the Apache License, Version 2.0.\n This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;\n without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n See the terms of the License for more details.\n\n SPDX-License-Identifier: Apache-2.0.\n\n-->\n<div class=\"st-pagination pagination\">\n <div *ngIf=\"hasOptions\" class=\"label st-pagination__per-page\">\n <p class=\"st-pagination__label\">{{label.element}} {{label.perPage}}</p>\n <st-select class=\"st-pagination__selector\" [options]=\"items\" [selected]=\"selectedItem\" (select)=\"onChangePerPage($event)\" [attr.id]=\"selectId\"></st-select>\n </div>\n\n <div class=\"label current-page-info\">\n <p class=\"st-pagination__label\">{{firstItem}}-{{lastItem}} {{label.of || 'of'}} {{total}}</p>\n\n <div class=\"buttons\">\n <button class=\"button button-toolbar\" [attr.id]=\"buttonPrevId\" [disabled]=\"disablePrevButton\" type=\"button\" (click)=\"prevPage()\">\n <i class=\"icon-arrow2_left\"></i>\n </button>\n <button class=\"button button-toolbar\" [attr.id]=\"buttonNextId\" [disabled]=\"disableNextButton\" type=\"button\" (click)=\"nextPage()\">\n <i class=\"icon-arrow2_right\"></i>\n </button>\n </div>\n </div>\n</div>\n", changeDetection: ChangeDetectionStrategy.OnPush, styles: ["@charset \"UTF-8\";.pagination{display:flex;align-items:center;height:42px}.pagination .label{display:flex;align-items:center}.pagination .label p{margin:0;padding-right:15px}.pagination .current-page-info{flex:1;justify-content:flex-end}.pagination .st-pagination__selector{max-width:93px}.pagination button:first-child{margin:0 5px}"] }] } ]; /** @nocollapse */ StPaginationComponent.ctorParameters = function () { return [ { type: ChangeDetectorRef }, { type: ElementRef } ]; }; StPaginationComponent.propDecorators = { perPage: [{ type: Input }], total: [{ type: Input }], label: [{ type: Input }], perPageOptions: [{ type: Input }], change: [{ type: Output }], changePerPage: [{ type: Output }], currentPage: [{ type: Input }] }; return StPaginationComponent; }()); export { StPaginationComponent }; if (false) { /** * \@Input {number} [perPage=20] The maximum number of items displayed per page * @type {?} */ StPaginationComponent.prototype.perPage; /** * \@Input {number} [total=''] Total of items * @type {?} */ StPaginationComponent.prototype.total; /** * \@Input {PaginateTexts} [label={element: 'Rows', perPage: 'per page', of: 'of'}] Translated texts displayed at the pagination * @type {?} */ StPaginationComponent.prototype.label; /** * \@Input {PaginateOptions[]} * [perPageOptions=Array( Object( value: 20, showFrom: 0 ),Object( value: 50, showFrom: 50 ), Object( value: 200, showFrom: 200 ))] * List of options displayed at a selector where user can change the number of items displayed per page * @type {?} */ StPaginationComponent.prototype.perPageOptions; /** * \@Output {Paginate} [change=''] Event emitted when user interacts with some of the elements in the pagination. * This sends the new pagination status (current page and items per page) * @type {?} */ StPaginationComponent.prototype.change; /** * \@Output {PaginateOptions} [changePerPage=''] Event emitted when user interacts with some of the elements in the selector of items displayed per page. * This sends the current items per page. * @type {?} */ StPaginationComponent.prototype.changePerPage; /** @type {?} */ StPaginationComponent.prototype.disableNextButton; /** @type {?} */ StPaginationComponent.prototype.disablePrevButton; /** @type {?} */ StPaginationComponent.prototype.firstItem; /** @type {?} */ StPaginationComponent.prototype.lastItem; /** @type {?} */ StPaginationComponent.prototype.items; /** @type {?} */ StPaginationComponent.prototype.selectedItem; /** * @type {?} * @private */ StPaginationComponent.prototype._currentPage; /** * @type {?} * @private */ StPaginationComponent.prototype._cd; /** * @type {?} * @private */ StPaginationComponent.prototype._paginationElement; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"st-pagination.component.js","sourceRoot":"ng://@stratio/egeo/","sources":["lib/st-pagination/st-pagination.component.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * © 2017 Stratio Big Data Inc., Sucursal en España.\n *\n * This software is licensed under the Apache License, Version 2.0.\n * This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;\n * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n * See the terms of the License for more details.\n *\n * SPDX-License-Identifier: Apache-2.0.\n */\nimport {\n   ChangeDetectionStrategy,\n   ChangeDetectorRef,\n   Component,\n   EventEmitter,\n   Input,\n   OnChanges,\n   OnInit,\n   Output,\n   SimpleChanges,\n   ElementRef\n} from '@angular/core';\nimport { StDropDownMenuItem } from '../st-dropdown-menu/st-dropdown-menu.interface';\nimport { Paginate, PaginateOptions, PaginateTexts } from './st-pagination.interface';\n\n/**\n * @description {Component} [Table]\n *\n * The pagination component has been designed to allow content to be displayed per pages. This informs user about the\n * number of the current page, the items displayed per page and the total of items. Moreover, when there are a lot of\n * items, it allows user to customize the number of items displayed per page.\n *\n * It is made by two sub-components:\n * - A range selector, that allows the user provides a dropdown to set how many items he wants to be displayed per page.\n * - A page navigation control, in order to let the user where he is and where he can go to.\n *\n * @example\n *\n * {html}\n *\n * ```\n * <div class=\"pagination\">\n *     <st-pagination [total]=\"items.length\" [perPage]=\"perPage\" [currentPage]=\"page\" [id]=\"'pagination-demo'\"\n *     (change)=\"onChangePage($event)\">\n *     </st-pagination>\n *     </div>\n * ```\n *\n */\n@Component({\n   selector: 'st-pagination',\n   templateUrl: './st-pagination.component.html',\n   styleUrls: ['./st-pagination.component.scss'],\n   changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class StPaginationComponent implements OnInit, OnChanges {\n   /** @Input {number} [perPage=20] The maximum number of items displayed per page */\n   @Input() perPage: number = 20;\n\n   /** @Input {number} [total=''] Total of items */\n   @Input() total: number;\n\n   /** @Input {PaginateTexts} [label={element: 'Rows', perPage: 'per page', of: 'of'}] Translated texts displayed at the pagination */\n   @Input() label: PaginateTexts = {\n      element: 'Rows', perPage: 'per page', of: 'of'\n   };\n\n   /** @Input {PaginateOptions[]}\n    * [perPageOptions=Array( Object( value: 20, showFrom: 0 ),Object( value: 50, showFrom: 50 ), Object( value: 200, showFrom: 200 ))]\n    *  List of options displayed at a selector where user can change the number of items displayed per page\n    */\n   @Input() perPageOptions: PaginateOptions[] = [\n      { value: 20, showFrom: 0 }, { value: 50, showFrom: 50 }, { value: 200, showFrom: 200 }\n   ];\n\n   /** @Output {Paginate} [change=''] Event emitted when user interacts with some of the elements in the pagination.\n    *  This sends the new pagination status (current page and items per page)\n    */\n   @Output() change: EventEmitter<Paginate> = new EventEmitter<Paginate>();\n\n   /** @Output {PaginateOptions} [changePerPage='']  Event emitted when user interacts with some of the elements in the selector of items displayed per page.\n    * This sends the current items per page.\n    */\n   @Output() changePerPage: EventEmitter<number> = new EventEmitter<number>();\n\n   /** @Input {number} [currentPage=1] Number of the current page */\n   @Input()\n   get currentPage(): number {\n      return this._currentPage;\n   }\n\n   set currentPage(currentPage: number) {\n      this._currentPage = currentPage;\n   }\n\n   public disableNextButton: boolean = false;\n   public disablePrevButton: boolean = true;\n   public firstItem: number;\n   public lastItem: number;\n   public items: StDropDownMenuItem[] = [];\n   public selectedItem: StDropDownMenuItem;\n\n   private _currentPage: number = 1;\n\n   constructor(private _cd: ChangeDetectorRef,\n               private _paginationElement: ElementRef) {\n   }\n\n   get hasOptions(): boolean {\n      return this.items && this.items.length > 1;\n   }\n\n   get paginationId(): string | null {\n      const pagination: HTMLElement = this._paginationElement.nativeElement;\n      return pagination.getAttribute('id') !== null ? pagination.id : null;\n   }\n\n   get selectId(): string {\n      return this.paginationId !== null ? `${this.paginationId}-select` : null;\n   }\n\n   get buttonPrevId(): string {\n      return this.paginationId !== null ? `${this.paginationId}-prev` : null;\n   }\n\n   get buttonNextId(): string {\n      return this.paginationId !== null ? `${this.paginationId}-next` : null;\n   }\n\n   ngOnInit(): void {\n      this.updatePages(false);\n      this.generateItems();\n   }\n\n   ngOnChanges(changes: SimpleChanges): void {\n      if (changes.total && changes.total.previousValue !== changes.total.currentValue && !changes.total.firstChange) {\n         this.generateItems();\n         this.updatePages(false);\n      }\n      if (changes.currentPage && changes.currentPage.previousValue !== changes.currentPage.currentValue && !changes.currentPage.firstChange) {\n         this._currentPage = changes.currentPage.currentValue;\n         this.updatePages(false);\n      }\n      if (changes.perPage && changes.perPage.previousValue !== changes.perPage.currentValue && !changes.perPage.firstChange) {\n         this.onChangePerPage(changes.perPage.currentValue);\n      }\n   }\n\n   generateItems(): void {\n      this.items = [];\n      this.perPageOptions.forEach(this.addPageOption.bind(this));\n\n      if (this.items.length) {\n         this.selectedItem = this.items.find(item => item.value === this.perPage) || this.items[0];\n      }\n\n      this._cd.markForCheck();\n   }\n\n   nextPage(): void {\n      this.currentPage++;\n      this.updatePages();\n   }\n\n   prevPage(): void {\n      this.currentPage--;\n      this.updatePages();\n   }\n\n   onChangePerPage(perPage: number): void {\n      this.currentPage = 1;\n      this.perPage = perPage;\n      this.updatePages();\n      this.selectedItem = this.items.find(item => item.value === this.perPage);\n      this.changePerPage.emit(this.perPage);\n   }\n\n   private addPageOption(option: PaginateOptions): void {\n      if (this.total && (!option.showFrom || option.showFrom <= this.total)) {\n         this.items.push({\n            label: `${option.value}`,\n            value: option.value\n         });\n      }\n   }\n\n   private updatePages(emit: boolean = true): void {\n      this.lastItem = this.perPage * this._currentPage;\n\n      if (this.currentPage === 1) {\n         this.firstItem = this._currentPage;\n         this.disablePrevButton = true;\n      } else {\n         this.firstItem = this.perPage * (this._currentPage - 1) + 1;\n         this.disablePrevButton = false;\n      }\n\n      if (this.lastItem >= this.total) {\n         this.lastItem = this.total;\n         this.disableNextButton = true;\n      } else {\n         this.disableNextButton = false;\n      }\n\n      if (emit) {\n         this.change.emit({\n            currentPage: this._currentPage,\n            perPage: this.perPage\n         });\n      }\n   }\n}\n"]}