pager.component.js 35 KB

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