@stratio/egeo
Version:
358 lines • 29.8 kB
JavaScript
/**
* @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, ElementRef, EventEmitter, Input, Output } 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.
*
* * \@model
*
* [Paginate] {./st-pagination.interface.ts#Paginate}
* [PaginateOptions] {./st-pagination.interface.ts#PaginateOptions}
* [PaginateTexts] {./st-pagination.interface.ts#PaginateTexts}
* [PaginateTextsSchema] {./st-pagination.interface.ts#PaginateTextsSchema}
* [PaginateIconClasses] {./st-pagination.interface.ts#PaginateIconClasses}
*
* \@example
*
* {html}
*
* ```
* <div class="pagination">
* <st-pagination [total]="items.length" [perPage]="perPage" [currentPage]="page" [id]="'pagination-demo'"
* (change)="onChangePage($event)">
* </st-pagination>
* </div>
* ```
*
*/
export class StPaginationComponent {
/**
* @param {?} _cd
* @param {?} _paginationElement
*/
constructor(_cd, _paginationElement) {
this._cd = _cd;
this._paginationElement = _paginationElement;
/**
* \@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 }
];
/**
* \@Input {PaginateIconClasses} [iconClasses=Object(previous='', next='')] Icon classes for previous and next page buttons
*/
this.iconClasses = { previous: 'icon-arrow2_left', next: 'icon-arrow2_right' };
/**
* \@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;
this._perPage = 20;
}
/**
* \@Input {number} [currentPage=1] Number of the current page
* @return {?}
*/
get currentPage() {
return this._currentPage;
}
/**
* @param {?} currentPage
* @return {?}
*/
set currentPage(currentPage) {
this._currentPage = currentPage;
this.updatePages(false);
}
/**
* \@Input {number} [perPage=20] The maximum number of items displayed per page
* @return {?}
*/
get perPage() {
return this._perPage;
}
/**
* @param {?} perPage
* @return {?}
*/
set perPage(perPage) {
this.onChangePerPage(perPage, false);
}
/**
* \@Input {number} [total=''] Total of items
* @return {?}
*/
get total() {
return this._total;
}
/**
* @param {?} total
* @return {?}
*/
set total(total) {
this._total = total;
this.generateItems();
this.updatePages(false);
}
/**
* @return {?}
*/
get hasOptions() {
return this.items && this.items.length > 1;
}
/**
* @return {?}
*/
get paginationId() {
/** @type {?} */
const pagination = this._paginationElement.nativeElement;
return pagination.getAttribute('id') !== null ? pagination.id : null;
}
/**
* @return {?}
*/
get selectId() {
return this.paginationId !== null ? `${this.paginationId}-select` : null;
}
/**
* @return {?}
*/
get buttonPrevId() {
return this.paginationId !== null ? `${this.paginationId}-prev` : null;
}
/**
* @return {?}
*/
get buttonNextId() {
return this.paginationId !== null ? `${this.paginationId}-next` : null;
}
/**
* @return {?}
*/
ngOnInit() {
this.updatePages(false);
this.generateItems();
}
/**
* @return {?}
*/
generateItems() {
this.items = [];
this.perPageOptions.forEach(this.addPageOption.bind(this));
if (this.items.length) {
this.selectedItem = this.items.find((/**
* @param {?} item
* @return {?}
*/
item => item.value === this._perPage)) || this.items[0];
}
this._cd.markForCheck();
}
/**
* @return {?}
*/
nextPage() {
this.currentPage++;
this.updatePages();
}
/**
* @return {?}
*/
prevPage() {
this.currentPage--;
this.updatePages();
}
/**
* @param {?} perPage
* @param {?=} emit
* @return {?}
*/
onChangePerPage(perPage, emit = true) {
if (perPage && typeof perPage === 'number') {
this._currentPage = 1;
this._perPage = perPage;
this.updatePages(emit);
this.selectedItem = this.items.find((/**
* @param {?} item
* @return {?}
*/
item => item.value === this._perPage));
if (emit) {
this.changePerPage.emit(this._perPage);
}
}
}
/**
* @private
* @param {?} option
* @return {?}
*/
addPageOption(option) {
if (this._total && (!option.showFrom || option.showFrom <= this._total)) {
this.items.push({
label: `${option.value}`,
value: option.value
});
}
}
/**
* @private
* @param {?=} emit
* @return {?}
*/
updatePages(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=\"{{iconClasses?.previous || 'icon-arrow2_left'}}\"></i>\n </button>\n <button class=\"button button-toolbar\" [attr.id]=\"buttonNextId\" [disabled]=\"disableNextButton\" type=\"button\" (click)=\"nextPage()\">\n <i class=\"{{iconClasses?.next || '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 = () => [
{ type: ChangeDetectorRef },
{ type: ElementRef }
];
StPaginationComponent.propDecorators = {
label: [{ type: Input }],
perPageOptions: [{ type: Input }],
iconClasses: [{ type: Input }],
change: [{ type: Output }],
changePerPage: [{ type: Output }],
currentPage: [{ type: Input }],
perPage: [{ type: Input }],
total: [{ type: Input }]
};
if (false) {
/**
* \@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;
/**
* \@Input {PaginateIconClasses} [iconClasses=Object(previous='', next='')] Icon classes for previous and next page buttons
* @type {?}
*/
StPaginationComponent.prototype.iconClasses;
/**
* \@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._perPage;
/**
* @type {?}
* @private
*/
StPaginationComponent.prototype._total;
/**
* @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   ElementRef,\n   EventEmitter,\n   Input,\n   OnInit,\n   Output\n} from '@angular/core';\nimport { StDropDownMenuItem } from '../st-dropdown-menu/st-dropdown-menu.interface';\nimport { Paginate, PaginateIconClasses, 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 * * @model\n *\n *   [Paginate] {./st-pagination.interface.ts#Paginate}\n *   [PaginateOptions] {./st-pagination.interface.ts#PaginateOptions}\n *   [PaginateTexts] {./st-pagination.interface.ts#PaginateTexts}\n *   [PaginateTextsSchema] {./st-pagination.interface.ts#PaginateTextsSchema}\n *   [PaginateIconClasses] {./st-pagination.interface.ts#PaginateIconClasses}\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 {\n\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   /** @Input {PaginateIconClasses} [iconClasses=Object(previous='', next='')] Icon classes for previous and next page buttons */\n   @Input() iconClasses: PaginateIconClasses = { previous: 'icon-arrow2_left', next: 'icon-arrow2_right' };\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      this.updatePages(false);\n   }\n\n   /** @Input {number} [perPage=20] The maximum number of items displayed per page */\n   @Input()\n   get perPage(): number {\n      return this._perPage;\n   }\n\n   set perPage(perPage: number) {\n      this.onChangePerPage(perPage, false);\n   }\n\n   /** @Input {number} [total=''] Total of items */\n   @Input()\n   get total(): number {\n      return this._total;\n   }\n\n   set total(total: number) {\n      this._total = total;\n      this.generateItems();\n      this.updatePages(false);\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   private _perPage: number = 20;\n   private _total: number;\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   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, emit: boolean = true): void {\n      if (perPage && typeof perPage === 'number') {\n         this._currentPage = 1;\n         this._perPage = perPage;\n         this.updatePages(emit);\n         this.selectedItem = this.items.find(item => item.value === this._perPage);\n         if (emit) {\n            this.changePerPage.emit(this._perPage);\n         }\n      }\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"]}