UNPKG

@hxui/angular

Version:

This README includes the steps that are necessary to import the HxUi-angular into a project or to contribute with development.

410 lines (409 loc) 33.4 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ import { Component, ElementRef, Renderer2, Input, Output, EventEmitter, forwardRef } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import { PaginationConfig } from './pagination.config'; export const /** @type {?} */ PAGER_CONTROL_VALUE_ACCESSOR = { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => PagerComponent), multi: true }; const /** @type {?} */ PAGER_TEMPLATE = ` <ul class="hx-flex hx-flex-justify-between"> <li [class.is-disabled]="noPrevious()" [class.is-previous]="align" class="{{ pageBtnClass }}"> <a href (click)="selectPage(page - 1, $event)">{{getText('previous')}}</a> </li> <li [class.is-disabled]="noNext()" [class.is-next]="align" class="{{ pageBtnClass }}"> <a href (click)="selectPage(page + 1, $event)">{{getText('next')}}</a> </li> </ul> `; export class PagerComponent { /** * @param {?} renderer * @param {?} elementRef * @param {?} paginationConfig */ constructor(renderer, elementRef, paginationConfig) { /** * fired when total pages count changes, $event:number equals to total pages count */ this.numPages = new EventEmitter(); /** * fired when page was changed, $event:{page, itemsPerPage} equals to object with current page index and number of items per page */ this.pageChanged = new EventEmitter(); this.onChange = Function.prototype; this.onTouched = Function.prototype; this.inited = false; this._page = 1; this.renderer = renderer; this.elementRef = elementRef; if (!this.config) { this.configureOptions(Object.assign({}, paginationConfig.main, paginationConfig.pager)); } } /** * maximum number of items per page. If value less than 1 will display all items on one page * @return {?} */ get itemsPerPage() { return this._itemsPerPage; } /** * @param {?} v * @return {?} */ set itemsPerPage(v) { this._itemsPerPage = v; this.totalPages = this.calculateTotalPages(); } /** * total number of items in all pages * @return {?} */ get totalItems() { return this._totalItems; } /** * @param {?} v * @return {?} */ set totalItems(v) { this._totalItems = v; this.totalPages = this.calculateTotalPages(); } /** * @return {?} */ get totalPages() { return this._totalPages; } /** * @param {?} v * @return {?} */ set totalPages(v) { this._totalPages = v; this.numPages.emit(v); if (this.inited) { this.selectPage(this.page); } } /** * @param {?} value * @return {?} */ set page(value) { const /** @type {?} */ _previous = this._page; this._page = (value > this.totalPages) ? this.totalPages : (value || 1); if (_previous === this._page || typeof _previous === 'undefined') { return; } this.pageChanged.emit({ page: this._page, itemsPerPage: this.itemsPerPage }); } /** * @return {?} */ get page() { return this._page; } /** * @param {?} config * @return {?} */ configureOptions(config) { this.config = Object.assign({}, config); } /** * @return {?} */ ngOnInit() { this.classMap = this.elementRef.nativeElement.getAttribute('class') || ''; // watch for maxSize this.maxSize = typeof this.maxSize !== 'undefined' ? this.maxSize : this.config.maxSize; this.rotate = typeof this.rotate !== 'undefined' ? this.rotate : this.config.rotate; this.boundaryLinks = typeof this.boundaryLinks !== 'undefined' ? this.boundaryLinks : this.config.boundaryLinks; this.directionLinks = typeof this.directionLinks !== 'undefined' ? this.directionLinks : this.config.directionLinks; this.pageBtnClass = typeof this.pageBtnClass !== 'undefined' ? this.pageBtnClass : this.config.pageBtnClass; // base class this.itemsPerPage = typeof this.itemsPerPage !== 'undefined' ? this.itemsPerPage : this.config.itemsPerPage; this.totalPages = this.calculateTotalPages(); // this class this.pages = this.getPages(this.page, this.totalPages); this.inited = true; } /** * @param {?} value * @return {?} */ writeValue(value) { this.page = value; this.pages = this.getPages(this.page, this.totalPages); } /** * @param {?} key * @return {?} */ getText(key) { return (/** @type {?} */ (this))[key + 'Text'] || this.config[key + 'Text']; } /** * @return {?} */ noPrevious() { return this.page === 1; } /** * @return {?} */ noNext() { return this.page === this.totalPages; } /** * @param {?} fn * @return {?} */ registerOnChange(fn) { this.onChange = fn; } /** * @param {?} fn * @return {?} */ registerOnTouched(fn) { this.onTouched = fn; } /** * @param {?} page * @param {?=} event * @return {?} */ selectPage(page, event) { if (event) { event.preventDefault(); } if (!this.disabled) { if (event && event.target) { const /** @type {?} */ target = event.target; target.blur(); } this.writeValue(page); this.onChange(this.page); } } /** * @param {?} num * @param {?} text * @param {?} active * @return {?} */ makePage(num, text, active) { return { text, number: num, active }; } /** * @param {?} currentPage * @param {?} totalPages * @return {?} */ getPages(currentPage, totalPages) { const /** @type {?} */ pages = []; // Default page limits let /** @type {?} */ startPage = 1; let /** @type {?} */ endPage = totalPages; const /** @type {?} */ isMaxSized = typeof this.maxSize !== 'undefined' && this.maxSize < totalPages; // recompute if maxSize if (isMaxSized) { if (this.rotate) { // Current page is displayed in the middle of the visible ones startPage = Math.max(currentPage - Math.floor(this.maxSize / 2), 1); endPage = startPage + this.maxSize - 1; // Adjust if limit is exceeded if (endPage > totalPages) { endPage = totalPages; startPage = endPage - this.maxSize + 1; } } else { // Visible pages are paginated with maxSize startPage = ((Math.ceil(currentPage / this.maxSize) - 1) * this.maxSize) + 1; // Adjust last page if limit is exceeded endPage = Math.min(startPage + this.maxSize - 1, totalPages); } } // Add page number links for (let /** @type {?} */ num = startPage; num <= endPage; num++) { const /** @type {?} */ page = this.makePage(num, num.toString(), num === currentPage); pages.push(page); } // Add links to move between page sets if (isMaxSized && !this.rotate) { if (startPage > 1) { const /** @type {?} */ previousPageSet = this.makePage(startPage - 1, '...', false); pages.unshift(previousPageSet); } if (endPage < totalPages) { const /** @type {?} */ nextPageSet = this.makePage(endPage + 1, '...', false); pages.push(nextPageSet); } } return pages; } /** * @return {?} */ calculateTotalPages() { const /** @type {?} */ totalPages = this.itemsPerPage < 1 ? 1 : Math.ceil(this.totalItems / this.itemsPerPage); return Math.max(totalPages || 0, 1); } } PagerComponent.decorators = [ { type: Component, args: [{ selector: 'hx-pager', template: PAGER_TEMPLATE, providers: [PAGER_CONTROL_VALUE_ACCESSOR] },] }, ]; /** @nocollapse */ PagerComponent.ctorParameters = () => [ { type: Renderer2, }, { type: ElementRef, }, { type: PaginationConfig, }, ]; PagerComponent.propDecorators = { "align": [{ type: Input },], "maxSize": [{ type: Input },], "boundaryLinks": [{ type: Input },], "directionLinks": [{ type: Input },], "firstText": [{ type: Input },], "previousText": [{ type: Input },], "nextText": [{ type: Input },], "lastText": [{ type: Input },], "rotate": [{ type: Input },], "pageBtnClass": [{ type: Input },], "disabled": [{ type: Input },], "numPages": [{ type: Output },], "pageChanged": [{ type: Output },], "itemsPerPage": [{ type: Input },], "totalItems": [{ type: Input },], }; function PagerComponent_tsickle_Closure_declarations() { /** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */ PagerComponent.decorators; /** * @nocollapse * @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>} */ PagerComponent.ctorParameters; /** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */ PagerComponent.propDecorators; /** @type {?} */ PagerComponent.prototype.config; /** * if `true` aligns each link to the sides of pager * @type {?} */ PagerComponent.prototype.align; /** * limit number for page links in pager * @type {?} */ PagerComponent.prototype.maxSize; /** * if false first and last buttons will be hidden * @type {?} */ PagerComponent.prototype.boundaryLinks; /** * if false previous and next buttons will be hidden * @type {?} */ PagerComponent.prototype.directionLinks; /** * first button text * @type {?} */ PagerComponent.prototype.firstText; /** * previous button text * @type {?} */ PagerComponent.prototype.previousText; /** * next button text * @type {?} */ PagerComponent.prototype.nextText; /** * last button text * @type {?} */ PagerComponent.prototype.lastText; /** * if true current page will in the middle of pages list * @type {?} */ PagerComponent.prototype.rotate; /** * add class to <li> * @type {?} */ PagerComponent.prototype.pageBtnClass; /** * if true pagination component will be disabled * @type {?} */ PagerComponent.prototype.disabled; /** * fired when total pages count changes, $event:number equals to total pages count * @type {?} */ PagerComponent.prototype.numPages; /** * fired when page was changed, $event:{page, itemsPerPage} equals to object with current page index and number of items per page * @type {?} */ PagerComponent.prototype.pageChanged; /** @type {?} */ PagerComponent.prototype.onChange; /** @type {?} */ PagerComponent.prototype.onTouched; /** @type {?} */ PagerComponent.prototype.renderer; /** @type {?} */ PagerComponent.prototype.elementRef; /** @type {?} */ PagerComponent.prototype.classMap; /** @type {?} */ PagerComponent.prototype.pages; /** @type {?} */ PagerComponent.prototype._itemsPerPage; /** @type {?} */ PagerComponent.prototype._totalItems; /** @type {?} */ PagerComponent.prototype._totalPages; /** @type {?} */ PagerComponent.prototype.inited; /** @type {?} */ PagerComponent.prototype._page; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pager.component.js","sourceRoot":"ng://@hxui/angular/","sources":["lib/pagination/pager.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, OnInit, Renderer2, Input, Output, EventEmitter, forwardRef } from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { PageChangedEvent } from './pagination.component';\r\nimport { PaginationConfig } from './pagination.config';\r\n\r\nexport const PAGER_CONTROL_VALUE_ACCESSOR: any = {\r\n  provide: NG_VALUE_ACCESSOR,\r\n  useExisting: forwardRef(() => PagerComponent),\r\n  multi: true\r\n};\r\n\r\nconst PAGER_TEMPLATE = `\r\n    <ul class=\"hx-flex hx-flex-justify-between\">\r\n      <li [class.is-disabled]=\"noPrevious()\" [class.is-previous]=\"align\" class=\"{{ pageBtnClass }}\">\r\n        <a href (click)=\"selectPage(page - 1, $event)\">{{getText('previous')}}</a>\r\n      </li>\r\n      <li [class.is-disabled]=\"noNext()\" [class.is-next]=\"align\" class=\"{{ pageBtnClass }}\">\r\n        <a href (click)=\"selectPage(page + 1, $event)\">{{getText('next')}}</a>\r\n      </li>\r\n  </ul>\r\n`;\r\n\r\n@Component({\r\n  selector: 'hx-pager',\r\n  template: PAGER_TEMPLATE,\r\n  providers: [PAGER_CONTROL_VALUE_ACCESSOR]\r\n})\r\nexport class PagerComponent implements ControlValueAccessor, OnInit {\r\n  public config: any;\r\n  /** if `true` aligns each link to the sides of pager */\r\n  @Input() public align: boolean;\r\n  /** limit number for page links in pager */\r\n  @Input() public maxSize: number;\r\n  /** if false first and last buttons will be hidden */\r\n  @Input() public boundaryLinks: boolean;\r\n  /** if false previous and next buttons will be hidden */\r\n  @Input() public directionLinks: boolean;\r\n  // labels\r\n  /** first button text */\r\n  @Input() public firstText: string;\r\n  /** previous button text */\r\n  @Input() public previousText: string;\r\n  /** next button text */\r\n  @Input() public nextText: string;\r\n  /** last button text */\r\n  @Input() public lastText: string;\r\n  /** if true current page will in the middle of pages list */\r\n  @Input() public rotate: boolean;\r\n  // css\r\n  /** add class to <li> */\r\n  @Input() public pageBtnClass: string;\r\n\r\n  /** if true pagination component will be disabled */\r\n  @Input() public disabled: boolean;\r\n\r\n  /** fired when total pages count changes, $event:number equals to total pages count */\r\n  @Output() public numPages: EventEmitter<number> = new EventEmitter<number>();\r\n  /** fired when page was changed, $event:{page, itemsPerPage} equals to object with current page index and number of items per page */\r\n  @Output() public pageChanged: EventEmitter<PageChangedEvent> = new EventEmitter<PageChangedEvent>();\r\n\r\n  /** maximum number of items per page. If value less than 1 will display all items on one page */\r\n  @Input()\r\n  public get itemsPerPage(): number {\r\n    return this._itemsPerPage;\r\n  }\r\n\r\n  public set itemsPerPage(v: number) {\r\n    this._itemsPerPage = v;\r\n    this.totalPages = this.calculateTotalPages();\r\n  }\r\n\r\n  /** total number of items in all pages */\r\n  @Input()\r\n  public get totalItems(): number {\r\n    return this._totalItems;\r\n  }\r\n\r\n  public set totalItems(v: number) {\r\n    this._totalItems = v;\r\n    this.totalPages = this.calculateTotalPages();\r\n  }\r\n\r\n  public get totalPages(): number {\r\n    return this._totalPages;\r\n  }\r\n\r\n  public set totalPages(v: number) {\r\n    this._totalPages = v;\r\n    this.numPages.emit(v);\r\n    if (this.inited) {\r\n      this.selectPage(this.page);\r\n    }\r\n  }\r\n\r\n  public set page(value: number) {\r\n    const _previous = this._page;\r\n    this._page = (value > this.totalPages) ? this.totalPages : (value || 1);\r\n\r\n    if (_previous === this._page || typeof _previous === 'undefined') {\r\n      return;\r\n    }\r\n\r\n    this.pageChanged.emit({\r\n      page: this._page,\r\n      itemsPerPage: this.itemsPerPage\r\n    });\r\n  }\r\n\r\n  public get page(): number {\r\n    return this._page;\r\n  }\r\n\r\n  public onChange: any = Function.prototype;\r\n  public onTouched: any = Function.prototype;\r\n\r\n  public renderer: Renderer2;\r\n  public elementRef: ElementRef;\r\n\r\n  public classMap: string;\r\n  public pages: any[];\r\n\r\n  protected _itemsPerPage: number;\r\n  protected _totalItems: number;\r\n  protected _totalPages: number;\r\n  protected inited = false;\r\n  protected _page = 1;\r\n\r\n  public constructor(renderer: Renderer2, elementRef: ElementRef, paginationConfig: PaginationConfig) {\r\n    this.renderer = renderer;\r\n    this.elementRef = elementRef;\r\n    if (!this.config) {\r\n      this.configureOptions(Object.assign({}, paginationConfig.main, paginationConfig.pager));\r\n    }\r\n  }\r\n\r\n  public configureOptions(config: any): void {\r\n    this.config = Object.assign({}, config);\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    this.classMap = this.elementRef.nativeElement.getAttribute('class') || '';\r\n    // watch for maxSize\r\n    this.maxSize = typeof this.maxSize !== 'undefined'\r\n      ? this.maxSize\r\n      : this.config.maxSize;\r\n    this.rotate = typeof this.rotate !== 'undefined'\r\n      ? this.rotate\r\n      : this.config.rotate;\r\n    this.boundaryLinks = typeof this.boundaryLinks !== 'undefined'\r\n      ? this.boundaryLinks\r\n      : this.config.boundaryLinks;\r\n    this.directionLinks = typeof this.directionLinks !== 'undefined'\r\n      ? this.directionLinks\r\n      : this.config.directionLinks;\r\n    this.pageBtnClass = typeof this.pageBtnClass !== 'undefined'\r\n      ? this.pageBtnClass\r\n      : this.config.pageBtnClass;\r\n\r\n    // base class\r\n    this.itemsPerPage = typeof this.itemsPerPage !== 'undefined'\r\n      ? this.itemsPerPage\r\n      : this.config.itemsPerPage;\r\n    this.totalPages = this.calculateTotalPages();\r\n    // this class\r\n    this.pages = this.getPages(this.page, this.totalPages);\r\n    this.inited = true;\r\n  }\r\n\r\n  public writeValue(value: number): void {\r\n    this.page = value;\r\n    this.pages = this.getPages(this.page, this.totalPages);\r\n  }\r\n\r\n  public getText(key: string): string {\r\n    return (this as any)[key + 'Text'] || this.config[key + 'Text'];\r\n  }\r\n\r\n  public noPrevious(): boolean {\r\n    return this.page === 1;\r\n  }\r\n\r\n  public noNext(): boolean {\r\n    return this.page === this.totalPages;\r\n  }\r\n\r\n  public registerOnChange(fn: (_: any) => {}): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  public registerOnTouched(fn: () => {}): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  public selectPage(page: number, event?: Event): void {\r\n    if (event) {\r\n      event.preventDefault();\r\n    }\r\n\r\n    if (!this.disabled) {\r\n      if (event && event.target) {\r\n        const target: any = event.target;\r\n        target.blur();\r\n      }\r\n      this.writeValue(page);\r\n      this.onChange(this.page);\r\n    }\r\n  }\r\n\r\n  // Create page object used in template\r\n  protected makePage(num: number, text: string, active: boolean): {number: number, text: string, active: boolean} {\r\n    return {text, number: num, active};\r\n  }\r\n\r\n  protected getPages(currentPage: number, totalPages: number): any[] {\r\n    const pages: any[] = [];\r\n\r\n    // Default page limits\r\n    let startPage = 1;\r\n    let endPage = totalPages;\r\n    const isMaxSized = typeof this.maxSize !== 'undefined' && this.maxSize < totalPages;\r\n\r\n    // recompute if maxSize\r\n    if (isMaxSized) {\r\n      if (this.rotate) {\r\n        // Current page is displayed in the middle of the visible ones\r\n        startPage = Math.max(currentPage - Math.floor(this.maxSize / 2), 1);\r\n        endPage = startPage + this.maxSize - 1;\r\n\r\n        // Adjust if limit is exceeded\r\n        if (endPage > totalPages) {\r\n          endPage = totalPages;\r\n          startPage = endPage - this.maxSize + 1;\r\n        }\r\n      } else {\r\n        // Visible pages are paginated with maxSize\r\n        startPage = ((Math.ceil(currentPage / this.maxSize) - 1) * this.maxSize) + 1;\r\n\r\n        // Adjust last page if limit is exceeded\r\n        endPage = Math.min(startPage + this.maxSize - 1, totalPages);\r\n      }\r\n    }\r\n\r\n    // Add page number links\r\n    for (let num = startPage; num <= endPage; num++) {\r\n      const page = this.makePage(num, num.toString(), num === currentPage);\r\n      pages.push(page);\r\n    }\r\n\r\n    // Add links to move between page sets\r\n    if (isMaxSized && !this.rotate) {\r\n      if (startPage > 1) {\r\n        const previousPageSet = this.makePage(startPage - 1, '...', false);\r\n        pages.unshift(previousPageSet);\r\n      }\r\n\r\n      if (endPage < totalPages) {\r\n        const nextPageSet = this.makePage(endPage + 1, '...', false);\r\n        pages.push(nextPageSet);\r\n      }\r\n    }\r\n\r\n    return pages;\r\n  }\r\n\r\n  // base class\r\n  protected calculateTotalPages(): number {\r\n    const totalPages = this.itemsPerPage < 1\r\n      ? 1\r\n      : Math.ceil(this.totalItems / this.itemsPerPage);\r\n    return Math.max(totalPages || 0, 1);\r\n  }\r\n}\r\n"]}