desy-angular 13.0.0 → 13.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
|
@@ -234,4 +234,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
234
234
|
}], itemsPerPageChange: [{
|
|
235
235
|
type: Output
|
|
236
236
|
}] } });
|
|
237
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pagination.component.js","sourceRoot":"","sources":["../../../../../../../projects/desy-angular/src/lib/desy-pagination/components/pagination/pagination.component.ts","../../../../../../../projects/desy-angular/src/lib/desy-pagination/components/pagination/pagination.component.html"],"names":[],"mappings":"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","sourcesContent":["\nimport { AfterContentInit, ChangeDetectorRef, Component, ContentChildren, EventEmitter, HostBinding, Input, OnChanges, Output, QueryList, SimpleChanges } from '@angular/core';\nimport { AccessibilityComponent } from '../../../shared/components';\nimport { DesyContentChild } from '../../../shared/decorators/desy-content-child.decorator';\nimport { PaginationItemPerPageComponent } from '../pagination-item-perpage/pagination-item-perpage.component';\nimport { PaginationListboxLabelComponent } from '../pagination-listbox-label/pagination-listbox-label.component';\n\n\n@Component({\n  selector: 'desy-pagination',\n  templateUrl: './pagination.component.html'\n})\nexport class PaginationComponent extends AccessibilityComponent implements OnChanges, AfterContentInit {\n\n  @Input() hasSelect: boolean;\n  @Input() idPrefix: string;\n  @Input() totalItems: number;\n  @Input() hasPrevious: boolean = true;\n  @Input() hasNext: boolean = true;\n  @Input() hasFirst: boolean = true;\n  @Input() hasLast: boolean = true;\n  @Input() showPrevious: boolean = true;\n  @Input() showNext: boolean = true;\n  @Input() showFirst: boolean = false;\n  @Input() showLast: boolean = false;\n  @Input() previousText: string;\n  @Input() nextText: string;\n  @Input() firstText: string;\n  @Input() lastText: string;\n  @Input() hasSelectItemsPerPage: string;\n  @Input() classes: string;\n\n  @Input() @HostBinding('class') classesContainer: any;\n  @Input() @HostBinding('attr.id') id: any;\n\n  @DesyContentChild()\n  @ContentChildren(PaginationListboxLabelComponent) listboxLabel: PaginationListboxLabelComponent;\n\n  @ContentChildren(PaginationItemPerPageComponent) listboxItemsPerPage: QueryList<PaginationItemPerPageComponent>;\n\n  @Input() currentPage = 1; // == currentPageindex + 1\n  @Output() currentPageChange = new EventEmitter<number>();\n\n\n  @Input() itemsPerPage: number;\n  @Output() itemsPerPageChange = new EventEmitter<number>();\n\n  nPages: number;\n  items: PaginationItemPerPageComponent[];\n  value: number;\n  itemsPerPageList: PaginationItemPerPageComponent[];\n  valuePerPage: number;\n  nPagesHistory = 0;\n\n  defaultText: boolean = false;\n\n  readonly previousIcon = '<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 140 140\"  width=\"1em\" height=\"1em\" class=\"self-center h-2.5 w-2.5 mr-2\" aria-hidden=\"true\" focusable=\"false\"><path d=\"M54.87 71.77a2.5 2.5 0 010-3.54L106 17.07A10 10 0 1091.89 2.93L35.43 59.39a15 15 0 000 21.22l56.46 56.46A10 10 0 10106 122.93z\" fill=\"currentColor\" /></svg>';\n  readonly nextIcon = '<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 140 140\" width=\"1em\" height=\"1em\" class=\"self-center h-2.5 w-2.5 ml-2\" aria-hidden=\"true\" focusable=\"false\"><path d=\"M34 137.07a10 10 0 010-14.14l51.13-51.16a2.5 2.5 0 000-3.54L34 17.07A10 10 0 0148.11 2.93l56.46 56.46a15 15 0 010 21.22l-56.46 56.46a10 10 0 01-14.11 0z\" fill=\"currentColor\" /></svg>';\n  readonly firstIcon = '<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" width=\"1em\" height=\"1em\" class=\"self-center h-2.5 w-2.5 mr-2\" aria-hidden=\"true\" focusable=\"false\"><g><path d=\"M10.42,12a2.64,2.64,0,0,1,.77-1.88L20.73.58a1.77,1.77,0,0,1,2.5,2.5l-8.74,8.74a.27.27,0,0,0,0,.36l8.74,8.74a1.77,1.77,0,0,1-2.5,2.5l-9.54-9.54A2.64,2.64,0,0,1,10.42,12Z\" fill=\"currentColor\"></path><path d=\"M.25,12A2.65,2.65,0,0,1,1,10.12L10.57.58a1.77,1.77,0,0,1,2.5,2.5L4.33,11.82a.25.25,0,0,0,0,.36l8.74,8.74a1.77,1.77,0,0,1-2.5,2.5L1,13.88A2.65,2.65,0,0,1,.25,12Z\" fill=\"currentColor\"></path></g></svg>';\n  readonly lastIcon = '<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" width=\"1em\" height=\"1em\" class=\"self-center h-2.5 w-2.5 ml-2\" aria-hidden=\"true\" focusable=\"false\"><g><path d=\"M13.58,12a2.64,2.64,0,0,1-.77,1.88L3.27,23.42a1.77,1.77,0,0,1-2.5-2.5l8.74-8.74a.27.27,0,0,0,0-.36L.77,3.08A1.77,1.77,0,0,1,3.27.58l9.54,9.54A2.64,2.64,0,0,1,13.58,12Z\" fill=\"currentColor\"></path><path d=\"M23.75,12A2.65,2.65,0,0,1,23,13.88l-9.54,9.54a1.77,1.77,0,0,1-2.5-2.5l8.74-8.74a.25.25,0,0,0,0-.36L10.93,3.08a1.77,1.77,0,0,1,2.5-2.5L23,10.12A2.65,2.65,0,0,1,23.75,12Z\" fill=\"currentColor\"></path></g></svg>';\n  readonly prefix = '<span class=\"sr-only\">Página&nbsp;</span>';\n\n  constructor(private changeDetector: ChangeDetectorRef) {\n    super();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (this.currentPage === null || this.currentPage === undefined) {\n      this.currentPage = 1;\n    }\n    this.checkChanges();\n    this.classesContainer = this.classesContainer ? this.classesContainer += ' lg:flex lg:flex-wrap lg:items-center lg:gap-base' : 'lg:flex lg:flex-wrap lg:items-center lg:gap-base'\n    this.id = this.id ? this.id : null\n  }\n\n  ngAfterContentInit(): void {\n    if (this.listboxItemsPerPage) {\n      this.setupItemsPerPage();\n      this.listboxItemsPerPage.changes.subscribe(() => {\n        this.setupItemsPerPage();\n      })\n    }\n  }\n\n  checkChanges(): void {\n    this.nPages = Math.ceil(this.totalItems / this.itemsPerPage);\n\n    if (!this.currentPage || this.currentPage < 1 || this.currentPage > this.nPages) {\n      this.currentPage = 1;\n      this.currentPageChange.emit(this.currentPage);\n    }\n    if (!this.firstText) {\n      this.firstText = 'Primera';\n    }\n    if (!this.previousText) {\n      this.previousText = 'Anterior';\n    }\n    if (!this.nextText) {\n      this.nextText = 'Siguiente';\n    }\n    if (!this.lastText) {\n      this.lastText = 'Última';\n    }\n    this.buildPages();\n  }\n\n  getSuffix(page: number, isNumber = false): string {\n    return page >= 0 && page * this.itemsPerPage < this.totalItems ?\n      (isNumber ? `<span class=\"sr-only\">:&nbsp; con los resultados del ${page * this.itemsPerPage + 1} al ${this.getLastItemNumber(page)}</span>` : `<span class=\"sr-only\">:&nbsp;Página ${page + 1} con los resultados del ${page * this.itemsPerPage + 1} al ${this.getLastItemNumber(page)}</span>`)\n      : '';\n  }\n\n  getLastItemNumber(pageIndex: number): number {\n    return Math.min((pageIndex + 1) * this.itemsPerPage, this.totalItems);\n  }\n\n  buildPages(): void {\n    if (this.nPagesHistory != this.nPages) {\n      this.nPagesHistory = this.nPages\n      const itemList = [];\n      for (let i = 0; i < this.nPages; i++) {\n        const item = {\n          value: i + 1,\n          text: i + 1,\n          selected: ((i + 1) === this.currentPage)\n        };\n        itemList.push(item);\n      }\n      this.value = this.currentPage\n      this.items = itemList;\n    }\n  }\n\n  getIdPrefix(): string {\n    return this.idPrefix ? this.idPrefix : 'pagination-item';\n  }\n\n  getButtonId(index: number): string {\n    return this.getIdPrefix() + '-' + ++index;\n  }\n\n  changePage(current: number): void {\n    const hasPageChange = current !== this.currentPage;\n    this.currentPage = current;\n    if (hasPageChange) {\n      this.currentPageChange.emit(this.currentPage);\n    }\n    for (let i = 0; i < this.items.length; i++) {\n      const item = this.items[i];\n      item.selected = ((i + 1) === this.currentPage);\n      this.value = this.currentPage\n    }\n  }\n\n  previous(): void {\n    if (this.currentPage > 1) {\n      this.changePage(this.currentPage - 1);\n    }\n  }\n\n  next(): void {\n    if (this.currentPage < this.nPages) {\n      this.changePage(this.currentPage + 1);\n    }\n  }\n\n  first(): void {\n    if (this.currentPage > 1) {\n      this.changePage(1);\n    }\n  }\n\n  last(): void {\n    if (this.currentPage < this.nPages) {\n      this.changePage(this.nPages);\n    }\n  }\n\n  getListboxLabel(): PaginationListboxLabelComponent {\n    return this.listboxLabel ? this.listboxLabel : null;\n  }\n\n  changeItemsPerPage(event: any) {\n    if (event) {\n      let newValue = event;\n      this.itemsPerPage = newValue;\n      this.checkChanges();\n      this.itemsPerPageChange.emit(newValue);\n      this.changeDetector.detectChanges();\n    }\n  }\n\n  handleActiveItemChange(event): void {\n    if (event !== null && event !== undefined) {\n      this.changePage(event);\n    }\n  }\n\n  setupItemsPerPage(): void {\n    this.itemsPerPageList = this.listboxItemsPerPage && this.listboxItemsPerPage.length > 0 ? this.listboxItemsPerPage.toArray() : null;\n    if (this.itemsPerPageList) {\n      const currentItemsPerPageItem = this.itemsPerPageList.find(i => i.value === this.itemsPerPage);\n      if (currentItemsPerPageItem) {\n        currentItemsPerPageItem.selected = true;\n      }\n      const hasActive = this.itemsPerPageList.find(i => i.selected);\n      if (!hasActive && this.itemsPerPageList.length > 0) {\n        this.itemsPerPageList[0].selected = true;\n      }\n      this.changeDetector.detectChanges();\n    }\n  }\n}\n","<ng-container *ngIf=\"hasSelect\">\n  <p [attr.id]=\"id + '-label'\" class=\"w-full mb-xs text-sm text-neutral-dark\">\n    Selecciona para cargar datos automáticamente\n  </p>\n  <nav [class]=\"['flex flex-wrap items-center flex-1 mb-base lg:mb-0 text-sm', classes] | makeHtmlList\"\n        [desyAppAccessibility]=\"this\">\n    <desy-button *ngIf=\"showFirst\" (clickEvent)=\"first()\" [id]=\"getIdPrefix() + '-first'\"\n                  [html]=\"firstIcon + prefix + firstText + getSuffix(currentPage - 2)\" [disabled]=\"currentPage === 1 || !hasFirst\"\n                  classes=\"c-button--sm c-button--transparent mr-xs\"></desy-button>\n    <desy-button *ngIf=\"showPrevious\" (clickEvent)=\"previous()\" [id]=\"getIdPrefix() + '-previous'\"\n                  [html]=\"previousIcon + prefix + previousText + getSuffix(currentPage - 2)\" [disabled]=\"currentPage === 1 || !hasPrevious\"\n                  classes=\"c-button--sm c-button--transparent mr-xs\"></desy-button>\n    <div class=\"flex flex-wrap items-center pl-sm\"\n          [ngClass]=\"{'w-full lg:w-auto': showFirst || showLast}\">\n      <p *ngIf=\"showFirst || showLast\" class=\"lg:hidden mr-xs text-sm text-neutral-dark\">Página actual:</p>\n          <desy-select [classes]=\"'c-select--sm c-select--transparent'\" \n                 [formGroupClasses]=\"'-mt-sm mb-0 mr-xs'\" \n                 [id]=\"id + '-items-listbox-'\"\n                 [name]=\"id + 'items-listbox-'\"\n                 [describedBy]=\"id + '-label'\"\n                 [items]=\"items\"\n                 [ngModel]=\"value\"\n                 (ngModelChange)=\"handleActiveItemChange($event)\">\n             <desy-label [classes]=\"'sr-only'\">\n                Selecciona una página\n             </desy-label>\n          </desy-select>\n    </div>\n    <desy-button *ngIf=\"showNext\" (clickEvent)=\"next()\" [id]=\"getIdPrefix() + '-next'\"\n                  [html]=\"prefix + nextText + getSuffix(currentPage) + nextIcon\" [disabled]=\"currentPage === nPages || !hasNext\"\n                  classes=\"c-button--sm c-button--transparent mr-xs\"></desy-button>\n    <desy-button *ngIf=\"showLast\" (clickEvent)=\"last()\" [id]=\"getIdPrefix() + '-last'\"\n                  [html]=\"prefix + lastText + getSuffix(currentPage) + lastIcon\" [disabled]=\"currentPage === nPages || !hasLast\"\n                  classes=\"c-button--sm c-button--transparent mr-xs\"></desy-button>\n  </nav>\n</ng-container>\n<ng-container *ngIf=\"!hasSelect\">\n  <nav [class]=\"['flex flex-wrap items-center flex-1 mb-base lg:mb-0 text-sm', classes] | makeHtmlList\"\n        [desyAppAccessibility]=\"this\">\n    <ul class=\"flex flex-wrap\">\n      <li *ngFor=\"let item of items; index as i\">\n        <desy-button *ngIf=\"item.active\" [id]=\"getButtonId(i)\"\n                      [html]=\"'<strong>' + prefix + (i + 1) + getSuffix(i,true) + '</strong>'\"\n                      classes=\"c-button--primary c-button--disabled mb-sm mr-sm\"\n                      [disabled]=\"true\" ariaCurrent=\"page\" tabindex=\"-1\"></desy-button>\n        <desy-button *ngIf=\"!item.active\" [id]=\"getButtonId(i)\"\n                      [html]=\"prefix + (i + 1) + getSuffix(i,true)\"\n                      (clickEvent)=\"changePage(i + 1)\"\n                      classes=\"mb-sm mr-sm\"></desy-button>\n      </li>\n    </ul>\n  </nav>\n</ng-container>\n  \n<div *ngIf=\"hasSelectItemsPerPage\" class=\"block relative -top-xs lg:ml-auto text-sm text-neutral-dark\">\n    <desy-select [classes]=\"'c-select--sm c-select--transparent'\" \n                 [formGroupClasses]=\"'flex flex-wrap place-items-baseline gap-xs -mt-sm mb-0 mr-xs'\" \n                 [id]=\"'items-listbox-' + getIdPrefix()\"\n                 [name]=\"'items-listbox-' + getIdPrefix()\"\n                 [describedBy]=\"id + '-label'\"\n                 [items]=\"itemsPerPageList\"\n                 [ngModel]=\"valuePerPage\"\n                 (ngModelChange)=\"changeItemsPerPage($event)\">\n      <desy-label [classes]=\"listboxLabel && listboxLabel.classes ? listboxLabel.classes : 'inline-block flex align-middle mb-[0]'\">\n        <ng-container *ngIf=\"listboxLabel\">\n          <ng-container *desyCustomInnerContent=\"{ component: listboxLabel }\"></ng-container>\n        </ng-container>\n        <ng-container *ngIf=\"!listboxLabel\">\n          Items por página\n        </ng-container>\n      </desy-label>\n   </desy-select>\n</div>\n\n\n<p [attr.id]=\"idPrefix + '-status'\" role=\"status\" aria-live=\"polite\" class=\"block relative -top-xs lg:ml-auto text-sm text-neutral-dark\" *ngIf=\"totalItems && itemsPerPage\">\n  <span class=\"sr-only\">Posición de paginación: </span>{{(currentPage - 1) * itemsPerPage + 1}} - {{getLastItemNumber(currentPage - 1)}} de {{totalItems}}\n</p>\n"]}
|
|
237
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pagination.component.js","sourceRoot":"","sources":["../../../../../../../projects/desy-angular/src/lib/desy-pagination/components/pagination/pagination.component.ts","../../../../../../../projects/desy-angular/src/lib/desy-pagination/components/pagination/pagination.component.html"],"names":[],"mappings":"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","sourcesContent":["\nimport { AfterContentInit, ChangeDetectorRef, Component, ContentChildren, EventEmitter, HostBinding, Input, OnChanges, Output, QueryList, SimpleChanges } from '@angular/core';\nimport { AccessibilityComponent } from '../../../shared/components';\nimport { DesyContentChild } from '../../../shared/decorators/desy-content-child.decorator';\nimport { PaginationItemPerPageComponent } from '../pagination-item-perpage/pagination-item-perpage.component';\nimport { PaginationListboxLabelComponent } from '../pagination-listbox-label/pagination-listbox-label.component';\n\n\n@Component({\n  selector: 'desy-pagination',\n  templateUrl: './pagination.component.html'\n})\nexport class PaginationComponent extends AccessibilityComponent implements OnChanges, AfterContentInit {\n\n  @Input() hasSelect: boolean;\n  @Input() idPrefix: string;\n  @Input() totalItems: number;\n  @Input() hasPrevious: boolean = true;\n  @Input() hasNext: boolean = true;\n  @Input() hasFirst: boolean = true;\n  @Input() hasLast: boolean = true;\n  @Input() showPrevious: boolean = true;\n  @Input() showNext: boolean = true;\n  @Input() showFirst: boolean = false;\n  @Input() showLast: boolean = false;\n  @Input() previousText: string;\n  @Input() nextText: string;\n  @Input() firstText: string;\n  @Input() lastText: string;\n  @Input() hasSelectItemsPerPage: string | boolean;\n  @Input() classes: string;\n\n  @Input() @HostBinding('class') classesContainer: any;\n  @Input() @HostBinding('attr.id') id: any;\n\n  @DesyContentChild()\n  @ContentChildren(PaginationListboxLabelComponent) listboxLabel: PaginationListboxLabelComponent;\n\n  @ContentChildren(PaginationItemPerPageComponent) listboxItemsPerPage: QueryList<PaginationItemPerPageComponent>;\n\n  @Input() currentPage = 1; // == currentPageindex + 1\n  @Output() currentPageChange = new EventEmitter<number>();\n\n\n  @Input() itemsPerPage: number;\n  @Output() itemsPerPageChange = new EventEmitter<number>();\n\n  nPages: number;\n  items: PaginationItemPerPageComponent[];\n  value: number;\n  itemsPerPageList: PaginationItemPerPageComponent[];\n  valuePerPage: number;\n  nPagesHistory = 0;\n\n  defaultText: boolean = false;\n\n  readonly previousIcon = '<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 140 140\"  width=\"1em\" height=\"1em\" class=\"self-center h-2.5 w-2.5 mr-2\" aria-hidden=\"true\" focusable=\"false\"><path d=\"M54.87 71.77a2.5 2.5 0 010-3.54L106 17.07A10 10 0 1091.89 2.93L35.43 59.39a15 15 0 000 21.22l56.46 56.46A10 10 0 10106 122.93z\" fill=\"currentColor\" /></svg>';\n  readonly nextIcon = '<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 140 140\" width=\"1em\" height=\"1em\" class=\"self-center h-2.5 w-2.5 ml-2\" aria-hidden=\"true\" focusable=\"false\"><path d=\"M34 137.07a10 10 0 010-14.14l51.13-51.16a2.5 2.5 0 000-3.54L34 17.07A10 10 0 0148.11 2.93l56.46 56.46a15 15 0 010 21.22l-56.46 56.46a10 10 0 01-14.11 0z\" fill=\"currentColor\" /></svg>';\n  readonly firstIcon = '<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" width=\"1em\" height=\"1em\" class=\"self-center h-2.5 w-2.5 mr-2\" aria-hidden=\"true\" focusable=\"false\"><g><path d=\"M10.42,12a2.64,2.64,0,0,1,.77-1.88L20.73.58a1.77,1.77,0,0,1,2.5,2.5l-8.74,8.74a.27.27,0,0,0,0,.36l8.74,8.74a1.77,1.77,0,0,1-2.5,2.5l-9.54-9.54A2.64,2.64,0,0,1,10.42,12Z\" fill=\"currentColor\"></path><path d=\"M.25,12A2.65,2.65,0,0,1,1,10.12L10.57.58a1.77,1.77,0,0,1,2.5,2.5L4.33,11.82a.25.25,0,0,0,0,.36l8.74,8.74a1.77,1.77,0,0,1-2.5,2.5L1,13.88A2.65,2.65,0,0,1,.25,12Z\" fill=\"currentColor\"></path></g></svg>';\n  readonly lastIcon = '<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" width=\"1em\" height=\"1em\" class=\"self-center h-2.5 w-2.5 ml-2\" aria-hidden=\"true\" focusable=\"false\"><g><path d=\"M13.58,12a2.64,2.64,0,0,1-.77,1.88L3.27,23.42a1.77,1.77,0,0,1-2.5-2.5l8.74-8.74a.27.27,0,0,0,0-.36L.77,3.08A1.77,1.77,0,0,1,3.27.58l9.54,9.54A2.64,2.64,0,0,1,13.58,12Z\" fill=\"currentColor\"></path><path d=\"M23.75,12A2.65,2.65,0,0,1,23,13.88l-9.54,9.54a1.77,1.77,0,0,1-2.5-2.5l8.74-8.74a.25.25,0,0,0,0-.36L10.93,3.08a1.77,1.77,0,0,1,2.5-2.5L23,10.12A2.65,2.65,0,0,1,23.75,12Z\" fill=\"currentColor\"></path></g></svg>';\n  readonly prefix = '<span class=\"sr-only\">Página&nbsp;</span>';\n\n  constructor(private changeDetector: ChangeDetectorRef) {\n    super();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (this.currentPage === null || this.currentPage === undefined) {\n      this.currentPage = 1;\n    }\n    this.checkChanges();\n    this.classesContainer = this.classesContainer ? this.classesContainer += ' lg:flex lg:flex-wrap lg:items-center lg:gap-base' : 'lg:flex lg:flex-wrap lg:items-center lg:gap-base'\n    this.id = this.id ? this.id : null\n  }\n\n  ngAfterContentInit(): void {\n    if (this.listboxItemsPerPage) {\n      this.setupItemsPerPage();\n      this.listboxItemsPerPage.changes.subscribe(() => {\n        this.setupItemsPerPage();\n      })\n    }\n  }\n\n  checkChanges(): void {\n    this.nPages = Math.ceil(this.totalItems / this.itemsPerPage);\n\n    if (!this.currentPage || this.currentPage < 1 || this.currentPage > this.nPages) {\n      this.currentPage = 1;\n      this.currentPageChange.emit(this.currentPage);\n    }\n    if (!this.firstText) {\n      this.firstText = 'Primera';\n    }\n    if (!this.previousText) {\n      this.previousText = 'Anterior';\n    }\n    if (!this.nextText) {\n      this.nextText = 'Siguiente';\n    }\n    if (!this.lastText) {\n      this.lastText = 'Última';\n    }\n    this.buildPages();\n  }\n\n  getSuffix(page: number, isNumber = false): string {\n    return page >= 0 && page * this.itemsPerPage < this.totalItems ?\n      (isNumber ? `<span class=\"sr-only\">:&nbsp; con los resultados del ${page * this.itemsPerPage + 1} al ${this.getLastItemNumber(page)}</span>` : `<span class=\"sr-only\">:&nbsp;Página ${page + 1} con los resultados del ${page * this.itemsPerPage + 1} al ${this.getLastItemNumber(page)}</span>`)\n      : '';\n  }\n\n  getLastItemNumber(pageIndex: number): number {\n    return Math.min((pageIndex + 1) * this.itemsPerPage, this.totalItems);\n  }\n\n  buildPages(): void {\n    if (this.nPagesHistory != this.nPages) {\n      this.nPagesHistory = this.nPages\n      const itemList = [];\n      for (let i = 0; i < this.nPages; i++) {\n        const item = {\n          value: i + 1,\n          text: i + 1,\n          selected: ((i + 1) === this.currentPage)\n        };\n        itemList.push(item);\n      }\n      this.value = this.currentPage\n      this.items = itemList;\n    }\n  }\n\n  getIdPrefix(): string {\n    return this.idPrefix ? this.idPrefix : 'pagination-item';\n  }\n\n  getButtonId(index: number): string {\n    return this.getIdPrefix() + '-' + ++index;\n  }\n\n  changePage(current: number): void {\n    const hasPageChange = current !== this.currentPage;\n    this.currentPage = current;\n    if (hasPageChange) {\n      this.currentPageChange.emit(this.currentPage);\n    }\n    for (let i = 0; i < this.items.length; i++) {\n      const item = this.items[i];\n      item.selected = ((i + 1) === this.currentPage);\n      this.value = this.currentPage\n    }\n  }\n\n  previous(): void {\n    if (this.currentPage > 1) {\n      this.changePage(this.currentPage - 1);\n    }\n  }\n\n  next(): void {\n    if (this.currentPage < this.nPages) {\n      this.changePage(this.currentPage + 1);\n    }\n  }\n\n  first(): void {\n    if (this.currentPage > 1) {\n      this.changePage(1);\n    }\n  }\n\n  last(): void {\n    if (this.currentPage < this.nPages) {\n      this.changePage(this.nPages);\n    }\n  }\n\n  getListboxLabel(): PaginationListboxLabelComponent {\n    return this.listboxLabel ? this.listboxLabel : null;\n  }\n\n  changeItemsPerPage(event: any) {\n    if (event) {\n      let newValue = event;\n      this.itemsPerPage = newValue;\n      this.checkChanges();\n      this.itemsPerPageChange.emit(newValue);\n      this.changeDetector.detectChanges();\n    }\n  }\n\n  handleActiveItemChange(event): void {\n    if (event !== null && event !== undefined) {\n      this.changePage(event);\n    }\n  }\n\n  setupItemsPerPage(): void {\n    this.itemsPerPageList = this.listboxItemsPerPage && this.listboxItemsPerPage.length > 0 ? this.listboxItemsPerPage.toArray() : null;\n    if (this.itemsPerPageList) {\n      const currentItemsPerPageItem = this.itemsPerPageList.find(i => i.value === this.itemsPerPage);\n      if (currentItemsPerPageItem) {\n        currentItemsPerPageItem.selected = true;\n      }\n      const hasActive = this.itemsPerPageList.find(i => i.selected);\n      if (!hasActive && this.itemsPerPageList.length > 0) {\n        this.itemsPerPageList[0].selected = true;\n      }\n      this.changeDetector.detectChanges();\n    }\n  }\n}\n","<ng-container *ngIf=\"hasSelect\">\n  <p [attr.id]=\"id + '-label'\" class=\"w-full mb-xs text-sm text-neutral-dark\">\n    Selecciona para cargar datos automáticamente\n  </p>\n  <nav [class]=\"['flex flex-wrap items-center flex-1 mb-base lg:mb-0 text-sm', classes] | makeHtmlList\"\n        [desyAppAccessibility]=\"this\">\n    <desy-button *ngIf=\"showFirst\" (clickEvent)=\"first()\" [id]=\"getIdPrefix() + '-first'\"\n                  [html]=\"firstIcon + prefix + firstText + getSuffix(currentPage - 2)\" [disabled]=\"currentPage === 1 || !hasFirst\"\n                  classes=\"c-button--sm c-button--transparent mr-xs\"></desy-button>\n    <desy-button *ngIf=\"showPrevious\" (clickEvent)=\"previous()\" [id]=\"getIdPrefix() + '-previous'\"\n                  [html]=\"previousIcon + prefix + previousText + getSuffix(currentPage - 2)\" [disabled]=\"currentPage === 1 || !hasPrevious\"\n                  classes=\"c-button--sm c-button--transparent mr-xs\"></desy-button>\n    <div class=\"flex flex-wrap items-center pl-sm\"\n          [ngClass]=\"{'w-full lg:w-auto': showFirst || showLast}\">\n      <p *ngIf=\"showFirst || showLast\" class=\"lg:hidden mr-xs text-sm text-neutral-dark\">Página actual:</p>\n          <desy-select [classes]=\"'c-select--sm c-select--transparent'\" \n                 [formGroupClasses]=\"'-mt-sm mb-0 mr-xs'\" \n                 [id]=\"id + '-items-listbox-'\"\n                 [name]=\"id + 'items-listbox-'\"\n                 [describedBy]=\"id + '-label'\"\n                 [items]=\"items\"\n                 [ngModel]=\"value\"\n                 (ngModelChange)=\"handleActiveItemChange($event)\">\n             <desy-label [classes]=\"'sr-only'\">\n                Selecciona una página\n             </desy-label>\n          </desy-select>\n    </div>\n    <desy-button *ngIf=\"showNext\" (clickEvent)=\"next()\" [id]=\"getIdPrefix() + '-next'\"\n                  [html]=\"prefix + nextText + getSuffix(currentPage) + nextIcon\" [disabled]=\"currentPage === nPages || !hasNext\"\n                  classes=\"c-button--sm c-button--transparent mr-xs\"></desy-button>\n    <desy-button *ngIf=\"showLast\" (clickEvent)=\"last()\" [id]=\"getIdPrefix() + '-last'\"\n                  [html]=\"prefix + lastText + getSuffix(currentPage) + lastIcon\" [disabled]=\"currentPage === nPages || !hasLast\"\n                  classes=\"c-button--sm c-button--transparent mr-xs\"></desy-button>\n  </nav>\n</ng-container>\n<ng-container *ngIf=\"!hasSelect\">\n  <nav [class]=\"['flex flex-wrap items-center flex-1 mb-base lg:mb-0 text-sm', classes] | makeHtmlList\"\n        [desyAppAccessibility]=\"this\">\n    <ul class=\"flex flex-wrap\">\n      <li *ngFor=\"let item of items; index as i\">\n        <desy-button *ngIf=\"item.active\" [id]=\"getButtonId(i)\"\n                      [html]=\"'<strong>' + prefix + (i + 1) + getSuffix(i,true) + '</strong>'\"\n                      classes=\"c-button--primary c-button--disabled mb-sm mr-sm\"\n                      [disabled]=\"true\" ariaCurrent=\"page\" tabindex=\"-1\"></desy-button>\n        <desy-button *ngIf=\"!item.active\" [id]=\"getButtonId(i)\"\n                      [html]=\"prefix + (i + 1) + getSuffix(i,true)\"\n                      (clickEvent)=\"changePage(i + 1)\"\n                      classes=\"mb-sm mr-sm\"></desy-button>\n      </li>\n    </ul>\n  </nav>\n</ng-container>\n  \n<div *ngIf=\"hasSelectItemsPerPage\" class=\"block relative -top-xs lg:ml-auto text-sm text-neutral-dark\">\n    <desy-select [classes]=\"'c-select--sm c-select--transparent'\" \n                 [formGroupClasses]=\"'flex flex-wrap place-items-baseline gap-xs -mt-sm mb-0 mr-xs'\" \n                 [id]=\"'items-listbox-' + getIdPrefix()\"\n                 [name]=\"'items-listbox-' + getIdPrefix()\"\n                 [describedBy]=\"id + '-label'\"\n                 [items]=\"itemsPerPageList\"\n                 [ngModel]=\"valuePerPage\"\n                 (ngModelChange)=\"changeItemsPerPage($event)\">\n      <desy-label [classes]=\"listboxLabel && listboxLabel.classes ? listboxLabel.classes : 'inline-block flex align-middle mb-[0]'\">\n        <ng-container *ngIf=\"listboxLabel\">\n          <ng-container *desyCustomInnerContent=\"{ component: listboxLabel }\"></ng-container>\n        </ng-container>\n        <ng-container *ngIf=\"!listboxLabel\">\n          Items por página\n        </ng-container>\n      </desy-label>\n   </desy-select>\n</div>\n\n\n<p [attr.id]=\"idPrefix + '-status'\" role=\"status\" aria-live=\"polite\" class=\"block relative -top-xs lg:ml-auto text-sm text-neutral-dark\" *ngIf=\"totalItems && itemsPerPage\">\n  <span class=\"sr-only\">Posición de paginación: </span>{{(currentPage - 1) * itemsPerPage + 1}} - {{getLastItemNumber(currentPage - 1)}} de {{totalItems}}\n</p>\n"]}
|