pagination.component.js 36 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524
  1. /**
  2. * @fileoverview added by tsickle
  3. * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
  4. */
  5. import { ChangeDetectorRef, Component, ElementRef, EventEmitter, forwardRef, Input, Output } from '@angular/core';
  6. import { NG_VALUE_ACCESSOR } from '@angular/forms';
  7. import { PaginationConfig } from './pagination.config';
  8. /**
  9. * @record
  10. */
  11. export function PageChangedEvent() { }
  12. if (false) {
  13. /** @type {?} */
  14. PageChangedEvent.prototype.itemsPerPage;
  15. /** @type {?} */
  16. PageChangedEvent.prototype.page;
  17. }
  18. /** @type {?} */
  19. export var PAGINATION_CONTROL_VALUE_ACCESSOR = {
  20. provide: NG_VALUE_ACCESSOR,
  21. /* tslint:disable-next-line: no-use-before-declare */
  22. useExisting: forwardRef((/**
  23. * @return {?}
  24. */
  25. function () { return PaginationComponent; })),
  26. multi: true
  27. };
  28. var PaginationComponent = /** @class */ (function () {
  29. function PaginationComponent(elementRef, paginationConfig, changeDetection) {
  30. this.elementRef = elementRef;
  31. this.changeDetection = changeDetection;
  32. /**
  33. * fired when total pages count changes, $event:number equals to total pages count
  34. */
  35. this.numPages = new EventEmitter();
  36. /**
  37. * fired when page was changed, $event:{page, itemsPerPage} equals to object
  38. * with current page index and number of items per page
  39. */
  40. this.pageChanged = new EventEmitter();
  41. this.onChange = Function.prototype;
  42. this.onTouched = Function.prototype;
  43. this.inited = false;
  44. this._page = 1;
  45. this.elementRef = elementRef;
  46. if (!this.config) {
  47. this.configureOptions(paginationConfig.main);
  48. }
  49. }
  50. Object.defineProperty(PaginationComponent.prototype, "itemsPerPage", {
  51. /** maximum number of items per page. If value less than 1 will display all items on one page */
  52. get: /**
  53. * maximum number of items per page. If value less than 1 will display all items on one page
  54. * @return {?}
  55. */
  56. function () {
  57. return this._itemsPerPage;
  58. },
  59. set: /**
  60. * @param {?} v
  61. * @return {?}
  62. */
  63. function (v) {
  64. this._itemsPerPage = v;
  65. this.totalPages = this.calculateTotalPages();
  66. },
  67. enumerable: true,
  68. configurable: true
  69. });
  70. Object.defineProperty(PaginationComponent.prototype, "totalItems", {
  71. /** total number of items in all pages */
  72. get: /**
  73. * total number of items in all pages
  74. * @return {?}
  75. */
  76. function () {
  77. return this._totalItems;
  78. },
  79. set: /**
  80. * @param {?} v
  81. * @return {?}
  82. */
  83. function (v) {
  84. this._totalItems = v;
  85. this.totalPages = this.calculateTotalPages();
  86. },
  87. enumerable: true,
  88. configurable: true
  89. });
  90. Object.defineProperty(PaginationComponent.prototype, "totalPages", {
  91. get: /**
  92. * @return {?}
  93. */
  94. function () {
  95. return this._totalPages;
  96. },
  97. set: /**
  98. * @param {?} v
  99. * @return {?}
  100. */
  101. function (v) {
  102. this._totalPages = v;
  103. this.numPages.emit(v);
  104. if (this.inited) {
  105. this.selectPage(this.page);
  106. }
  107. },
  108. enumerable: true,
  109. configurable: true
  110. });
  111. Object.defineProperty(PaginationComponent.prototype, "page", {
  112. get: /**
  113. * @return {?}
  114. */
  115. function () {
  116. return this._page;
  117. },
  118. set: /**
  119. * @param {?} value
  120. * @return {?}
  121. */
  122. function (value) {
  123. /** @type {?} */
  124. var _previous = this._page;
  125. this._page = value > this.totalPages ? this.totalPages : value || 1;
  126. this.changeDetection.markForCheck();
  127. if (_previous === this._page || typeof _previous === 'undefined') {
  128. return;
  129. }
  130. this.pageChanged.emit({
  131. page: this._page,
  132. itemsPerPage: this.itemsPerPage
  133. });
  134. },
  135. enumerable: true,
  136. configurable: true
  137. });
  138. /**
  139. * @param {?} config
  140. * @return {?}
  141. */
  142. PaginationComponent.prototype.configureOptions = /**
  143. * @param {?} config
  144. * @return {?}
  145. */
  146. function (config) {
  147. this.config = Object.assign({}, config);
  148. };
  149. /**
  150. * @return {?}
  151. */
  152. PaginationComponent.prototype.ngOnInit = /**
  153. * @return {?}
  154. */
  155. function () {
  156. if (typeof window !== 'undefined') {
  157. this.classMap = this.elementRef.nativeElement.getAttribute('class') || '';
  158. }
  159. // watch for maxSize
  160. this.maxSize =
  161. typeof this.maxSize !== 'undefined' ? this.maxSize : this.config.maxSize;
  162. this.rotate =
  163. typeof this.rotate !== 'undefined' ? this.rotate : this.config.rotate;
  164. this.boundaryLinks =
  165. typeof this.boundaryLinks !== 'undefined'
  166. ? this.boundaryLinks
  167. : this.config.boundaryLinks;
  168. this.directionLinks =
  169. typeof this.directionLinks !== 'undefined'
  170. ? this.directionLinks
  171. : this.config.directionLinks;
  172. this.pageBtnClass =
  173. typeof this.pageBtnClass !== 'undefined'
  174. ? this.pageBtnClass
  175. : this.config.pageBtnClass;
  176. // base class
  177. this.itemsPerPage =
  178. typeof this.itemsPerPage !== 'undefined'
  179. ? this.itemsPerPage
  180. : this.config.itemsPerPage;
  181. this.totalPages = this.calculateTotalPages();
  182. // this class
  183. this.pages = this.getPages(this.page, this.totalPages);
  184. this.inited = true;
  185. };
  186. /**
  187. * @param {?} value
  188. * @return {?}
  189. */
  190. PaginationComponent.prototype.writeValue = /**
  191. * @param {?} value
  192. * @return {?}
  193. */
  194. function (value) {
  195. this.page = value;
  196. this.pages = this.getPages(this.page, this.totalPages);
  197. };
  198. /**
  199. * @param {?} key
  200. * @return {?}
  201. */
  202. PaginationComponent.prototype.getText = /**
  203. * @param {?} key
  204. * @return {?}
  205. */
  206. function (key) {
  207. // tslint:disable-next-line:no-any
  208. return ((/** @type {?} */ (this)))[key + "Text"] || ((/** @type {?} */ (this))).config[key + "Text"];
  209. };
  210. /**
  211. * @return {?}
  212. */
  213. PaginationComponent.prototype.noPrevious = /**
  214. * @return {?}
  215. */
  216. function () {
  217. return this.page === 1;
  218. };
  219. /**
  220. * @return {?}
  221. */
  222. PaginationComponent.prototype.noNext = /**
  223. * @return {?}
  224. */
  225. function () {
  226. return this.page === this.totalPages;
  227. };
  228. /**
  229. * @param {?} fn
  230. * @return {?}
  231. */
  232. PaginationComponent.prototype.registerOnChange = /**
  233. * @param {?} fn
  234. * @return {?}
  235. */
  236. function (fn) {
  237. this.onChange = fn;
  238. };
  239. /**
  240. * @param {?} fn
  241. * @return {?}
  242. */
  243. PaginationComponent.prototype.registerOnTouched = /**
  244. * @param {?} fn
  245. * @return {?}
  246. */
  247. function (fn) {
  248. this.onTouched = fn;
  249. };
  250. /**
  251. * @param {?} page
  252. * @param {?=} event
  253. * @return {?}
  254. */
  255. PaginationComponent.prototype.selectPage = /**
  256. * @param {?} page
  257. * @param {?=} event
  258. * @return {?}
  259. */
  260. function (page, event) {
  261. if (event) {
  262. event.preventDefault();
  263. }
  264. if (!this.disabled) {
  265. if (event && event.target) {
  266. // tslint:disable-next-line:no-any
  267. /** @type {?} */
  268. var target = event.target;
  269. target.blur();
  270. }
  271. this.writeValue(page);
  272. this.onChange(this.page);
  273. }
  274. };
  275. // Create page object used in template
  276. // Create page object used in template
  277. /**
  278. * @protected
  279. * @param {?} num
  280. * @param {?} text
  281. * @param {?} active
  282. * @return {?}
  283. */
  284. PaginationComponent.prototype.makePage =
  285. // Create page object used in template
  286. /**
  287. * @protected
  288. * @param {?} num
  289. * @param {?} text
  290. * @param {?} active
  291. * @return {?}
  292. */
  293. function (num, text, active) {
  294. return { text: text, number: num, active: active };
  295. };
  296. /**
  297. * @protected
  298. * @param {?} currentPage
  299. * @param {?} totalPages
  300. * @return {?}
  301. */
  302. PaginationComponent.prototype.getPages = /**
  303. * @protected
  304. * @param {?} currentPage
  305. * @param {?} totalPages
  306. * @return {?}
  307. */
  308. function (currentPage, totalPages) {
  309. /** @type {?} */
  310. var pages = [];
  311. // Default page limits
  312. /** @type {?} */
  313. var startPage = 1;
  314. /** @type {?} */
  315. var endPage = totalPages;
  316. /** @type {?} */
  317. var isMaxSized = typeof this.maxSize !== 'undefined' && this.maxSize < totalPages;
  318. // recompute if maxSize
  319. if (isMaxSized) {
  320. if (this.rotate) {
  321. // Current page is displayed in the middle of the visible ones
  322. startPage = Math.max(currentPage - Math.floor(this.maxSize / 2), 1);
  323. endPage = startPage + this.maxSize - 1;
  324. // Adjust if limit is exceeded
  325. if (endPage > totalPages) {
  326. endPage = totalPages;
  327. startPage = endPage - this.maxSize + 1;
  328. }
  329. }
  330. else {
  331. // Visible pages are paginated with maxSize
  332. startPage =
  333. (Math.ceil(currentPage / this.maxSize) - 1) * this.maxSize + 1;
  334. // Adjust last page if limit is exceeded
  335. endPage = Math.min(startPage + this.maxSize - 1, totalPages);
  336. }
  337. }
  338. // Add page number links
  339. for (var num = startPage; num <= endPage; num++) {
  340. /** @type {?} */
  341. var page = this.makePage(num, num.toString(), num === currentPage);
  342. pages.push(page);
  343. }
  344. // Add links to move between page sets
  345. if (isMaxSized && !this.rotate) {
  346. if (startPage > 1) {
  347. /** @type {?} */
  348. var previousPageSet = this.makePage(startPage - 1, '...', false);
  349. pages.unshift(previousPageSet);
  350. }
  351. if (endPage < totalPages) {
  352. /** @type {?} */
  353. var nextPageSet = this.makePage(endPage + 1, '...', false);
  354. pages.push(nextPageSet);
  355. }
  356. }
  357. return pages;
  358. };
  359. // base class
  360. // base class
  361. /**
  362. * @protected
  363. * @return {?}
  364. */
  365. PaginationComponent.prototype.calculateTotalPages =
  366. // base class
  367. /**
  368. * @protected
  369. * @return {?}
  370. */
  371. function () {
  372. /** @type {?} */
  373. var totalPages = this.itemsPerPage < 1
  374. ? 1
  375. : Math.ceil(this.totalItems / this.itemsPerPage);
  376. return Math.max(totalPages || 0, 1);
  377. };
  378. PaginationComponent.decorators = [
  379. { type: Component, args: [{
  380. selector: 'pagination',
  381. template: "<ul class=\"pagination\" [ngClass]=\"classMap\">\n <li class=\"pagination-first page-item\"\n *ngIf=\"boundaryLinks\"\n [class.disabled]=\"noPrevious()||disabled\">\n <a class=\"page-link\" href (click)=\"selectPage(1, $event)\"\n [innerHTML]=\"getText('first')\"></a>\n </li>\n\n <li class=\"pagination-prev page-item\"\n *ngIf=\"directionLinks\"\n [class.disabled]=\"noPrevious()||disabled\">\n <a class=\"page-link\" href (click)=\"selectPage(page - 1, $event)\"\n [innerHTML]=\"getText('previous')\"></a>\n </li>\n\n <li *ngFor=\"let pg of pages\"\n [class.active]=\"pg.active\"\n [class.disabled]=\"disabled&&!pg.active\"\n class=\"pagination-page page-item\">\n <a class=\"page-link\" href (click)=\"selectPage(pg.number, $event)\"\n [innerHTML]=\"pg.text\"></a>\n </li>\n\n <li class=\"pagination-next page-item\"\n *ngIf=\"directionLinks\"\n [class.disabled]=\"noNext()||disabled\">\n <a class=\"page-link\" href (click)=\"selectPage(page + 1, $event)\"\n [innerHTML]=\"getText('next')\"></a></li>\n\n <li class=\"pagination-last page-item\"\n *ngIf=\"boundaryLinks\"\n [class.disabled]=\"noNext()||disabled\">\n <a class=\"page-link\" href (click)=\"selectPage(totalPages, $event)\"\n [innerHTML]=\"getText('last')\"></a></li>\n</ul>\n",
  382. providers: [PAGINATION_CONTROL_VALUE_ACCESSOR]
  383. }] }
  384. ];
  385. /** @nocollapse */
  386. PaginationComponent.ctorParameters = function () { return [
  387. { type: ElementRef },
  388. { type: PaginationConfig },
  389. { type: ChangeDetectorRef }
  390. ]; };
  391. PaginationComponent.propDecorators = {
  392. align: [{ type: Input }],
  393. maxSize: [{ type: Input }],
  394. boundaryLinks: [{ type: Input }],
  395. directionLinks: [{ type: Input }],
  396. firstText: [{ type: Input }],
  397. previousText: [{ type: Input }],
  398. nextText: [{ type: Input }],
  399. lastText: [{ type: Input }],
  400. rotate: [{ type: Input }],
  401. pageBtnClass: [{ type: Input }],
  402. disabled: [{ type: Input }],
  403. numPages: [{ type: Output }],
  404. pageChanged: [{ type: Output }],
  405. itemsPerPage: [{ type: Input }],
  406. totalItems: [{ type: Input }]
  407. };
  408. return PaginationComponent;
  409. }());
  410. export { PaginationComponent };
  411. if (false) {
  412. /** @type {?} */
  413. PaginationComponent.prototype.config;
  414. /**
  415. * if `true` aligns each link to the sides of pager
  416. * @type {?}
  417. */
  418. PaginationComponent.prototype.align;
  419. /**
  420. * limit number for page links in pager
  421. * @type {?}
  422. */
  423. PaginationComponent.prototype.maxSize;
  424. /**
  425. * if false first and last buttons will be hidden
  426. * @type {?}
  427. */
  428. PaginationComponent.prototype.boundaryLinks;
  429. /**
  430. * if false previous and next buttons will be hidden
  431. * @type {?}
  432. */
  433. PaginationComponent.prototype.directionLinks;
  434. /**
  435. * first button text
  436. * @type {?}
  437. */
  438. PaginationComponent.prototype.firstText;
  439. /**
  440. * previous button text
  441. * @type {?}
  442. */
  443. PaginationComponent.prototype.previousText;
  444. /**
  445. * next button text
  446. * @type {?}
  447. */
  448. PaginationComponent.prototype.nextText;
  449. /**
  450. * last button text
  451. * @type {?}
  452. */
  453. PaginationComponent.prototype.lastText;
  454. /**
  455. * if true current page will in the middle of pages list
  456. * @type {?}
  457. */
  458. PaginationComponent.prototype.rotate;
  459. /**
  460. * add class to <code><li\></code>
  461. * @type {?}
  462. */
  463. PaginationComponent.prototype.pageBtnClass;
  464. /**
  465. * if true pagination component will be disabled
  466. * @type {?}
  467. */
  468. PaginationComponent.prototype.disabled;
  469. /**
  470. * fired when total pages count changes, $event:number equals to total pages count
  471. * @type {?}
  472. */
  473. PaginationComponent.prototype.numPages;
  474. /**
  475. * fired when page was changed, $event:{page, itemsPerPage} equals to object
  476. * with current page index and number of items per page
  477. * @type {?}
  478. */
  479. PaginationComponent.prototype.pageChanged;
  480. /** @type {?} */
  481. PaginationComponent.prototype.onChange;
  482. /** @type {?} */
  483. PaginationComponent.prototype.onTouched;
  484. /** @type {?} */
  485. PaginationComponent.prototype.classMap;
  486. /** @type {?} */
  487. PaginationComponent.prototype.pages;
  488. /**
  489. * @type {?}
  490. * @protected
  491. */
  492. PaginationComponent.prototype._itemsPerPage;
  493. /**
  494. * @type {?}
  495. * @protected
  496. */
  497. PaginationComponent.prototype._totalItems;
  498. /**
  499. * @type {?}
  500. * @protected
  501. */
  502. PaginationComponent.prototype._totalPages;
  503. /**
  504. * @type {?}
  505. * @protected
  506. */
  507. PaginationComponent.prototype.inited;
  508. /**
  509. * @type {?}
  510. * @protected
  511. */
  512. PaginationComponent.prototype._page;
  513. /**
  514. * @type {?}
  515. * @private
  516. */
  517. PaginationComponent.prototype.elementRef;
  518. /**
  519. * @type {?}
  520. * @private
  521. */
  522. PaginationComponent.prototype.changeDetection;
  523. }
  524. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pagination.component.js","sourceRoot":"ng://ngx-bootstrap/pagination/","sources":["pagination.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  Input,\n  OnInit,\n  Output,\n  Provider\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { PaginationConfig } from './pagination.config';\n\nimport { ConfigModel, PagesModel } from './models';\n\nexport interface PageChangedEvent {\n  itemsPerPage: number;\n  page: number;\n}\n\nexport const PAGINATION_CONTROL_VALUE_ACCESSOR: Provider = {\n  provide: NG_VALUE_ACCESSOR,\n  /* tslint:disable-next-line: no-use-before-declare */\n  useExisting: forwardRef(() => PaginationComponent),\n  multi: true\n};\n\n@Component({\n  selector: 'pagination',\n  templateUrl: './pagination.component.html',\n  providers: [PAGINATION_CONTROL_VALUE_ACCESSOR]\n})\nexport class PaginationComponent implements ControlValueAccessor, OnInit {\n  config: ConfigModel;\n  /** if `true` aligns each link to the sides of pager */\n  @Input() align: boolean;\n  /** limit number for page links in pager */\n  @Input() maxSize: number;\n  /** if false first and last buttons will be hidden */\n  @Input() boundaryLinks: boolean;\n  /** if false previous and next buttons will be hidden */\n  @Input() directionLinks: boolean;\n  // labels\n  /** first button text */\n  @Input() firstText: string;\n  /** previous button text */\n  @Input() previousText: string;\n  /** next button text */\n  @Input() nextText: string;\n  /** last button text */\n  @Input() lastText: string;\n  /** if true current page will in the middle of pages list */\n  @Input() rotate: boolean;\n  // css\n  /** add class to <code><li\\></code> */\n  @Input() pageBtnClass: string;\n\n  /** if true pagination component will be disabled */\n  @Input() disabled: boolean;\n\n  /** fired when total pages count changes, $event:number equals to total pages count */\n  @Output() numPages: EventEmitter<number> = new EventEmitter<number>();\n  /** fired when page was changed, $event:{page, itemsPerPage} equals to object\n   * with current page index and number of items per page\n   */\n  @Output()\n  pageChanged = new EventEmitter<PageChangedEvent>();\n\n  /** maximum number of items per page. If value less than 1 will display all items on one page */\n  @Input()\n  get itemsPerPage(): number {\n    return this._itemsPerPage;\n  }\n\n  set itemsPerPage(v: number) {\n    this._itemsPerPage = v;\n    this.totalPages = this.calculateTotalPages();\n  }\n\n  /** total number of items in all pages */\n  @Input()\n  get totalItems(): number {\n    return this._totalItems;\n  }\n\n  set totalItems(v: number) {\n    this._totalItems = v;\n    this.totalPages = this.calculateTotalPages();\n  }\n\n  get totalPages(): number {\n    return this._totalPages;\n  }\n\n  set totalPages(v: number) {\n    this._totalPages = v;\n    this.numPages.emit(v);\n    if (this.inited) {\n      this.selectPage(this.page);\n    }\n  }\n\n  set page(value: number) {\n    const _previous = this._page;\n    this._page = value > this.totalPages ? this.totalPages : value || 1;\n    this.changeDetection.markForCheck();\n\n    if (_previous === this._page || typeof _previous === 'undefined') {\n      return;\n    }\n\n    this.pageChanged.emit({\n      page: this._page,\n      itemsPerPage: this.itemsPerPage\n    });\n  }\n\n  get page(): number {\n    return this._page;\n  }\n\n  onChange = Function.prototype;\n  onTouched = Function.prototype;\n\n  classMap: string;\n  pages: PagesModel[];\n\n  protected _itemsPerPage: number;\n  protected _totalItems: number;\n  protected _totalPages: number;\n  protected inited = false;\n  protected _page = 1;\n\n  constructor(\n    private elementRef: ElementRef,\n    paginationConfig: PaginationConfig,\n    private changeDetection: ChangeDetectorRef\n  ) {\n    this.elementRef = elementRef;\n    if (!this.config) {\n      this.configureOptions(paginationConfig.main);\n    }\n  }\n\n  configureOptions(config: ConfigModel): void {\n    this.config = Object.assign({}, config);\n  }\n\n  ngOnInit(): void {\n    if (typeof window !== 'undefined') {\n      this.classMap = this.elementRef.nativeElement.getAttribute('class') || '';\n    }\n    // watch for maxSize\n    this.maxSize =\n      typeof this.maxSize !== 'undefined' ? this.maxSize : this.config.maxSize;\n    this.rotate =\n      typeof this.rotate !== 'undefined' ? this.rotate : this.config.rotate;\n    this.boundaryLinks =\n      typeof this.boundaryLinks !== 'undefined'\n        ? this.boundaryLinks\n        : this.config.boundaryLinks;\n    this.directionLinks =\n      typeof this.directionLinks !== 'undefined'\n        ? this.directionLinks\n        : this.config.directionLinks;\n    this.pageBtnClass =\n      typeof this.pageBtnClass !== 'undefined'\n        ? this.pageBtnClass\n        : this.config.pageBtnClass;\n\n    // base class\n    this.itemsPerPage =\n      typeof this.itemsPerPage !== 'undefined'\n        ? this.itemsPerPage\n        : this.config.itemsPerPage;\n    this.totalPages = this.calculateTotalPages();\n    // this class\n    this.pages = this.getPages(this.page, this.totalPages);\n    this.inited = true;\n  }\n\n  writeValue(value: number): void {\n    this.page = value;\n    this.pages = this.getPages(this.page, this.totalPages);\n  }\n\n  getText(key: string): string {\n    // tslint:disable-next-line:no-any\n    return (this as any)[`${key}Text`] || (this as any).config[`${key}Text`];\n  }\n\n  noPrevious(): boolean {\n    return this.page === 1;\n  }\n\n  noNext(): boolean {\n    return this.page === this.totalPages;\n  }\n\n  registerOnChange(fn: () => {}): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => {}): void {\n    this.onTouched = fn;\n  }\n\n  selectPage(page: number, event?: Event): void {\n    if (event) {\n      event.preventDefault();\n    }\n\n    if (!this.disabled) {\n      if (event && event.target) {\n        // tslint:disable-next-line:no-any\n        const target: any = event.target;\n        target.blur();\n      }\n      this.writeValue(page);\n      this.onChange(this.page);\n    }\n  }\n\n  // Create page object used in template\n  protected makePage(\n    num: number,\n    text: string,\n    active: boolean\n  ): { number: number; text: string; active: boolean } {\n    return { text, number: num, active };\n  }\n\n  protected getPages(currentPage: number, totalPages: number): PagesModel[] {\n    const pages: PagesModel[] = [];\n\n    // Default page limits\n    let startPage = 1;\n    let endPage = totalPages;\n    const isMaxSized =\n      typeof this.maxSize !== 'undefined' && this.maxSize < totalPages;\n\n    // recompute if maxSize\n    if (isMaxSized) {\n      if (this.rotate) {\n        // Current page is displayed in the middle of the visible ones\n        startPage = Math.max(currentPage - Math.floor(this.maxSize / 2), 1);\n        endPage = startPage + this.maxSize - 1;\n\n        // Adjust if limit is exceeded\n        if (endPage > totalPages) {\n          endPage = totalPages;\n          startPage = endPage - this.maxSize + 1;\n        }\n      } else {\n        // Visible pages are paginated with maxSize\n        startPage =\n          (Math.ceil(currentPage / this.maxSize) - 1) * this.maxSize + 1;\n\n        // Adjust last page if limit is exceeded\n        endPage = Math.min(startPage + this.maxSize - 1, totalPages);\n      }\n    }\n\n    // Add page number links\n    for (let num = startPage; num <= endPage; num++) {\n      const page = this.makePage(num, num.toString(), num === currentPage);\n      pages.push(page);\n    }\n\n    // Add links to move between page sets\n    if (isMaxSized && !this.rotate) {\n      if (startPage > 1) {\n        const previousPageSet = this.makePage(startPage - 1, '...', false);\n        pages.unshift(previousPageSet);\n      }\n\n      if (endPage < totalPages) {\n        const nextPageSet = this.makePage(endPage + 1, '...', false);\n        pages.push(nextPageSet);\n      }\n    }\n\n    return pages;\n  }\n\n  // base class\n  protected calculateTotalPages(): number {\n    const totalPages =\n      this.itemsPerPage < 1\n        ? 1\n        : Math.ceil(this.totalItems / this.itemsPerPage);\n\n    return Math.max(totalPages || 0, 1);\n  }\n}\n"]}