pager.component.js 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210
  1. /**
  2. * @fileoverview added by tsickle
  3. * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
  4. */
  5. import { Component, Input, Output, EventEmitter, ChangeDetectionStrategy } from '@angular/core';
  6. export class DataTablePagerComponent {
  7. constructor() {
  8. this.change = new EventEmitter();
  9. this._count = 0;
  10. this._page = 1;
  11. this._size = 0;
  12. }
  13. /**
  14. * @param {?} val
  15. * @return {?}
  16. */
  17. set size(val) {
  18. this._size = val;
  19. this.pages = this.calcPages();
  20. }
  21. /**
  22. * @return {?}
  23. */
  24. get size() {
  25. return this._size;
  26. }
  27. /**
  28. * @param {?} val
  29. * @return {?}
  30. */
  31. set count(val) {
  32. this._count = val;
  33. this.pages = this.calcPages();
  34. }
  35. /**
  36. * @return {?}
  37. */
  38. get count() {
  39. return this._count;
  40. }
  41. /**
  42. * @param {?} val
  43. * @return {?}
  44. */
  45. set page(val) {
  46. this._page = val;
  47. this.pages = this.calcPages();
  48. }
  49. /**
  50. * @return {?}
  51. */
  52. get page() {
  53. return this._page;
  54. }
  55. /**
  56. * @return {?}
  57. */
  58. get totalPages() {
  59. /** @type {?} */
  60. const count = this.size < 1 ? 1 : Math.ceil(this.count / this.size);
  61. return Math.max(count || 0, 1);
  62. }
  63. /**
  64. * @return {?}
  65. */
  66. canPrevious() {
  67. return this.page > 1;
  68. }
  69. /**
  70. * @return {?}
  71. */
  72. canNext() {
  73. return this.page < this.totalPages;
  74. }
  75. /**
  76. * @return {?}
  77. */
  78. prevPage() {
  79. this.selectPage(this.page - 1);
  80. }
  81. /**
  82. * @return {?}
  83. */
  84. nextPage() {
  85. this.selectPage(this.page + 1);
  86. }
  87. /**
  88. * @param {?} page
  89. * @return {?}
  90. */
  91. selectPage(page) {
  92. if (page > 0 && page <= this.totalPages && page !== this.page) {
  93. this.page = page;
  94. this.change.emit({
  95. page
  96. });
  97. }
  98. }
  99. /**
  100. * @param {?=} page
  101. * @return {?}
  102. */
  103. calcPages(page) {
  104. /** @type {?} */
  105. const pages = [];
  106. /** @type {?} */
  107. let startPage = 1;
  108. /** @type {?} */
  109. let endPage = this.totalPages;
  110. /** @type {?} */
  111. const maxSize = 5;
  112. /** @type {?} */
  113. const isMaxSized = maxSize < this.totalPages;
  114. page = page || this.page;
  115. if (isMaxSized) {
  116. startPage = page - Math.floor(maxSize / 2);
  117. endPage = page + Math.floor(maxSize / 2);
  118. if (startPage < 1) {
  119. startPage = 1;
  120. endPage = Math.min(startPage + maxSize - 1, this.totalPages);
  121. }
  122. else if (endPage > this.totalPages) {
  123. startPage = Math.max(this.totalPages - maxSize + 1, 1);
  124. endPage = this.totalPages;
  125. }
  126. }
  127. for (let num = startPage; num <= endPage; num++) {
  128. pages.push({
  129. number: num,
  130. text: (/** @type {?} */ (((/** @type {?} */ (num)))))
  131. });
  132. }
  133. return pages;
  134. }
  135. }
  136. DataTablePagerComponent.decorators = [
  137. { type: Component, args: [{
  138. selector: 'datatable-pager',
  139. template: `
  140. <ul class="pager">
  141. <li [class.disabled]="!canPrevious()">
  142. <a role="button" aria-label="go to first page" href="javascript:void(0)" (click)="selectPage(1)">
  143. <i class="{{ pagerPreviousIcon }}"></i>
  144. </a>
  145. </li>
  146. <li [class.disabled]="!canPrevious()">
  147. <a role="button" aria-label="go to previous page" href="javascript:void(0)" (click)="prevPage()">
  148. <i class="{{ pagerLeftArrowIcon }}"></i>
  149. </a>
  150. </li>
  151. <li
  152. role="button"
  153. [attr.aria-label]="'page ' + pg.number"
  154. class="pages"
  155. *ngFor="let pg of pages"
  156. [class.active]="pg.number === page"
  157. >
  158. <a href="javascript:void(0)" (click)="selectPage(pg.number)">
  159. {{ pg.text }}
  160. </a>
  161. </li>
  162. <li [class.disabled]="!canNext()">
  163. <a role="button" aria-label="go to next page" href="javascript:void(0)" (click)="nextPage()">
  164. <i class="{{ pagerRightArrowIcon }}"></i>
  165. </a>
  166. </li>
  167. <li [class.disabled]="!canNext()">
  168. <a role="button" aria-label="go to last page" href="javascript:void(0)" (click)="selectPage(totalPages)">
  169. <i class="{{ pagerNextIcon }}"></i>
  170. </a>
  171. </li>
  172. </ul>
  173. `,
  174. host: {
  175. class: 'datatable-pager'
  176. },
  177. changeDetection: ChangeDetectionStrategy.OnPush
  178. }] }
  179. ];
  180. DataTablePagerComponent.propDecorators = {
  181. pagerLeftArrowIcon: [{ type: Input }],
  182. pagerRightArrowIcon: [{ type: Input }],
  183. pagerPreviousIcon: [{ type: Input }],
  184. pagerNextIcon: [{ type: Input }],
  185. size: [{ type: Input }],
  186. count: [{ type: Input }],
  187. page: [{ type: Input }],
  188. change: [{ type: Output }]
  189. };
  190. if (false) {
  191. /** @type {?} */
  192. DataTablePagerComponent.prototype.pagerLeftArrowIcon;
  193. /** @type {?} */
  194. DataTablePagerComponent.prototype.pagerRightArrowIcon;
  195. /** @type {?} */
  196. DataTablePagerComponent.prototype.pagerPreviousIcon;
  197. /** @type {?} */
  198. DataTablePagerComponent.prototype.pagerNextIcon;
  199. /** @type {?} */
  200. DataTablePagerComponent.prototype.change;
  201. /** @type {?} */
  202. DataTablePagerComponent.prototype._count;
  203. /** @type {?} */
  204. DataTablePagerComponent.prototype._page;
  205. /** @type {?} */
  206. DataTablePagerComponent.prototype._size;
  207. /** @type {?} */
  208. DataTablePagerComponent.prototype.pages;
  209. }
  210. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pager.component.js","sourceRoot":"ng://@swimlane/ngx-datatable/","sources":["lib/components/footer/pager.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, ChangeDetectionStrategy } from '@angular/core';\n\n@Component({\n  selector: 'datatable-pager',\n  template: `\n    <ul class=\"pager\">\n      <li [class.disabled]=\"!canPrevious()\">\n        <a role=\"button\" aria-label=\"go to first page\" href=\"javascript:void(0)\" (click)=\"selectPage(1)\">\n          <i class=\"{{ pagerPreviousIcon }}\"></i>\n        </a>\n      </li>\n      <li [class.disabled]=\"!canPrevious()\">\n        <a role=\"button\" aria-label=\"go to previous page\" href=\"javascript:void(0)\" (click)=\"prevPage()\">\n          <i class=\"{{ pagerLeftArrowIcon }}\"></i>\n        </a>\n      </li>\n      <li\n        role=\"button\"\n        [attr.aria-label]=\"'page ' + pg.number\"\n        class=\"pages\"\n        *ngFor=\"let pg of pages\"\n        [class.active]=\"pg.number === page\"\n      >\n        <a href=\"javascript:void(0)\" (click)=\"selectPage(pg.number)\">\n          {{ pg.text }}\n        </a>\n      </li>\n      <li [class.disabled]=\"!canNext()\">\n        <a role=\"button\" aria-label=\"go to next page\" href=\"javascript:void(0)\" (click)=\"nextPage()\">\n          <i class=\"{{ pagerRightArrowIcon }}\"></i>\n        </a>\n      </li>\n      <li [class.disabled]=\"!canNext()\">\n        <a role=\"button\" aria-label=\"go to last page\" href=\"javascript:void(0)\" (click)=\"selectPage(totalPages)\">\n          <i class=\"{{ pagerNextIcon }}\"></i>\n        </a>\n      </li>\n    </ul>\n  `,\n  host: {\n    class: 'datatable-pager'\n  },\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DataTablePagerComponent {\n  @Input() pagerLeftArrowIcon: string;\n  @Input() pagerRightArrowIcon: string;\n  @Input() pagerPreviousIcon: string;\n  @Input() pagerNextIcon: string;\n\n  @Input()\n  set size(val: number) {\n    this._size = val;\n    this.pages = this.calcPages();\n  }\n\n  get size(): number {\n    return this._size;\n  }\n\n  @Input()\n  set count(val: number) {\n    this._count = val;\n    this.pages = this.calcPages();\n  }\n\n  get count(): number {\n    return this._count;\n  }\n\n  @Input()\n  set page(val: number) {\n    this._page = val;\n    this.pages = this.calcPages();\n  }\n\n  get page(): number {\n    return this._page;\n  }\n\n  get totalPages(): number {\n    const count = this.size < 1 ? 1 : Math.ceil(this.count / this.size);\n    return Math.max(count || 0, 1);\n  }\n\n  @Output() change: EventEmitter<any> = new EventEmitter();\n\n  _count: number = 0;\n  _page: number = 1;\n  _size: number = 0;\n  pages: any;\n\n  canPrevious(): boolean {\n    return this.page > 1;\n  }\n\n  canNext(): boolean {\n    return this.page < this.totalPages;\n  }\n\n  prevPage(): void {\n    this.selectPage(this.page - 1);\n  }\n\n  nextPage(): void {\n    this.selectPage(this.page + 1);\n  }\n\n  selectPage(page: number): void {\n    if (page > 0 && page <= this.totalPages && page !== this.page) {\n      this.page = page;\n\n      this.change.emit({\n        page\n      });\n    }\n  }\n\n  calcPages(page?: number): any[] {\n    const pages = [];\n    let startPage = 1;\n    let endPage = this.totalPages;\n    const maxSize = 5;\n    const isMaxSized = maxSize < this.totalPages;\n\n    page = page || this.page;\n\n    if (isMaxSized) {\n      startPage = page - Math.floor(maxSize / 2);\n      endPage = page + Math.floor(maxSize / 2);\n\n      if (startPage < 1) {\n        startPage = 1;\n        endPage = Math.min(startPage + maxSize - 1, this.totalPages);\n      } else if (endPage > this.totalPages) {\n        startPage = Math.max(this.totalPages - maxSize + 1, 1);\n        endPage = this.totalPages;\n      }\n    }\n\n    for (let num = startPage; num <= endPage; num++) {\n      pages.push({\n        number: num,\n        text: <string>(<any>num)\n      });\n    }\n\n    return pages;\n  }\n}\n"]}