angular-io-pager
Version:
314 lines (303 loc) • 42 kB
JavaScript
(function (global, factory) {
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('@angular/forms'), require('@angular/platform-browser')) :
typeof define === 'function' && define.amd ? define('angular-io-pager', ['exports', '@angular/core', '@angular/forms', '@angular/platform-browser'], factory) :
(factory((global['angular-io-pager'] = {}),global.ng.core,global.ng.forms,global.ng.platformBrowser));
}(this, (function (exports,core,forms,platformBrowser) { 'use strict';
/*! *****************************************************************************
Copyright (c) Microsoft Corporation. All rights reserved.
Licensed under the Apache License, Version 2.0 (the "License"); you may not use
this file except in compliance with the License. You may obtain a copy of the
License at http://www.apache.org/licenses/LICENSE-2.0
THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED
WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,
MERCHANTABLITY OR NON-INFRINGEMENT.
See the Apache Version 2.0 License for specific language governing permissions
and limitations under the License.
***************************************************************************** */
function __read(o, n) {
var m = typeof Symbol === "function" && o[Symbol.iterator];
if (!m)
return o;
var i = m.call(o), r, ar = [], e;
try {
while ((n === void 0 || n-- > 0) && !(r = i.next()).done)
ar.push(r.value);
}
catch (error) {
e = { error: error };
}
finally {
try {
if (r && !r.done && (m = i["return"]))
m.call(i);
}
finally {
if (e)
throw e.error;
}
}
return ar;
}
function __spread() {
for (var ar = [], i = 0; i < arguments.length; i++)
ar = ar.concat(__read(arguments[i]));
return ar;
}
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
var AngularIoPagerComponent = (function () {
function AngularIoPagerComponent() {
this.pageGap = 10;
this.id = 1;
this.noOfPages = 10;
this.pageClick = new core.EventEmitter();
// page view count selectors
this.from = 1;
this.to = 0;
this.pageLength = 20;
this.currentPage = 1;
this.pages = [];
this.pageNum = [];
this.showLeftNav = false;
this.showRightNav = false;
this.totalPageLength = 0;
this.leftNavString = '<<';
this.rightNavString = '>>';
this.lastPageMax = 0;
this.lastPageMin = 0;
this._total = 0;
}
Object.defineProperty(AngularIoPagerComponent.prototype, "totalRecords", {
get: /**
* @return {?}
*/ function () {
return this._total;
},
set: /**
* @param {?} value
* @return {?}
*/ function (value) {
this._total = value;
if (value > 0) {
this.pagePreparation();
}
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
AngularIoPagerComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
for (var i = 1; i <= this.pageLength; i++) {
this.pages.push(i * this.pageGap);
}
this.to = this.pages[0];
};
/**
* @return {?}
*/
AngularIoPagerComponent.prototype.pagePreparation = /**
* @return {?}
*/
function () {
var _this = this;
this.reCalculatePageNumbers();
setTimeout(function () {
_this.setSelectedPage();
}, 0);
};
/**
* @return {?}
*/
AngularIoPagerComponent.prototype.reCalculatePageNumbers = /**
* @return {?}
*/
function () {
/** @type {?} */
var divided = (this.totalRecords / this.pageGap).toString().split('.');
/** @type {?} */
var wholePageLen = parseInt(divided[0], 10);
/** @type {?} */
var partialPageLen = 0;
if (divided.length === 2) {
// has one more page with limited records
partialPageLen = 1;
}
this.totalPageLength = wholePageLen + partialPageLen;
this.pageNum.length = 0;
this.populatePages(1);
};
/**
* @param {?} start
* @return {?}
*/
AngularIoPagerComponent.prototype.populatePages = /**
* @param {?} start
* @return {?}
*/
function (start) {
/** @type {?} */
var until = 1;
this.pageNum.length = 0;
for (var i = start; i <= this.totalPageLength && until <= this.noOfPages; i++) {
this.pageNum.push(i);
until++;
}
this.currentPage = this.lastPageMin = Math.min.apply(Math, __spread(this.pageNum));
this.lastPageMax = Math.max.apply(Math, __spread(this.pageNum));
this.setPrevNextNav();
};
/**
* @return {?}
*/
AngularIoPagerComponent.prototype.pageLengthChange = /**
* @return {?}
*/
function () {
this.reCalculatePageNumbers();
this.setSelectedPage();
};
/**
* @param {?} e
* @return {?}
*/
AngularIoPagerComponent.prototype.pageChange = /**
* @param {?} e
* @return {?}
*/
function (e) {
if (e.target.classList.contains('cmdLeft')) {
this.populatePages(this.lastPageMin - this.noOfPages);
this.setSelectedPage();
}
else if (e.target.classList.contains('cmdRight')) {
this.populatePages(++this.lastPageMax);
this.setSelectedPage();
}
else {
this.setSelectedPage(e.target);
}
};
/**
* @param {?=} el
* @return {?}
*/
AngularIoPagerComponent.prototype.setSelectedPage = /**
* @param {?=} el
* @return {?}
*/
function (el) {
var _this = this;
if (el === void 0) {
el = null;
}
if (el != null) {
this.currentPage = parseInt(el.innerText, 10);
}
this.to = Math.min(this.currentPage * this.pageGap, this.totalRecords);
this.from = this.currentPage * this.pageGap - this.pageGap + 1;
setTimeout(function () {
el = /** @type {?} */ (((el == null
? document
.getElementById('pager' + _this.id)
.querySelector('.pageElements')
: el)));
/** @type {?} */
var closePageNum = el;
while ((closePageNum = closePageNum.parentElement) &&
!closePageNum.classList.contains('pageNumbers')) { }
Array.from(closePageNum.children).forEach(function (x) {
return x.classList.remove('selected');
});
el.classList.add('selected');
}, 0);
this.emitPageClick();
};
/**
* @return {?}
*/
AngularIoPagerComponent.prototype.setPrevNextNav = /**
* @return {?}
*/
function () {
this.showLeftNav = this.showRightNav = false;
if (this.currentPage > this.noOfPages) {
// current page is out of maximum pages can be shown, it means it is not the first set of page numbers. show left
this.showLeftNav = true;
}
/** @type {?} */
var currentPageIsInBetween = (this.currentPage / this.noOfPages).toString().split('.')
.length === 2;
/** @type {?} */
var currHighestPageShowing = parseInt((this.currentPage / this.noOfPages).toString(), 10) *
this.noOfPages +
(currentPageIsInBetween ? this.noOfPages : 0);
if (currHighestPageShowing < this.totalPageLength) {
this.showRightNav = true;
}
};
/**
* @return {?}
*/
AngularIoPagerComponent.prototype.emitPageClick = /**
* @return {?}
*/
function () {
this.pageClick.emit({ from: this.from, to: this.to });
};
AngularIoPagerComponent.decorators = [
{ type: core.Component, args: [{
selector: 'sr-angular-io-pager',
template: "<div class=\"pager\" [ngClass]=\"{'hidden': totalRecords <= 0}\" [id]=\"'pager' + id\">\n <div class=\"left\">\n Show\n <select [(ngModel)]=\"pageGap\" (change)=\"pageLengthChange()\"\n id=\"pageGap\">\n <option *ngFor=\"let pg of pages\" [value]=\"pg\">{{pg}}</option>\n </select>\n Showing {{from}}-{{to}} of {{totalRecords}}\n </div>\n <div class=\"right\">\n <ul class=\"pageNumbers\" id=\"pageList\">\n <li *ngIf=\"showLeftNav\" (click)=\"pageChange($event)\"\n class=\"cmdLeft\"> {{leftNavString}} </li>\n <li *ngFor=\"let pn of pageNum\" (click)=\"pageChange($event)\"\n class=\"pageElements\">{{pn}}</li>\n <li *ngIf=\"showRightNav\" (click)=\"pageChange($event)\"\n class=\"cmdRight\"> {{rightNavString}} </li>\n </ul>\n </div>\n</div>",
styles: [".pager{font:bold 13px Arial;color:#377bba}.pageNumbers{list-style:none;border:1px solid #dfdfdf;display:inline-block;padding-left:0;margin:0}.pageNumbers li{float:left;padding:8px 10px;background:#fff;border-left:1px solid #dfdfdf;border-collapse:collapse;color:#377bba;cursor:pointer;min-width:15px;text-align:center}.pageNumbers li.selected{background:#377bba;color:#fff}.pageNumbers li:first-of-type{border-left:0}.pageNumbers li:hover{background:#3a4046;color:#fff}div.left{padding:9px 0}select{color:#377bba;font-weight:700;font-size:.9em;padding:2px;border:1px solid #377bba}.left{float:left}.right{float:right}.hidden{display:none}"]
},] },
];
/** @nocollapse */
AngularIoPagerComponent.ctorParameters = function () { return []; };
AngularIoPagerComponent.propDecorators = {
pageGap: [{ type: core.Input }],
id: [{ type: core.Input }],
noOfPages: [{ type: core.Input }],
totalRecords: [{ type: core.Input }],
pageClick: [{ type: core.Output }]
};
return AngularIoPagerComponent;
}());
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
var AngularIoPagerModule = (function () {
function AngularIoPagerModule() {
}
AngularIoPagerModule.decorators = [
{ type: core.NgModule, args: [{
imports: [
forms.FormsModule, platformBrowser.BrowserModule
],
declarations: [AngularIoPagerComponent],
exports: [AngularIoPagerComponent]
},] },
];
return AngularIoPagerModule;
}());
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
exports.AngularIoPagerModule = AngularIoPagerModule;
exports.ɵa = AngularIoPagerComponent;
Object.defineProperty(exports, '__esModule', { value: true });
})));
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"angular-io-pager.umd.js.map","sources":[null,"ng://angular-io-pager/lib/angular-io-pager/pager.component.ts","ng://angular-io-pager/lib/angular-io-pager.module.ts"],"sourcesContent":["/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation. All rights reserved.\r\nLicensed under the Apache License, Version 2.0 (the \"License\"); you may not use\r\nthis file except in compliance with the License. You may obtain a copy of the\r\nLicense at http://www.apache.org/licenses/LICENSE-2.0\r\n\r\nTHIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\r\nKIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED\r\nWARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,\r\nMERCHANTABLITY OR NON-INFRINGEMENT.\r\n\r\nSee the Apache Version 2.0 License for specific language governing permissions\r\nand limitations under the License.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n    extendStatics = Object.setPrototypeOf ||\r\n        ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n        function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\r\n    return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n    extendStatics(d, b);\r\n    function __() { this.constructor = d; }\r\n    d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n    __assign = Object.assign || function __assign(t) {\r\n        for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n            s = arguments[i];\r\n            for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n        }\r\n        return t;\r\n    }\r\n    return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n    var t = {};\r\n    for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n        t[p] = s[p];\r\n    if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n        for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) if (e.indexOf(p[i]) < 0)\r\n            t[p[i]] = s[p[i]];\r\n    return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n    var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n    if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n    else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n    return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n    return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n    if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n    return new (P || (P = Promise))(function (resolve, reject) {\r\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n        function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }\r\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n    });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n    var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n    return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n    function verb(n) { return function (v) { return step([n, v]); }; }\r\n    function step(op) {\r\n        if (f) throw new TypeError(\"Generator is already executing.\");\r\n        while (_) try {\r\n            if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n            if (y = 0, t) op = [op[0] & 2, t.value];\r\n            switch (op[0]) {\r\n                case 0: case 1: t = op; break;\r\n                case 4: _.label++; return { value: op[1], done: false };\r\n                case 5: _.label++; y = op[1]; op = [0]; continue;\r\n                case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n                default:\r\n                    if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n                    if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n                    if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n                    if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n                    if (t[2]) _.ops.pop();\r\n                    _.trys.pop(); continue;\r\n            }\r\n            op = body.call(thisArg, _);\r\n        } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n        if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n    }\r\n}\r\n\r\nexport function __exportStar(m, exports) {\r\n    for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p];\r\n}\r\n\r\nexport function __values(o) {\r\n    var m = typeof Symbol === \"function\" && o[Symbol.iterator], i = 0;\r\n    if (m) return m.call(o);\r\n    return {\r\n        next: function () {\r\n            if (o && i >= o.length) o = void 0;\r\n            return { value: o && o[i++], done: !o };\r\n        }\r\n    };\r\n}\r\n\r\nexport function __read(o, n) {\r\n    var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n    if (!m) return o;\r\n    var i = m.call(o), r, ar = [], e;\r\n    try {\r\n        while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n    }\r\n    catch (error) { e = { error: error }; }\r\n    finally {\r\n        try {\r\n            if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n        }\r\n        finally { if (e) throw e.error; }\r\n    }\r\n    return ar;\r\n}\r\n\r\nexport function __spread() {\r\n    for (var ar = [], i = 0; i < arguments.length; i++)\r\n        ar = ar.concat(__read(arguments[i]));\r\n    return ar;\r\n}\r\n\r\nexport function __await(v) {\r\n    return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n    var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n    return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n    function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n    function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n    function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n    function fulfill(value) { resume(\"next\", value); }\r\n    function reject(value) { resume(\"throw\", value); }\r\n    function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n    var i, p;\r\n    return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n    function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n    var m = o[Symbol.asyncIterator], i;\r\n    return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n    function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n    function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n    if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n    return cooked;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n    if (mod && mod.__esModule) return mod;\r\n    var result = {};\r\n    if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];\r\n    result.default = mod;\r\n    return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n    return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n","import { Component, OnInit, Input, Output, EventEmitter } from '@angular/core';\n\n@Component({\n  selector: 'sr-angular-io-pager',\n  template: `<div class=\"pager\" [ngClass]=\"{'hidden': totalRecords <= 0}\" [id]=\"'pager' + id\">\n  <div class=\"left\">\n      Show\n      <select [(ngModel)]=\"pageGap\" (change)=\"pageLengthChange()\"\n          id=\"pageGap\">\n          <option *ngFor=\"let pg of pages\" [value]=\"pg\">{{pg}}</option>\n      </select>\n      Showing {{from}}-{{to}} of {{totalRecords}}\n  </div>\n  <div class=\"right\">\n      <ul class=\"pageNumbers\" id=\"pageList\">\n          <li *ngIf=\"showLeftNav\" (click)=\"pageChange($event)\"\n              class=\"cmdLeft\"> {{leftNavString}} </li>\n          <li *ngFor=\"let pn of pageNum\" (click)=\"pageChange($event)\"\n              class=\"pageElements\">{{pn}}</li>\n          <li *ngIf=\"showRightNav\" (click)=\"pageChange($event)\"\n              class=\"cmdRight\"> {{rightNavString}} </li>\n      </ul>\n  </div>\n</div>`,\n  styles: [`.pager{font:bold 13px Arial;color:#377bba}.pageNumbers{list-style:none;border:1px solid #dfdfdf;display:inline-block;padding-left:0;margin:0}.pageNumbers li{float:left;padding:8px 10px;background:#fff;border-left:1px solid #dfdfdf;border-collapse:collapse;color:#377bba;cursor:pointer;min-width:15px;text-align:center}.pageNumbers li.selected{background:#377bba;color:#fff}.pageNumbers li:first-of-type{border-left:0}.pageNumbers li:hover{background:#3a4046;color:#fff}div.left{padding:9px 0}select{color:#377bba;font-weight:700;font-size:.9em;padding:2px;border:1px solid #377bba}.left{float:left}.right{float:right}.hidden{display:none}`]\n})\nexport class AngularIoPagerComponent implements OnInit {\n  @Input()\n  pageGap = 10;\n  @Input()\n  id = 1;\n  @Input()\n  noOfPages = 10;\n  @Input()\n  public set totalRecords(value: number) {\n    this._total = value;\n\n    if (value > 0) {\n      this.pagePreparation();\n    }\n  }\n\n  public get totalRecords(): number {\n    return this._total;\n  }\n\n  @Output()\n  pageClick: EventEmitter<object> = new EventEmitter();\n\n  // page view count selectors\n  from = 1;\n  to = 0;\n  pageLength = 20;\n  currentPage = 1;\n  pages: number[] = [];\n  pageNum: number[] = [];\n  showLeftNav = false;\n  showRightNav = false;\n  totalPageLength = 0;\n  leftNavString = '<<';\n  rightNavString = '>>';\n  lastPageMax = 0;\n  lastPageMin = 0;\n  _total = 0;\n\n  constructor() {}\n\n  ngOnInit() {\n    for (let i = 1; i <= this.pageLength; i++) {\n      this.pages.push(i * this.pageGap);\n    }\n\n    this.to = this.pages[0];\n  }\n\n  pagePreparation() {\n    this.reCalculatePageNumbers();\n\n    setTimeout(() => {\n      this.setSelectedPage();\n    }, 0);\n  }\n\n  reCalculatePageNumbers() {\n    const divided = (this.totalRecords / this.pageGap).toString().split('.');\n    const wholePageLen = parseInt(divided[0], 10);\n    let partialPageLen = 0;\n    if (divided.length === 2) {\n      // has one more page with limited records\n      partialPageLen = 1;\n    }\n\n    this.totalPageLength = wholePageLen + partialPageLen;\n    this.pageNum.length = 0;\n    this.populatePages(1);\n  }\n\n  populatePages(start: number) {\n    let until = 1;\n    this.pageNum.length = 0;\n\n    for (\n      let i = start;\n      i <= this.totalPageLength && until <= this.noOfPages;\n      i++\n    ) {\n      this.pageNum.push(i);\n      until++;\n    }\n\n    this.currentPage = this.lastPageMin = Math.min(...this.pageNum);\n    this.lastPageMax = Math.max(...this.pageNum);\n    this.setPrevNextNav();\n  }\n\n  pageLengthChange() {\n    this.reCalculatePageNumbers();\n    this.setSelectedPage();\n  }\n\n  pageChange(e) {\n    if (e.target.classList.contains('cmdLeft')) {\n      this.populatePages(this.lastPageMin - this.noOfPages);\n      this.setSelectedPage();\n    } else if (e.target.classList.contains('cmdRight')) {\n      this.populatePages(++this.lastPageMax);\n      this.setSelectedPage();\n    } else {\n      this.setSelectedPage(e.target);\n    }\n  }\n\n  setSelectedPage(el: HTMLElement = null) {\n    if (el != null) {\n      this.currentPage = parseInt(el.innerText, 10);\n    }\n    this.to = Math.min(this.currentPage * this.pageGap, this.totalRecords);\n    this.from = this.currentPage * this.pageGap - this.pageGap + 1;\n\n    setTimeout(() => {\n      el = <HTMLElement>(\n        (el == null\n          ? document\n              .getElementById('pager' + this.id)\n              .querySelector('.pageElements')\n          : el)\n      );\n\n      let closePageNum = el;\n      while (\n        (closePageNum = closePageNum.parentElement) &&\n        !closePageNum.classList.contains('pageNumbers')\n      ) {}\n\n      Array.from(closePageNum.children).forEach(x =>\n        x.classList.remove('selected')\n      );\n\n      el.classList.add('selected');\n    }, 0);\n\n    this.emitPageClick();\n  }\n\n  setPrevNextNav() {\n    this.showLeftNav = this.showRightNav = false;\n    if (this.currentPage > this.noOfPages) {\n      // current page is out of maximum pages can be shown, it means it is not the first set of page numbers. show left\n      this.showLeftNav = true;\n    }\n\n    // get whether page is not a multiple of PagesToShow\n    const currentPageIsInBetween =\n      (this.currentPage / this.noOfPages).toString().split('.')\n        .length === 2;\n\n    // get highest page number in the current page\n    // formula used = current page divided with maxPagetoShow, if found remainder,\n    // page might have upcoming page links, so finding largest page number in that page.\n    // ex. if the base showing is 40 in the case of 10 as the page length.\n    // now 40 is the highest page showing, if 42 then 50 is the highest page showing.\n\n    const currHighestPageShowing =\n      parseInt((this.currentPage / this.noOfPages).toString(), 10) *\n        this.noOfPages +\n      (currentPageIsInBetween ? this.noOfPages : 0);\n\n    if (currHighestPageShowing < this.totalPageLength) {\n      this.showRightNav = true;\n    }\n  }\n\n  emitPageClick() {\n    this.pageClick.emit({ from: this.from, to: this.to });\n  }\n}\n","import { NgModule } from '@angular/core';\nimport { AngularIoPagerComponent } from './angular-io-pager/pager.component';\nimport { FormsModule } from '@angular/forms';\nimport { BrowserModule } from '@angular/platform-browser';\n\n@NgModule({\n  imports: [\n    FormsModule, BrowserModule\n  ],\n  declarations: [AngularIoPagerComponent],\n  exports: [AngularIoPagerComponent]\n})\nexport class AngularIoPagerModule { }\n"],"names":["EventEmitter","Component","Input","Output","NgModule","FormsModule","BrowserModule"],"mappings":"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"}