dfx-bootstrap-table
Version:
Angular table CDK implementation for Bootstrap with filtering, sorting and pagination.
244 lines • 45 kB
JavaScript
import { _IdGenerator } from '@angular/cdk/a11y';
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Inject, InjectionToken, Input, Optional, Output, ViewEncapsulation, booleanAttribute, inject, numberAttribute, } from '@angular/core';
import { FormsModule } from '@angular/forms';
import { ReplaySubject } from 'rxjs';
import { NgbPaginatorIntl } from './paginator-intl.service';
import * as i0 from "@angular/core";
import * as i1 from "./paginator-intl.service";
import * as i2 from "@angular/forms";
/** The default page size if there is no page size and there are no provided page size options. */
const DEFAULT_PAGE_SIZE = 50;
/** Injection token that can be used to provide the default options for the paginator module. */
export const NGB_PAGINATOR_DEFAULT_OPTIONS = new InjectionToken('NGB_PAGINATOR_DEFAULT_OPTIONS');
export class NgbPaginator {
/** The zero-based page index of the displayed list of items. Defaulted to 0. */
get pageIndex() {
return this._pageIndex;
}
set pageIndex(value) {
this._pageIndex = Math.max(value || 0, 0);
this._changeDetectorRef.markForCheck();
}
/** The length of the total number of items that are being paginated. Defaulted to 0. */
get length() {
return this._length;
}
set length(value) {
this._length = value || 0;
this._changeDetectorRef.markForCheck();
}
/** Number of items to display on a page. By default set to 50. */
get pageSize() {
return this._pageSize;
}
set pageSize(value) {
this._pageSize = Math.max(value || 0, 0);
this._updateDisplayedPageSizeOptions();
}
/** The set of provided page size options to display to the user. */
get pageSizeOptions() {
return this._pageSizeOptions;
}
set pageSizeOptions(value) {
this._pageSizeOptions = (value || []).map((p) => numberAttribute(p, 0));
this._updateDisplayedPageSizeOptions();
}
constructor(
// eslint-disable-next-line @angular-eslint/prefer-inject
_intl,
// eslint-disable-next-line @angular-eslint/prefer-inject
_changeDetectorRef,
// eslint-disable-next-line @angular-eslint/prefer-inject
defaults) {
this._intl = _intl;
this._changeDetectorRef = _changeDetectorRef;
/** ID for the DOM node containing the paginator's items per page label. */
this._pageSizeLabelId = inject(_IdGenerator).getId('ngb-paginator-page-size-label-');
this._isInitialized = false;
this._initializedStream = new ReplaySubject(1);
this._pageIndex = 0;
this._length = 0;
this._pageSizeOptions = [];
/** Whether to hide the page size selection UI from the user. */
this.hidePageSize = false;
/** Whether to show the first/last buttons UI to the user. */
this.showFirstLastButtons = false;
/** Whether the paginator is disabled. */
this.disabled = false;
/** Event emitted when the paginator changes the page size or page index. */
this.page = new EventEmitter();
/** Emits when the paginator is initialized. */
this.initialized = this._initializedStream;
this._intlChanges = _intl.changes.subscribe(() => this._changeDetectorRef.markForCheck());
if (defaults) {
const { pageSize, pageSizeOptions, hidePageSize, showFirstLastButtons } = defaults;
if (pageSize != null) {
this.pageSize = pageSize;
}
if (pageSizeOptions != null) {
this.pageSizeOptions = pageSizeOptions;
}
if (hidePageSize != null) {
this.hidePageSize = hidePageSize;
}
if (showFirstLastButtons != null) {
this.showFirstLastButtons = showFirstLastButtons;
}
}
}
ngOnInit() {
this._isInitialized = true;
this._updateDisplayedPageSizeOptions();
this._initializedStream.next();
}
ngOnDestroy() {
this._initializedStream.complete();
this._intlChanges.unsubscribe();
}
/** Advances to the next page if it exists. */
nextPage() {
if (!this.hasNextPage()) {
return;
}
const previousPageIndex = this.pageIndex;
this.pageIndex = this.pageIndex + 1;
this._emitPageEvent(previousPageIndex);
}
/** Move back to the previous page if it exists. */
previousPage() {
if (!this.hasPreviousPage()) {
return;
}
const previousPageIndex = this.pageIndex;
this.pageIndex = this.pageIndex - 1;
this._emitPageEvent(previousPageIndex);
}
/** Move to the first page if not already there. */
firstPage() {
// hasPreviousPage being false implies at the start
if (!this.hasPreviousPage()) {
return;
}
const previousPageIndex = this.pageIndex;
this.pageIndex = 0;
this._emitPageEvent(previousPageIndex);
}
/** Move to the last page if not already there. */
lastPage() {
// hasNextPage being false implies at the end
if (!this.hasNextPage()) {
return;
}
const previousPageIndex = this.pageIndex;
this.pageIndex = this.getNumberOfPages() - 1;
this._emitPageEvent(previousPageIndex);
}
/** Whether there is a previous page. */
hasPreviousPage() {
return this.pageIndex >= 1 && this.pageSize !== 0;
}
/** Whether there is a next page. */
hasNextPage() {
const maxPageIndex = this.getNumberOfPages() - 1;
return this.pageIndex < maxPageIndex && this.pageSize !== 0;
}
/** Calculate the number of pages */
getNumberOfPages() {
if (!this.pageSize) {
return 0;
}
return Math.ceil(this.length / this.pageSize);
}
/**
* Changes the page size so that the first item displayed on the page will still be
* displayed using the new page size.
*
* For example, if the page size is 10 and on the second page (items indexed 10-19) then
* switching so that the page size is 5 will set the third page as the current page so
* that the 10th item will still be displayed.
*/
_changePageSize(pageSize) {
// Current page needs to be updated to reflect the new page size. Navigate to the page
// containing the previous page's first item.
const startIndex = this.pageIndex * this.pageSize;
const previousPageIndex = this.pageIndex;
this.pageIndex = Math.floor(startIndex / pageSize) || 0;
this.pageSize = pageSize;
this._emitPageEvent(previousPageIndex);
}
/** Checks whether the buttons for going forwards should be disabled. */
_nextButtonsDisabled() {
return this.disabled || !this.hasNextPage();
}
/** Checks whether the buttons for going backwards should be disabled. */
_previousButtonsDisabled() {
return this.disabled || !this.hasPreviousPage();
}
/**
* Updates the list of page size options to display to the user. Includes making sure that
* the page size is an option and that the list is sorted.
*/
_updateDisplayedPageSizeOptions() {
if (!this._isInitialized) {
return;
}
// If no page size is provided, use the first page size option or the default page size.
if (!this.pageSize) {
this._pageSize = this.pageSizeOptions.length != 0 ? this.pageSizeOptions[0] : DEFAULT_PAGE_SIZE;
}
this._displayedPageSizeOptions = this.pageSizeOptions.slice();
if (this._displayedPageSizeOptions.indexOf(this.pageSize) === -1) {
this._displayedPageSizeOptions.push(this.pageSize);
}
// Sort the numbers using a number-specific sort function.
this._displayedPageSizeOptions.sort((a, b) => a - b);
this._changeDetectorRef.markForCheck();
}
/** Emits an event notifying that a change of the paginator's properties has been triggered. */
_emitPageEvent(previousPageIndex) {
this.page.emit({
previousPageIndex,
pageIndex: this.pageIndex,
pageSize: this.pageSize,
length: this.length,
});
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.2", ngImport: i0, type: NgbPaginator, deps: [{ token: i1.NgbPaginatorIntl }, { token: i0.ChangeDetectorRef }, { token: NGB_PAGINATOR_DEFAULT_OPTIONS, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.3.2", type: NgbPaginator, isStandalone: true, selector: "ngb-paginator", inputs: { pageIndex: ["pageIndex", "pageIndex", numberAttribute], length: ["length", "length", numberAttribute], pageSize: ["pageSize", "pageSize", numberAttribute], pageSizeOptions: "pageSizeOptions", hidePageSize: ["hidePageSize", "hidePageSize", booleanAttribute], showFirstLastButtons: ["showFirstLastButtons", "showFirstLastButtons", booleanAttribute], disabled: ["disabled", "disabled", booleanAttribute], size: "size" }, outputs: { page: "page" }, host: { attributes: { "role": "group" } }, exportAs: ["ngbPaginator"], ngImport: i0, template: "<div\n class=\"d-flex flex-column-reverse flex-lg-row justify-content-center justify-content-lg-end align-items-end align-items-lg-center gap-lg-5 gap-3\">\n @if (!hidePageSize) {\n <div class=\"d-inline-flex align-items-center gap-2\">\n <small class=\"ws-nowrap\" [attr.id]=\"_pageSizeLabelId\">{{ _intl.itemsPerPageLabel }}</small>\n\n @if (_displayedPageSizeOptions.length > 1) {\n <select\n class=\"form-select form-select-sm\"\n name=\"pageSize\"\n [ngModel]=\"pageSize\"\n [disabled]=\"disabled\"\n [attr.aria-labelledby]=\"_pageSizeLabelId\"\n (ngModelChange)=\"_changePageSize($any($event))\">\n @for (pageSizeOption of _displayedPageSizeOptions; track pageSizeOption) {\n <option [ngValue]=\"pageSizeOption\">{{ pageSizeOption }}</option>\n }\n </select>\n } @if (_displayedPageSizeOptions.length <= 1) {\n <small>{{pageSize}}</small>\n }\n </div>\n }\n\n <div class=\"d-inline-flex align-items-center gap-lg-5 gap-3\">\n <small aria-live=\"polite\">{{ _intl.getRangeLabel(pageIndex, pageSize, length) }}</small>\n\n <ul [class]=\"'my-0 pagination' + (size ? ' pagination-' + size : '')\">\n @if (showFirstLastButtons) {\n <li class=\"page-item\" [class.disabled]=\"_previousButtonsDisabled()\">\n <button\n class=\"page-link\"\n type=\"button\"\n (click)=\"firstPage()\"\n [disabled]=\"_previousButtonsDisabled()\"\n [attr.aria-label]=\"_intl.firstPageLabel\"\n [attr.tabindex]=\"_previousButtonsDisabled() ? '-1' : null\">\n <span aria-hidden=\"true\">««</span>\n </button>\n </li>\n }\n\n <li class=\"page-item\" [class.disabled]=\"_previousButtonsDisabled()\">\n <button\n class=\"page-link\"\n type=\"button\"\n (click)=\"previousPage()\"\n [disabled]=\"_previousButtonsDisabled()\"\n [attr.aria-label]=\"_intl.previousPageLabel\"\n [attr.tabindex]=\"_previousButtonsDisabled() ? '-1' : null\">\n <span aria-hidden=\"true\">«</span>\n </button>\n </li>\n <li class=\"page-item\" [class.disabled]=\"_nextButtonsDisabled()\">\n <button\n class=\"page-link\"\n type=\"button\"\n (click)=\"nextPage()\"\n [disabled]=\"_nextButtonsDisabled()\"\n [attr.aria-label]=\"_intl.nextPageLabel\"\n [attr.tabindex]=\"_nextButtonsDisabled() ? '-1' : null\">\n <span aria-hidden=\"true\">»</span>\n </button>\n </li>\n\n @if(showFirstLastButtons) {\n <li class=\"page-item\" [class.disabled]=\"_nextButtonsDisabled()\">\n <button\n class=\"page-link\"\n type=\"button\"\n (click)=\"lastPage()\"\n [disabled]=\"_nextButtonsDisabled()\"\n [attr.aria-label]=\"_intl.lastPageLabel\"\n [attr.tabindex]=\"_nextButtonsDisabled() ? '-1' : null\">\n <span aria-hidden=\"true\">»»</span>\n </button>\n </li>\n }\n </ul>\n </div>\n</div>\n", styles: [".ws-nowrap{white-space:nowrap}\n"], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.2", ngImport: i0, type: NgbPaginator, decorators: [{
type: Component,
args: [{ selector: 'ngb-paginator', exportAs: 'ngbPaginator', host: {
role: 'group',
}, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, imports: [FormsModule], template: "<div\n class=\"d-flex flex-column-reverse flex-lg-row justify-content-center justify-content-lg-end align-items-end align-items-lg-center gap-lg-5 gap-3\">\n @if (!hidePageSize) {\n <div class=\"d-inline-flex align-items-center gap-2\">\n <small class=\"ws-nowrap\" [attr.id]=\"_pageSizeLabelId\">{{ _intl.itemsPerPageLabel }}</small>\n\n @if (_displayedPageSizeOptions.length > 1) {\n <select\n class=\"form-select form-select-sm\"\n name=\"pageSize\"\n [ngModel]=\"pageSize\"\n [disabled]=\"disabled\"\n [attr.aria-labelledby]=\"_pageSizeLabelId\"\n (ngModelChange)=\"_changePageSize($any($event))\">\n @for (pageSizeOption of _displayedPageSizeOptions; track pageSizeOption) {\n <option [ngValue]=\"pageSizeOption\">{{ pageSizeOption }}</option>\n }\n </select>\n } @if (_displayedPageSizeOptions.length <= 1) {\n <small>{{pageSize}}</small>\n }\n </div>\n }\n\n <div class=\"d-inline-flex align-items-center gap-lg-5 gap-3\">\n <small aria-live=\"polite\">{{ _intl.getRangeLabel(pageIndex, pageSize, length) }}</small>\n\n <ul [class]=\"'my-0 pagination' + (size ? ' pagination-' + size : '')\">\n @if (showFirstLastButtons) {\n <li class=\"page-item\" [class.disabled]=\"_previousButtonsDisabled()\">\n <button\n class=\"page-link\"\n type=\"button\"\n (click)=\"firstPage()\"\n [disabled]=\"_previousButtonsDisabled()\"\n [attr.aria-label]=\"_intl.firstPageLabel\"\n [attr.tabindex]=\"_previousButtonsDisabled() ? '-1' : null\">\n <span aria-hidden=\"true\">««</span>\n </button>\n </li>\n }\n\n <li class=\"page-item\" [class.disabled]=\"_previousButtonsDisabled()\">\n <button\n class=\"page-link\"\n type=\"button\"\n (click)=\"previousPage()\"\n [disabled]=\"_previousButtonsDisabled()\"\n [attr.aria-label]=\"_intl.previousPageLabel\"\n [attr.tabindex]=\"_previousButtonsDisabled() ? '-1' : null\">\n <span aria-hidden=\"true\">«</span>\n </button>\n </li>\n <li class=\"page-item\" [class.disabled]=\"_nextButtonsDisabled()\">\n <button\n class=\"page-link\"\n type=\"button\"\n (click)=\"nextPage()\"\n [disabled]=\"_nextButtonsDisabled()\"\n [attr.aria-label]=\"_intl.nextPageLabel\"\n [attr.tabindex]=\"_nextButtonsDisabled() ? '-1' : null\">\n <span aria-hidden=\"true\">»</span>\n </button>\n </li>\n\n @if(showFirstLastButtons) {\n <li class=\"page-item\" [class.disabled]=\"_nextButtonsDisabled()\">\n <button\n class=\"page-link\"\n type=\"button\"\n (click)=\"lastPage()\"\n [disabled]=\"_nextButtonsDisabled()\"\n [attr.aria-label]=\"_intl.lastPageLabel\"\n [attr.tabindex]=\"_nextButtonsDisabled() ? '-1' : null\">\n <span aria-hidden=\"true\">»»</span>\n </button>\n </li>\n }\n </ul>\n </div>\n</div>\n", styles: [".ws-nowrap{white-space:nowrap}\n"] }]
}], ctorParameters: () => [{ type: i1.NgbPaginatorIntl }, { type: i0.ChangeDetectorRef }, { type: undefined, decorators: [{
type: Optional
}, {
type: Inject,
args: [NGB_PAGINATOR_DEFAULT_OPTIONS]
}] }], propDecorators: { pageIndex: [{
type: Input,
args: [{ transform: numberAttribute }]
}], length: [{
type: Input,
args: [{ transform: numberAttribute }]
}], pageSize: [{
type: Input,
args: [{ transform: numberAttribute }]
}], pageSizeOptions: [{
type: Input
}], hidePageSize: [{
type: Input,
args: [{ transform: booleanAttribute }]
}], showFirstLastButtons: [{
type: Input,
args: [{ transform: booleanAttribute }]
}], disabled: [{
type: Input,
args: [{ transform: booleanAttribute }]
}], size: [{
type: Input
}], page: [{
type: Output
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"paginator.js","sourceRoot":"","sources":["../../../../../../libs/dfx-bootstrap-table/src/lib/paginator/paginator.ts","../../../../../../libs/dfx-bootstrap-table/src/lib/paginator/paginator.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EACL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,YAAY,EACZ,MAAM,EACN,cAAc,EACd,KAAK,EAGL,QAAQ,EACR,MAAM,EACN,iBAAiB,EACjB,gBAAgB,EAChB,MAAM,EACN,eAAe,GAChB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAE7C,OAAO,EAAc,aAAa,EAAgB,MAAM,MAAM,CAAC;AAE/D,OAAO,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;;;;AAE5D,kGAAkG;AAClG,MAAM,iBAAiB,GAAG,EAAE,CAAC;AAmC7B,gGAAgG;AAChG,MAAM,CAAC,MAAM,6BAA6B,GAAG,IAAI,cAAc,CAA6B,+BAA+B,CAAC,CAAC;AAkB7H,MAAM,OAAO,YAAY;IAQvB,gFAAgF;IAChF,IACI,SAAS;QACX,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IACD,IAAI,SAAS,CAAC,KAAa;QACzB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;QAC1C,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;IACzC,CAAC;IAGD,wFAAwF;IACxF,IACI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IACD,IAAI,MAAM,CAAC,KAAa;QACtB,IAAI,CAAC,OAAO,GAAG,KAAK,IAAI,CAAC,CAAC;QAC1B,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;IACzC,CAAC;IAGD,kEAAkE;IAClE,IACI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IACD,IAAI,QAAQ,CAAC,KAAa;QACxB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;QACzC,IAAI,CAAC,+BAA+B,EAAE,CAAC;IACzC,CAAC;IAGD,oEAAoE;IACpE,IACI,eAAe;QACjB,OAAO,IAAI,CAAC,gBAAgB,CAAC;IAC/B,CAAC;IACD,IAAI,eAAe,CAAC,KAAmC;QACrD,IAAI,CAAC,gBAAgB,GAAG,CAAC,KAAK,IAAK,EAAe,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,eAAe,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACtF,IAAI,CAAC,+BAA+B,EAAE,CAAC;IACzC,CAAC;IA4BD;IACE,yDAAyD;IAClD,KAAuB;IAC9B,yDAAyD;IACjD,kBAAqC;IAC7C,yDAAyD;IACN,QAAqC;QAJjF,UAAK,GAAL,KAAK,CAAkB;QAEtB,uBAAkB,GAAlB,kBAAkB,CAAmB;QAhF/C,2EAA2E;QAClE,qBAAgB,GAAG,MAAM,CAAC,YAAY,CAAC,CAAC,KAAK,CAAC,gCAAgC,CAAC,CAAC;QAGjF,mBAAc,GAAG,KAAK,CAAC;QACvB,uBAAkB,GAAG,IAAI,aAAa,CAAO,CAAC,CAAC,CAAC;QAWhD,eAAU,GAAG,CAAC,CAAC;QAWf,YAAO,GAAG,CAAC,CAAC;QAsBZ,qBAAgB,GAAa,EAAE,CAAC;QAExC,gEAAgE;QACxB,iBAAY,GAAG,KAAK,CAAC;QAE7D,6DAA6D;QACrB,yBAAoB,GAAG,KAAK,CAAC;QAErE,yCAAyC;QACD,aAAQ,GAAG,KAAK,CAAC;QASzD,4EAA4E;QACzD,SAAI,GAA4B,IAAI,YAAY,EAAa,CAAC;QAKjF,+CAA+C;QAC/C,gBAAW,GAAqB,IAAI,CAAC,kBAAkB,CAAC;QAUtD,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC,CAAC;QAE1F,IAAI,QAAQ,EAAE,CAAC;YACb,MAAM,EAAE,QAAQ,EAAE,eAAe,EAAE,YAAY,EAAE,oBAAoB,EAAE,GAAG,QAAQ,CAAC;YAEnF,IAAI,QAAQ,IAAI,IAAI,EAAE,CAAC;gBACrB,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;YAC3B,CAAC;YAED,IAAI,eAAe,IAAI,IAAI,EAAE,CAAC;gBAC5B,IAAI,CAAC,eAAe,GAAG,eAAe,CAAC;YACzC,CAAC;YAED,IAAI,YAAY,IAAI,IAAI,EAAE,CAAC;gBACzB,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;YACnC,CAAC;YAED,IAAI,oBAAoB,IAAI,IAAI,EAAE,CAAC;gBACjC,IAAI,CAAC,oBAAoB,GAAG,oBAAoB,CAAC;YACnD,CAAC;QACH,CAAC;IACH,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAC3B,IAAI,CAAC,+BAA+B,EAAE,CAAC;QACvC,IAAI,CAAC,kBAAkB,CAAC,IAAI,EAAE,CAAC;IACjC,CAAC;IAED,WAAW;QACT,IAAI,CAAC,kBAAkB,CAAC,QAAQ,EAAE,CAAC;QACnC,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,CAAC;IAClC,CAAC;IAED,8CAA8C;IAC9C,QAAQ;QACN,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,CAAC;YACxB,OAAO;QACT,CAAC;QAED,MAAM,iBAAiB,GAAG,IAAI,CAAC,SAAS,CAAC;QACzC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC;QACpC,IAAI,CAAC,cAAc,CAAC,iBAAiB,CAAC,CAAC;IACzC,CAAC;IAED,mDAAmD;IACnD,YAAY;QACV,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,EAAE,CAAC;YAC5B,OAAO;QACT,CAAC;QAED,MAAM,iBAAiB,GAAG,IAAI,CAAC,SAAS,CAAC;QACzC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC;QACpC,IAAI,CAAC,cAAc,CAAC,iBAAiB,CAAC,CAAC;IACzC,CAAC;IAED,mDAAmD;IACnD,SAAS;QACP,mDAAmD;QACnD,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,EAAE,CAAC;YAC5B,OAAO;QACT,CAAC;QAED,MAAM,iBAAiB,GAAG,IAAI,CAAC,SAAS,CAAC;QACzC,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC;QACnB,IAAI,CAAC,cAAc,CAAC,iBAAiB,CAAC,CAAC;IACzC,CAAC;IAED,kDAAkD;IAClD,QAAQ;QACN,6CAA6C;QAC7C,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,CAAC;YACxB,OAAO;QACT,CAAC;QAED,MAAM,iBAAiB,GAAG,IAAI,CAAC,SAAS,CAAC;QACzC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,gBAAgB,EAAE,GAAG,CAAC,CAAC;QAC7C,IAAI,CAAC,cAAc,CAAC,iBAAiB,CAAC,CAAC;IACzC,CAAC;IAED,wCAAwC;IACxC,eAAe;QACb,OAAO,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,IAAI,CAAC,QAAQ,KAAK,CAAC,CAAC;IACpD,CAAC;IAED,oCAAoC;IACpC,WAAW;QACT,MAAM,YAAY,GAAG,IAAI,CAAC,gBAAgB,EAAE,GAAG,CAAC,CAAC;QACjD,OAAO,IAAI,CAAC,SAAS,GAAG,YAAY,IAAI,IAAI,CAAC,QAAQ,KAAK,CAAC,CAAC;IAC9D,CAAC;IAED,oCAAoC;IACpC,gBAAgB;QACd,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACnB,OAAO,CAAC,CAAC;QACX,CAAC;QAED,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC;IAChD,CAAC;IAED;;;;;;;OAOG;IACH,eAAe,CAAC,QAAgB;QAC9B,sFAAsF;QACtF,6CAA6C;QAC7C,MAAM,UAAU,GAAG,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC;QAClD,MAAM,iBAAiB,GAAG,IAAI,CAAC,SAAS,CAAC;QAEzC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC;QACxD,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,cAAc,CAAC,iBAAiB,CAAC,CAAC;IACzC,CAAC;IAED,wEAAwE;IACxE,oBAAoB;QAClB,OAAO,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;IAC9C,CAAC;IAED,yEAAyE;IACzE,wBAAwB;QACtB,OAAO,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC;IAClD,CAAC;IAED;;;OAGG;IACK,+BAA+B;QACrC,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC;YACzB,OAAO;QACT,CAAC;QAED,wFAAwF;QACxF,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACnB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,eAAe,CAAC,MAAM,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,iBAAiB,CAAC;QAClG,CAAC;QAED,IAAI,CAAC,yBAAyB,GAAG,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,CAAC;QAE9D,IAAI,IAAI,CAAC,yBAAyB,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC;YACjE,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACrD,CAAC;QAED,0DAA0D;QAC1D,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QACrD,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;IACzC,CAAC;IAED,+FAA+F;IACvF,cAAc,CAAC,iBAAyB;QAC9C,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC;YACb,iBAAiB;YACjB,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,MAAM,EAAE,IAAI,CAAC,MAAM;SACpB,CAAC,CAAC;IACL,CAAC;8GAvPU,YAAY,mFAmFD,6BAA6B;kGAnFxC,YAAY,iGASH,eAAe,gCAWf,eAAe,sCAWf,eAAe,sFAsBf,gBAAgB,0EAGhB,gBAAgB,sCAGhB,gBAAgB,6IC1ItC,2iGAiFA,yFDJY,WAAW;;2FAEV,YAAY;kBAhBxB,SAAS;+BACE,eAAe,YACf,cAAc,QAOlB;wBACJ,IAAI,EAAE,OAAO;qBACd,mBACgB,uBAAuB,CAAC,MAAM,iBAChC,iBAAiB,CAAC,IAAI,WAC5B,CAAC,WAAW,CAAC;;0BAqFnB,QAAQ;;0BAAI,MAAM;2BAAC,6BAA6B;yCAzE/C,SAAS;sBADZ,KAAK;uBAAC,EAAE,SAAS,EAAE,eAAe,EAAE;gBAYjC,MAAM;sBADT,KAAK;uBAAC,EAAE,SAAS,EAAE,eAAe,EAAE;gBAYjC,QAAQ;sBADX,KAAK;uBAAC,EAAE,SAAS,EAAE,eAAe,EAAE;gBAYjC,eAAe;sBADlB,KAAK;gBAWkC,YAAY;sBAAnD,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAGE,oBAAoB;sBAA3D,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAGE,QAAQ;sBAA/C,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAO7B,IAAI;sBAAZ,KAAK;gBAGa,IAAI;sBAAtB,MAAM","sourcesContent":["import { _IdGenerator } from '@angular/cdk/a11y';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Inject,\n  InjectionToken,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  ViewEncapsulation,\n  booleanAttribute,\n  inject,\n  numberAttribute,\n} from '@angular/core';\nimport { FormsModule } from '@angular/forms';\n\nimport { Observable, ReplaySubject, Subscription } from 'rxjs';\n\nimport { NgbPaginatorIntl } from './paginator-intl.service';\n\n/** The default page size if there is no page size and there are no provided page size options. */\nconst DEFAULT_PAGE_SIZE = 50;\n\n/**\n * Change event object that is emitted when the user selects a\n * different page size or navigates to another page.\n */\nexport type PageEvent = {\n  /** The current page index. */\n  pageIndex: number;\n\n  /** Index of the page that was selected previously. */\n  previousPageIndex: number;\n\n  /** The current page size. */\n  pageSize: number;\n\n  /** The current total number of items being paged. */\n  length: number;\n};\n\n/** Object that can be used to configure the default options for the paginator module. */\nexport interface NgbPaginatorDefaultOptions {\n  /** Number of items to display on a page. By default set to 50. */\n  pageSize?: number;\n\n  /** The set of provided page size options to display to the user. */\n  pageSizeOptions?: number[];\n\n  /** Whether to hide the page size selection UI from the user. */\n  hidePageSize?: boolean;\n\n  /** Whether to show the first/last buttons UI to the user. */\n  showFirstLastButtons?: boolean;\n}\n\n/** Injection token that can be used to provide the default options for the paginator module. */\nexport const NGB_PAGINATOR_DEFAULT_OPTIONS = new InjectionToken<NgbPaginatorDefaultOptions>('NGB_PAGINATOR_DEFAULT_OPTIONS');\n\n@Component({\n  selector: 'ngb-paginator',\n  exportAs: 'ngbPaginator',\n  templateUrl: './paginator.html',\n  styles: `\n    .ws-nowrap {\n      white-space: nowrap;\n    }\n  `,\n  host: {\n    role: 'group',\n  },\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  imports: [FormsModule],\n})\nexport class NgbPaginator implements OnInit, OnDestroy {\n  /** ID for the DOM node containing the paginator's items per page label. */\n  readonly _pageSizeLabelId = inject(_IdGenerator).getId('ngb-paginator-page-size-label-');\n\n  private _intlChanges: Subscription;\n  private _isInitialized = false;\n  private _initializedStream = new ReplaySubject<void>(1);\n\n  /** The zero-based page index of the displayed list of items. Defaulted to 0. */\n  @Input({ transform: numberAttribute })\n  get pageIndex(): number {\n    return this._pageIndex;\n  }\n  set pageIndex(value: number) {\n    this._pageIndex = Math.max(value || 0, 0);\n    this._changeDetectorRef.markForCheck();\n  }\n  private _pageIndex = 0;\n\n  /** The length of the total number of items that are being paginated. Defaulted to 0. */\n  @Input({ transform: numberAttribute })\n  get length(): number {\n    return this._length;\n  }\n  set length(value: number) {\n    this._length = value || 0;\n    this._changeDetectorRef.markForCheck();\n  }\n  private _length = 0;\n\n  /** Number of items to display on a page. By default set to 50. */\n  @Input({ transform: numberAttribute })\n  get pageSize(): number {\n    return this._pageSize;\n  }\n  set pageSize(value: number) {\n    this._pageSize = Math.max(value || 0, 0);\n    this._updateDisplayedPageSizeOptions();\n  }\n  private _pageSize!: number;\n\n  /** The set of provided page size options to display to the user. */\n  @Input()\n  get pageSizeOptions(): number[] {\n    return this._pageSizeOptions;\n  }\n  set pageSizeOptions(value: number[] | readonly number[]) {\n    this._pageSizeOptions = (value || ([] as number[])).map((p) => numberAttribute(p, 0));\n    this._updateDisplayedPageSizeOptions();\n  }\n  private _pageSizeOptions: number[] = [];\n\n  /** Whether to hide the page size selection UI from the user. */\n  @Input({ transform: booleanAttribute }) hidePageSize = false;\n\n  /** Whether to show the first/last buttons UI to the user. */\n  @Input({ transform: booleanAttribute }) showFirstLastButtons = false;\n\n  /** Whether the paginator is disabled. */\n  @Input({ transform: booleanAttribute }) disabled = false;\n\n  /**\n   * The paginator display size.\n   *\n   * Bootstrap currently supports small and large sizes.\n   */\n  @Input() size?: 'sm' | 'lg' | null;\n\n  /** Event emitted when the paginator changes the page size or page index. */\n  @Output() readonly page: EventEmitter<PageEvent> = new EventEmitter<PageEvent>();\n\n  /** Displayed set of page size options. Will be sorted and include current page size. */\n  _displayedPageSizeOptions!: number[];\n\n  /** Emits when the paginator is initialized. */\n  initialized: Observable<void> = this._initializedStream;\n\n  constructor(\n    // eslint-disable-next-line @angular-eslint/prefer-inject\n    public _intl: NgbPaginatorIntl,\n    // eslint-disable-next-line @angular-eslint/prefer-inject\n    private _changeDetectorRef: ChangeDetectorRef,\n    // eslint-disable-next-line @angular-eslint/prefer-inject\n    @Optional() @Inject(NGB_PAGINATOR_DEFAULT_OPTIONS) defaults?: NgbPaginatorDefaultOptions,\n  ) {\n    this._intlChanges = _intl.changes.subscribe(() => this._changeDetectorRef.markForCheck());\n\n    if (defaults) {\n      const { pageSize, pageSizeOptions, hidePageSize, showFirstLastButtons } = defaults;\n\n      if (pageSize != null) {\n        this.pageSize = pageSize;\n      }\n\n      if (pageSizeOptions != null) {\n        this.pageSizeOptions = pageSizeOptions;\n      }\n\n      if (hidePageSize != null) {\n        this.hidePageSize = hidePageSize;\n      }\n\n      if (showFirstLastButtons != null) {\n        this.showFirstLastButtons = showFirstLastButtons;\n      }\n    }\n  }\n\n  ngOnInit(): void {\n    this._isInitialized = true;\n    this._updateDisplayedPageSizeOptions();\n    this._initializedStream.next();\n  }\n\n  ngOnDestroy(): void {\n    this._initializedStream.complete();\n    this._intlChanges.unsubscribe();\n  }\n\n  /** Advances to the next page if it exists. */\n  nextPage(): void {\n    if (!this.hasNextPage()) {\n      return;\n    }\n\n    const previousPageIndex = this.pageIndex;\n    this.pageIndex = this.pageIndex + 1;\n    this._emitPageEvent(previousPageIndex);\n  }\n\n  /** Move back to the previous page if it exists. */\n  previousPage(): void {\n    if (!this.hasPreviousPage()) {\n      return;\n    }\n\n    const previousPageIndex = this.pageIndex;\n    this.pageIndex = this.pageIndex - 1;\n    this._emitPageEvent(previousPageIndex);\n  }\n\n  /** Move to the first page if not already there. */\n  firstPage(): void {\n    // hasPreviousPage being false implies at the start\n    if (!this.hasPreviousPage()) {\n      return;\n    }\n\n    const previousPageIndex = this.pageIndex;\n    this.pageIndex = 0;\n    this._emitPageEvent(previousPageIndex);\n  }\n\n  /** Move to the last page if not already there. */\n  lastPage(): void {\n    // hasNextPage being false implies at the end\n    if (!this.hasNextPage()) {\n      return;\n    }\n\n    const previousPageIndex = this.pageIndex;\n    this.pageIndex = this.getNumberOfPages() - 1;\n    this._emitPageEvent(previousPageIndex);\n  }\n\n  /** Whether there is a previous page. */\n  hasPreviousPage(): boolean {\n    return this.pageIndex >= 1 && this.pageSize !== 0;\n  }\n\n  /** Whether there is a next page. */\n  hasNextPage(): boolean {\n    const maxPageIndex = this.getNumberOfPages() - 1;\n    return this.pageIndex < maxPageIndex && this.pageSize !== 0;\n  }\n\n  /** Calculate the number of pages */\n  getNumberOfPages(): number {\n    if (!this.pageSize) {\n      return 0;\n    }\n\n    return Math.ceil(this.length / this.pageSize);\n  }\n\n  /**\n   * Changes the page size so that the first item displayed on the page will still be\n   * displayed using the new page size.\n   *\n   * For example, if the page size is 10 and on the second page (items indexed 10-19) then\n   * switching so that the page size is 5 will set the third page as the current page so\n   * that the 10th item will still be displayed.\n   */\n  _changePageSize(pageSize: number): void {\n    // Current page needs to be updated to reflect the new page size. Navigate to the page\n    // containing the previous page's first item.\n    const startIndex = this.pageIndex * this.pageSize;\n    const previousPageIndex = this.pageIndex;\n\n    this.pageIndex = Math.floor(startIndex / pageSize) || 0;\n    this.pageSize = pageSize;\n    this._emitPageEvent(previousPageIndex);\n  }\n\n  /** Checks whether the buttons for going forwards should be disabled. */\n  _nextButtonsDisabled(): boolean {\n    return this.disabled || !this.hasNextPage();\n  }\n\n  /** Checks whether the buttons for going backwards should be disabled. */\n  _previousButtonsDisabled(): boolean {\n    return this.disabled || !this.hasPreviousPage();\n  }\n\n  /**\n   * Updates the list of page size options to display to the user. Includes making sure that\n   * the page size is an option and that the list is sorted.\n   */\n  private _updateDisplayedPageSizeOptions() {\n    if (!this._isInitialized) {\n      return;\n    }\n\n    // If no page size is provided, use the first page size option or the default page size.\n    if (!this.pageSize) {\n      this._pageSize = this.pageSizeOptions.length != 0 ? this.pageSizeOptions[0] : DEFAULT_PAGE_SIZE;\n    }\n\n    this._displayedPageSizeOptions = this.pageSizeOptions.slice();\n\n    if (this._displayedPageSizeOptions.indexOf(this.pageSize) === -1) {\n      this._displayedPageSizeOptions.push(this.pageSize);\n    }\n\n    // Sort the numbers using a number-specific sort function.\n    this._displayedPageSizeOptions.sort((a, b) => a - b);\n    this._changeDetectorRef.markForCheck();\n  }\n\n  /** Emits an event notifying that a change of the paginator's properties has been triggered. */\n  private _emitPageEvent(previousPageIndex: number) {\n    this.page.emit({\n      previousPageIndex,\n      pageIndex: this.pageIndex,\n      pageSize: this.pageSize,\n      length: this.length,\n    });\n  }\n}\n","<div\n  class=\"d-flex flex-column-reverse flex-lg-row justify-content-center justify-content-lg-end align-items-end align-items-lg-center gap-lg-5 gap-3\">\n  @if (!hidePageSize) {\n  <div class=\"d-inline-flex align-items-center gap-2\">\n    <small class=\"ws-nowrap\" [attr.id]=\"_pageSizeLabelId\">{{ _intl.itemsPerPageLabel }}</small>\n\n    @if (_displayedPageSizeOptions.length > 1) {\n    <select\n      class=\"form-select form-select-sm\"\n      name=\"pageSize\"\n      [ngModel]=\"pageSize\"\n      [disabled]=\"disabled\"\n      [attr.aria-labelledby]=\"_pageSizeLabelId\"\n      (ngModelChange)=\"_changePageSize($any($event))\">\n      @for (pageSizeOption of _displayedPageSizeOptions; track pageSizeOption) {\n      <option [ngValue]=\"pageSizeOption\">{{ pageSizeOption }}</option>\n      }\n    </select>\n    } @if (_displayedPageSizeOptions.length <= 1) {\n    <small>{{pageSize}}</small>\n    }\n  </div>\n  }\n\n  <div class=\"d-inline-flex align-items-center gap-lg-5 gap-3\">\n    <small aria-live=\"polite\">{{ _intl.getRangeLabel(pageIndex, pageSize, length) }}</small>\n\n    <ul [class]=\"'my-0 pagination' + (size ? ' pagination-' + size : '')\">\n      @if (showFirstLastButtons) {\n      <li class=\"page-item\" [class.disabled]=\"_previousButtonsDisabled()\">\n        <button\n          class=\"page-link\"\n          type=\"button\"\n          (click)=\"firstPage()\"\n          [disabled]=\"_previousButtonsDisabled()\"\n          [attr.aria-label]=\"_intl.firstPageLabel\"\n          [attr.tabindex]=\"_previousButtonsDisabled() ? '-1' : null\">\n          <span aria-hidden=\"true\">&laquo;&laquo;</span>\n        </button>\n      </li>\n      }\n\n      <li class=\"page-item\" [class.disabled]=\"_previousButtonsDisabled()\">\n        <button\n          class=\"page-link\"\n          type=\"button\"\n          (click)=\"previousPage()\"\n          [disabled]=\"_previousButtonsDisabled()\"\n          [attr.aria-label]=\"_intl.previousPageLabel\"\n          [attr.tabindex]=\"_previousButtonsDisabled() ? '-1' : null\">\n          <span aria-hidden=\"true\">&laquo;</span>\n        </button>\n      </li>\n      <li class=\"page-item\" [class.disabled]=\"_nextButtonsDisabled()\">\n        <button\n          class=\"page-link\"\n          type=\"button\"\n          (click)=\"nextPage()\"\n          [disabled]=\"_nextButtonsDisabled()\"\n          [attr.aria-label]=\"_intl.nextPageLabel\"\n          [attr.tabindex]=\"_nextButtonsDisabled() ? '-1' : null\">\n          <span aria-hidden=\"true\">&raquo;</span>\n        </button>\n      </li>\n\n      @if(showFirstLastButtons) {\n      <li class=\"page-item\" [class.disabled]=\"_nextButtonsDisabled()\">\n        <button\n          class=\"page-link\"\n          type=\"button\"\n          (click)=\"lastPage()\"\n          [disabled]=\"_nextButtonsDisabled()\"\n          [attr.aria-label]=\"_intl.lastPageLabel\"\n          [attr.tabindex]=\"_nextButtonsDisabled() ? '-1' : null\">\n          <span aria-hidden=\"true\">&raquo;&raquo;</span>\n        </button>\n      </li>\n      }\n    </ul>\n  </div>\n</div>\n"]}