@asi-ngtools/lib
Version:
This project is a little components library, simple to use, which will help you to simplify your project.
148 lines (147 loc) • 13.8 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
import { Component, Input, EventEmitter, Output } from '@angular/core';
import * as nh from '../../native-helper';
export class AsiPaginationComponent {
constructor() {
this.nbElements = 0;
this.nbVisibleElements = 0;
this.selectedPagination = 1;
this.onPaginationChanged = new EventEmitter();
}
/**
* @return {?}
*/
onFirstPage() {
return this.selectedPagination === 1;
}
/**
* @return {?}
*/
onLastPage() {
return this.selectedPagination === this.nbElements;
}
/**
* @param {?} pagination
* @return {?}
*/
isCurrentPagination(pagination) {
return this.selectedPagination === pagination;
}
/**
* @param {?} pagination
* @return {?}
*/
changePagination(pagination) {
if (pagination !== AsiPaginationComponent.TRI_POINT) {
this.selectedPagination = pagination;
this.onPaginationChanged.emit(this.selectedPagination);
}
}
/**
* @return {?}
*/
previousPage() {
if (this.selectedPagination > 1) {
this.selectedPagination--;
this.onPaginationChanged.emit(this.selectedPagination);
}
}
/**
* @return {?}
*/
nextPage() {
if (this.selectedPagination < this.nbElements) {
this.selectedPagination++;
this.onPaginationChanged.emit(this.selectedPagination);
}
}
/**
* @return {?}
*/
goLastPage() {
if (this.selectedPagination !== this.nbElements) {
this.selectedPagination = this.nbElements;
this.onPaginationChanged.emit(this.selectedPagination);
}
}
/**
* @return {?}
*/
goFirstPage() {
if (this.selectedPagination !== 1) {
this.selectedPagination = 1;
this.onPaginationChanged.emit(this.selectedPagination);
}
}
/**
* @return {?}
*/
getPaginationItems() {
/** @type {?} */
const currentPage = this.selectedPagination;
/** @type {?} */
let halfVisibleElement = Math.floor(this.nbVisibleElements / 2);
if (!this.nbElements) {
this.nbElements = 1;
}
if (this.nbElements <= this.nbVisibleElements) {
// Show all
return this.createNumbersTab(1, this.nbElements);
}
else if (currentPage < halfVisibleElement + 2) {
// Pagination start
return nh.concat(this.createNumbersTab(1, this.nbVisibleElements - 1), [AsiPaginationComponent.TRI_POINT, this.nbElements]);
}
else if (currentPage > this.nbElements - halfVisibleElement) {
// Pagination end
return nh.concat([1, AsiPaginationComponent.TRI_POINT], this.createNumbersTab(this.nbElements - this.nbVisibleElements + 2, this.nbElements));
}
else {
// Between
return nh.concat([1, AsiPaginationComponent.TRI_POINT], this.createNumbersTab(currentPage - halfVisibleElement + 1, currentPage + halfVisibleElement - 1), [AsiPaginationComponent.TRI_POINT, this.nbElements]);
}
}
;
/**
* @param {?} min
* @param {?} max
* @return {?}
*/
createNumbersTab(min, max) {
/** @type {?} */
let index = min - 1;
return nh.times(max - min + 1, () => {
return ++index;
});
}
}
AsiPaginationComponent.TRI_POINT = '...';
AsiPaginationComponent.decorators = [
{ type: Component, args: [{
selector: 'asi-pagination',
host: { 'class': 'asi-component asi-pagination' },
template: "<div class=\"action-panel\">\r\n <div [ngClass]=\"{ 'disabled' : onFirstPage()}\">\r\n <span (click)=\"goFirstPage()\" class=\"paginate-boutton action\" [innerHTML]=\"'‹‹'\"></span>\r\n <span (click)=\"previousPage()\" class=\"paginate-boutton action\" [innerHTML]=\"'‹'\"></span>\r\n </div>\r\n</div>\r\n<span *ngFor=\"let paginationItem of getPaginationItems()\" [ngClass]=\"{'selected' : isCurrentPagination(paginationItem) , 'paginate-boutton' : paginationItem != '...'}\"\r\n (click)=\"changePagination(paginationItem)\" [innerHTML]=\"paginationItem\"></span>\r\n<div class=\"action-panel\">\r\n <div [ngClass]=\"{ 'disabled' : onLastPage()}\">\r\n <span (click)=\"nextPage()\" class=\"paginate-boutton action\" [innerHTML]=\"'›'\"></span>\r\n <span (click)=\"goLastPage()\" class=\"paginate-boutton action\" [innerHTML]=\"'››'\"></span>\r\n </div>\r\n</div>"
}] }
];
AsiPaginationComponent.propDecorators = {
nbElements: [{ type: Input }],
nbVisibleElements: [{ type: Input }],
selectedPagination: [{ type: Input }],
onPaginationChanged: [{ type: Output }]
};
if (false) {
/** @type {?} */
AsiPaginationComponent.TRI_POINT;
/** @type {?} */
AsiPaginationComponent.prototype.nbElements;
/** @type {?} */
AsiPaginationComponent.prototype.nbVisibleElements;
/** @type {?} */
AsiPaginationComponent.prototype.selectedPagination;
/** @type {?} */
AsiPaginationComponent.prototype.onPaginationChanged;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"asi-pagination.component.js","sourceRoot":"ng://@asi-ngtools/lib/","sources":["lib/components/asi-pagination/asi-pagination.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, EventEmitter, Output } from '@angular/core';\r\nimport * as nh from '../../native-helper';\r\n\r\n@Component({\r\n  selector: 'asi-pagination',\r\n  host: { 'class': 'asi-component asi-pagination' },\r\n  templateUrl: 'asi-pagination.component.html',\r\n})\r\nexport class AsiPaginationComponent {\r\n\r\n  private static TRI_POINT = '...';\r\n\r\n  @Input() nbElements = 0;\r\n  @Input() nbVisibleElements = 0;\r\n  @Input() selectedPagination = 1;\r\n  @Output() onPaginationChanged = new EventEmitter<number>();\r\n\r\n  onFirstPage() {\r\n    return this.selectedPagination === 1;\r\n  }\r\n\r\n  onLastPage() {\r\n    return this.selectedPagination === this.nbElements;\r\n  }\r\n\r\n  isCurrentPagination(pagination: number) {\r\n    return this.selectedPagination === pagination;\r\n  }\r\n\r\n  changePagination(pagination: any) {\r\n    if (pagination !== AsiPaginationComponent.TRI_POINT) {\r\n      this.selectedPagination = pagination;\r\n      this.onPaginationChanged.emit(this.selectedPagination);\r\n    }\r\n  }\r\n\r\n  previousPage() {\r\n    if (this.selectedPagination > 1) {\r\n      this.selectedPagination--;\r\n      this.onPaginationChanged.emit(this.selectedPagination);\r\n    }\r\n  }\r\n\r\n  nextPage() {\r\n    if (this.selectedPagination < this.nbElements) {\r\n      this.selectedPagination++;\r\n      this.onPaginationChanged.emit(this.selectedPagination);\r\n    }\r\n  }\r\n\r\n  goLastPage() {\r\n    if (this.selectedPagination !== this.nbElements) {\r\n      this.selectedPagination = this.nbElements;\r\n      this.onPaginationChanged.emit(this.selectedPagination);\r\n    }\r\n  }\r\n\r\n  goFirstPage() {\r\n    if (this.selectedPagination !== 1) {\r\n      this.selectedPagination = 1;\r\n      this.onPaginationChanged.emit(this.selectedPagination);\r\n    }\r\n  }\r\n\r\n  getPaginationItems() {\r\n    const currentPage = this.selectedPagination;\r\n    let halfVisibleElement = Math.floor(this.nbVisibleElements / 2);\r\n\r\n    if (!this.nbElements) {\r\n      this.nbElements = 1;\r\n    }\r\n\r\n    if (this.nbElements <= this.nbVisibleElements) {\r\n      // Show all\r\n      return this.createNumbersTab(1, this.nbElements);\r\n    } else if (currentPage < halfVisibleElement + 2) {\r\n      // Pagination start\r\n      return nh.concat(this.createNumbersTab(1, this.nbVisibleElements - 1), [AsiPaginationComponent.TRI_POINT, this.nbElements]);\r\n    } else if (currentPage > this.nbElements - halfVisibleElement) {\r\n      // Pagination end\r\n      return nh.concat([1, AsiPaginationComponent.TRI_POINT],\r\n        this.createNumbersTab(this.nbElements - this.nbVisibleElements + 2, this.nbElements));\r\n    } else {\r\n      // Between\r\n      return nh.concat([1, AsiPaginationComponent.TRI_POINT],\r\n        this.createNumbersTab(currentPage - halfVisibleElement + 1, currentPage + halfVisibleElement - 1),\r\n        [AsiPaginationComponent.TRI_POINT, this.nbElements]);\r\n    }\r\n  };\r\n\r\n  createNumbersTab(min: number, max: number): Array<number> {\r\n    let index = min - 1;\r\n    return nh.times(max - min + 1, () => {\r\n      return ++index;\r\n    });\r\n  }\r\n}\r\n"]}