pager.component.js 32 KB

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