@angular-generic-table/core
Version:
A generic table component for Angular
149 lines (148 loc) • 17.7 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
import { Component, Input } from '@angular/core';
import { GenericTableComponent } from './generic-table.component';
var GtPaginationComponent = /** @class */ (function () {
function GtPaginationComponent() {
this.ready = false;
}
Object.defineProperty(GtPaginationComponent.prototype, "genericTable", {
get: /**
* @return {?}
*/
function () {
return this._genericTable;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
var _this = this;
if (value) {
value.gtEvent.subscribe(function (res) {
if (res.name === 'gt-info' && res.value.pageTotal > 0) {
_this.ready = true;
}
});
}
this._genericTable = value;
},
enumerable: true,
configurable: true
});
GtPaginationComponent.decorators = [
{ type: Component, args: [{
selector: 'gt-pagination',
template: "<nav class=\"gt-pagination\" aria-label=\"Table navigation\" *ngIf=\"genericTable && genericTable.gtInfo && ready && genericTable.gtData?.length > 0\" [ngClass]=\"{'no-data':genericTable.gtInfo.pageTotal === 0}\">\n <ul class=\"pagination\" [ngClass]=\"gtClasses\">\n <li class=\"page-item\" [ngClass]=\"{'disabled' : genericTable.gtInfo.pageCurrent === 1 || genericTable.loading }\"><a class=\"page-link\" href=\"javascript:void(0);\" (click)=\"genericTable.gtInfo.pageCurrent > 1 && genericTable.previousPage()\" [attr.aria-label]=\"genericTable.gtTexts.paginatePrevious\"><span aria-hidden=\"true\">«</span><span class=\"sr-only\">{{genericTable.gtTexts.paginatePrevious}}</span></a></li>\n <li class=\"page-item\" [ngClass]=\"{'disabled' : genericTable.loading && genericTable.gtInfo.pageCurrent !== page, 'active' : genericTable.gtInfo.pageCurrent === page }\" *ngFor=\"let page of genericTable.gtInfo.pageTotal | gtPaginationPipe:genericTable.gtInfo.pageCurrent\"><a class=\"page-link\" [tabindex]=\"page === true ? -1:0\" href=\"javascript:void(0);\" (click)=\"page === true ? '':genericTable.goToPage(page)\">{{page === true ? '…':page}}</a></li>\n <li class=\"page-item\" [ngClass]=\"{'disabled' : genericTable.gtInfo.pageCurrent === genericTable.gtInfo.pageTotal || genericTable.loading }\"><a class=\"page-link gt-link\" href=\"javascript:void(0);\" (click)=\"genericTable.gtInfo.pageCurrent !== genericTable.gtInfo.pageTotal && genericTable.nextPage()\" [attr.aria-label]=\"genericTable.gtTexts.paginateNext\"><span aria-hidden=\"true\">»</span><span class=\"sr-only\">{{genericTable.gtTexts.paginateNext}}</span></a></li>\n </ul>\n </nav>\n ",
styles: ['.gt-link {cursor: pointer;}']
},] },
];
/** @nocollapse */
GtPaginationComponent.propDecorators = {
"genericTable": [{ type: Input },],
"gtClasses": [{ type: Input },],
};
return GtPaginationComponent;
}());
export { GtPaginationComponent };
function GtPaginationComponent_tsickle_Closure_declarations() {
/** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */
GtPaginationComponent.decorators;
/**
* @nocollapse
* @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>}
*/
GtPaginationComponent.ctorParameters;
/** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */
GtPaginationComponent.propDecorators;
/** @type {?} */
GtPaginationComponent.prototype._genericTable;
/** @type {?} */
GtPaginationComponent.prototype.gtClasses;
/** @type {?} */
GtPaginationComponent.prototype.ready;
}
import { Pipe } from '@angular/core';
var PaginationPipe = /** @class */ (function () {
function PaginationPipe() {
}
/**
* @param {?} totalPages
* @param {?} currentPage
* @return {?}
*/
PaginationPipe.prototype.transform = /**
* @param {?} totalPages
* @param {?} currentPage
* @return {?}
*/
function (totalPages, currentPage) {
if (totalPages === 0) {
return [1];
}
var /** @type {?} */ pagination = []; // create new empty array for pagination
var /** @type {?} */ siblings = 2; // sibling elements ie. number of elements on each side of current page
var /** @type {?} */ paginationLength = totalPages < siblings * 2 + 1 ? totalPages : siblings * 2 + 1; // number of elements in pagination array
var /** @type {?} */ start = currentPage <= siblings ? 1 : currentPage - siblings; // starting position for array
var /** @type {?} */ modifier = totalPages - (currentPage + siblings) <= 0
? totalPages - (currentPage + siblings)
: 0; // modifier for pagination values
var /** @type {?} */ modifiedPosition = start + modifier <= 0 ? 1 : start + modifier;
// push pages to pagination array
for (var /** @type {?} */ i = 0; i < paginationLength; i++) {
pagination.push(modifiedPosition + i);
}
// if first page is not included in pagination...
if (pagination.indexOf(1) === -1) {
// ...check if second page is in pagination...
if (pagination.indexOf(2) === -1) {
// ...if not check if total number of pages equals seven and number of siblings are two...
if (totalPages === 7 && siblings === 2) {
// ...add second page and don't convert page number to ellipsis
pagination.unshift(2);
}
else {
// ...if not, use this placeholder for ellipsis instead of actual page number
pagination[0] = true;
}
}
// ...add first page as first array item
pagination.unshift(1);
}
else if (totalPages > paginationLength) {
// if first page is included add extra page to keep number of items consistent
pagination.splice(paginationLength, 0, paginationLength + 1);
}
// check if last page is included in pagination...
if (pagination.indexOf(totalPages) === -1) {
// ...if not, page next to last should either show ellipsis or actual page number for the page
pagination[pagination.length - 1] =
pagination[pagination.length - 1] === totalPages - 1
? totalPages - 1
: true;
// ...add last page to pagination
pagination.push(totalPages);
}
return pagination;
};
PaginationPipe.decorators = [
{ type: Pipe, args: [{
name: 'gtPaginationPipe'
},] },
];
return PaginationPipe;
}());
export { PaginationPipe };
function PaginationPipe_tsickle_Closure_declarations() {
/** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */
PaginationPipe.decorators;
/**
* @nocollapse
* @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>}
*/
PaginationPipe.ctorParameters;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gt-pagination.component.js","sourceRoot":"ng://@angular-generic-table/core/","sources":["components/gt-pagination.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input } from '@angular/core';\nimport { GenericTableComponent } from './generic-table.component';\n\n@Component({\n\tselector: 'gt-pagination',\n\ttemplate: `<nav class=\"gt-pagination\" aria-label=\"Table navigation\" *ngIf=\"genericTable && genericTable.gtInfo && ready && genericTable.gtData?.length > 0\" [ngClass]=\"{'no-data':genericTable.gtInfo.pageTotal === 0}\">\n  <ul class=\"pagination\" [ngClass]=\"gtClasses\">\n    <li class=\"page-item\" [ngClass]=\"{'disabled' : genericTable.gtInfo.pageCurrent === 1 || genericTable.loading }\"><a class=\"page-link\" href=\"javascript:void(0);\" (click)=\"genericTable.gtInfo.pageCurrent > 1 && genericTable.previousPage()\" [attr.aria-label]=\"genericTable.gtTexts.paginatePrevious\"><span aria-hidden=\"true\">&laquo;</span><span class=\"sr-only\">{{genericTable.gtTexts.paginatePrevious}}</span></a></li>\n    <li class=\"page-item\" [ngClass]=\"{'disabled' : genericTable.loading && genericTable.gtInfo.pageCurrent !== page, 'active' : genericTable.gtInfo.pageCurrent === page }\" *ngFor=\"let page of genericTable.gtInfo.pageTotal | gtPaginationPipe:genericTable.gtInfo.pageCurrent\"><a class=\"page-link\" [tabindex]=\"page === true ? -1:0\" href=\"javascript:void(0);\" (click)=\"page === true ? '':genericTable.goToPage(page)\">{{page === true ? '&hellip;':page}}</a></li>\n    <li class=\"page-item\" [ngClass]=\"{'disabled' : genericTable.gtInfo.pageCurrent === genericTable.gtInfo.pageTotal || genericTable.loading }\"><a class=\"page-link gt-link\" href=\"javascript:void(0);\" (click)=\"genericTable.gtInfo.pageCurrent !== genericTable.gtInfo.pageTotal && genericTable.nextPage()\" [attr.aria-label]=\"genericTable.gtTexts.paginateNext\"><span aria-hidden=\"true\">&raquo;</span><span class=\"sr-only\">{{genericTable.gtTexts.paginateNext}}</span></a></li>\n  </ul>\n  </nav>\n    `,\n\tstyles: ['.gt-link {cursor: pointer;}']\n})\nexport class GtPaginationComponent {\n\tget genericTable(): GenericTableComponent<any, any> {\n\t\treturn this._genericTable;\n\t}\n\n\t@Input()\n\tset genericTable(value: GenericTableComponent<any, any>) {\n\t\tif (value) {\n\t\t\tvalue.gtEvent.subscribe((res: any) => {\n\t\t\t\tif (res.name === 'gt-info' && res.value.pageTotal > 0) {\n\t\t\t\t\tthis.ready = true;\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\t\tthis._genericTable = value;\n\t}\n\n\tprivate _genericTable: GenericTableComponent<any, any>;\n\t@Input() gtClasses: string;\n\tpublic ready = false;\n}\nimport { Pipe, PipeTransform } from '@angular/core';\n\n@Pipe({\n\tname: 'gtPaginationPipe'\n})\nexport class PaginationPipe implements PipeTransform {\n\ttransform(totalPages: number, currentPage: number): Array<any> {\n\t\tif (totalPages === 0) {\n\t\t\treturn [1];\n\t\t}\n\t\tconst pagination: Array<any> = []; // create new empty array for pagination\n\t\tconst siblings = 2; // sibling elements ie. number of elements on each side of current page\n\t\tconst paginationLength =\n\t\t\ttotalPages < siblings * 2 + 1 ? totalPages : siblings * 2 + 1; // number of elements in pagination array\n\t\tconst start = currentPage <= siblings ? 1 : currentPage - siblings; // starting position for array\n\t\tconst modifier =\n\t\t\ttotalPages - (currentPage + siblings) <= 0\n\t\t\t\t? totalPages - (currentPage + siblings)\n\t\t\t\t: 0; // modifier for pagination values\n\t\tconst modifiedPosition = start + modifier <= 0 ? 1 : start + modifier;\n\n\t\t// push pages to pagination array\n\t\tfor (let i = 0; i < paginationLength; i++) {\n\t\t\tpagination.push(modifiedPosition + i);\n\t\t}\n\n\t\t// if first page is not included in pagination...\n\t\tif (pagination.indexOf(1) === -1) {\n\t\t\t// ...check if second page is in pagination...\n\t\t\tif (pagination.indexOf(2) === -1) {\n\t\t\t\t// ...if not check if total number of pages equals seven and number of siblings are two...\n\t\t\t\tif (totalPages === 7 && siblings === 2) {\n\t\t\t\t\t// ...add second page and don't convert page number to ellipsis\n\t\t\t\t\tpagination.unshift(2);\n\t\t\t\t} else {\n\t\t\t\t\t// ...if not, use this placeholder for ellipsis instead of actual page number\n\t\t\t\t\tpagination[0] = true;\n\t\t\t\t}\n\t\t\t}\n\t\t\t// ...add first page as first array item\n\t\t\tpagination.unshift(1);\n\t\t} else if (totalPages > paginationLength) {\n\t\t\t// if first page is included add extra page to keep number of items consistent\n\t\t\tpagination.splice(paginationLength, 0, paginationLength + 1);\n\t\t}\n\t\t// check if last page is included in pagination...\n\t\tif (pagination.indexOf(totalPages) === -1) {\n\t\t\t// ...if not, page next to last should either show ellipsis or actual page number for the page\n\t\t\tpagination[pagination.length - 1] =\n\t\t\t\tpagination[pagination.length - 1] === totalPages - 1\n\t\t\t\t\t? totalPages - 1\n\t\t\t\t\t: true;\n\n\t\t\t// ...add last page to pagination\n\t\t\tpagination.push(totalPages);\n\t\t}\n\n\t\treturn pagination;\n\t}\n}\n"]}