UNPKG

@taiga-ui/kit

Version:
263 lines 33 kB
var TuiPaginationComponent_1; import { __decorate, __param } from "tslib"; import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, forwardRef, Inject, Input, Optional, Output, QueryList, ViewChildren, } from '@angular/core'; import { AbstractTuiInteractive, clamp, EMPTY_QUERY, isNativeFocusedIn, setNativeFocused, TUI_FOCUSABLE_ITEM_ACCESSOR, tuiDefaultProp, } from '@taiga-ui/cdk'; import { TuiAppearance, TuiBrightness, TuiButtonComponent, TuiHorizontalDirection, TuiModeDirective, TuiSizeS, } from '@taiga-ui/core'; import { TUI_PAGINATION_TEXTS } from '@taiga-ui/kit/tokens'; import { horizontalDirectionToNumber } from '@taiga-ui/kit/utils/math'; import { Observable } from 'rxjs'; const DOTS_LENGTH = 1; const ACTIVE_ITEM_LENGTH = 1; export function nonNegativeInteger(length) { return Number.isInteger(length) && length >= 0; } // @dynamic let TuiPaginationComponent = TuiPaginationComponent_1 = class TuiPaginationComponent extends AbstractTuiInteractive { constructor(elementRef, modeDirective, texts$) { super(); this.elementRef = elementRef; this.modeDirective = modeDirective; this.texts$ = texts$; this.length = 1; this.size = 'm'; this.disabled = false; /** * Amount of visible pages around active page */ this.activePadding = 1; /** * Amount of visible pages at the edges */ this.sidePadding = 1; /** * Customization for page number display. */ this.content = null; /** * Active page index */ this.index = 0; this.indexChange = new EventEmitter(); this.elements = EMPTY_QUERY; } get nativeFocusableElement() { if (this.disabled) { return null; } let activeElementIndex = 0; const { elementsLength } = this; for (let i = 0; i < elementsLength; i++) { const itemIndex = this.getItemIndexByElementIndex(i); if (itemIndex) { activeElementIndex++; } if (itemIndex === this.index) { break; } } const activeElement = this.elements.find((_, index) => index === activeElementIndex); return activeElement ? activeElement.nativeFocusableElement : null; } get focused() { return isNativeFocusedIn(this.elementRef.nativeElement); } /** * Number of items in a container. */ get elementsLength() { return this.itemsFit ? this.length : this.maxElementsLength; } get sizeM() { return this.size === 'm'; } get mode() { return this.modeDirective ? this.modeDirective.mode : null; } get arrowIsDisabledLeft() { return this.index === 0; } get arrowIsDisabledRight() { return this.reverseIndex === 0; } elementIsFocusable(index) { return this.index === index && !this.focused; } getItemContext(index) { return { $implicit: index }; } /** * Get index by element index * @param elementIndex * @returns index or null (for '…') */ getItemIndexByElementIndex(elementIndex) { if (!this.sizeM) { return elementIndex; } if (elementIndex < this.sidePadding) { return elementIndex; } if (elementIndex === this.sidePadding && this.hasCollapsedItems(this.index)) { return null; } const reverseElementIndex = this.lastElementIndex - elementIndex; if (reverseElementIndex === this.sidePadding && this.hasCollapsedItems(this.reverseIndex)) { return null; } if (reverseElementIndex < this.sidePadding) { return this.lastIndex - reverseElementIndex; } const computedIndex = this.index - this.maxHalfLength + elementIndex; return clamp(computedIndex, elementIndex, this.lastIndex - reverseElementIndex); } getElementMode(index) { return this.index === index ? "primary" /* Primary */ : "flat" /* Flat */; } getSmallElementMode(index, mode) { return this.index === index && mode !== 'onLight' ? "primary" /* Primary */ : "secondary" /* Secondary */; } onElementClick(index) { this.updateIndex(index); } onElementKeyDownArrowLeft(element) { if (element === this.elements.first) { return; } const previous = this.elements.find((_, index, array) => array[index + 1] === element); if (previous && previous.nativeFocusableElement) { setNativeFocused(previous.nativeFocusableElement); } } onElementKeyDownArrowRight(element) { if (element === this.elements.last) { return; } const next = this.elements.find((_, index, array) => array[index - 1] === element); if (next && next.nativeFocusableElement) { setNativeFocused(next.nativeFocusableElement); } } onArrowClick(direction) { this.tryChangeTo(direction); this.focusActive(); } onActiveZone(focused) { this.updateFocused(focused); } /** * Active index from the end */ get reverseIndex() { return this.lastIndex - this.index; } /** * Max number of elements in half (not counting the middle one). */ get maxHalfLength() { return this.sidePadding + DOTS_LENGTH + this.activePadding; } /** * Is there '...' anywhere */ get itemsFit() { return this.length <= this.maxElementsLength; } /** * Max number of elements */ get maxElementsLength() { return this.maxHalfLength * 2 + ACTIVE_ITEM_LENGTH; } get lastIndex() { return this.length - 1; } get lastElementIndex() { return this.elementsLength - 1; } /** * Are there collapsed items at that index * @param index * @returns there are collapsed items */ hasCollapsedItems(index) { return !this.itemsFit && index > this.maxHalfLength; } tryChangeTo(direction) { this.updateIndex(clamp(this.index + horizontalDirectionToNumber(direction), 0, this.lastIndex)); } focusActive() { const { nativeFocusableElement } = this; if (nativeFocusableElement) { setNativeFocused(nativeFocusableElement); } } updateIndex(index) { if (this.index === index) { return; } this.index = index; this.indexChange.emit(index); } }; TuiPaginationComponent.ctorParameters = () => [ { type: ElementRef, decorators: [{ type: Inject, args: [ElementRef,] }] }, { type: TuiModeDirective, decorators: [{ type: Optional }, { type: Inject, args: [TuiModeDirective,] }] }, { type: Observable, decorators: [{ type: Inject, args: [TUI_PAGINATION_TEXTS,] }] } ]; __decorate([ Input(), tuiDefaultProp(nonNegativeInteger, 'Must be non-negative integer') ], TuiPaginationComponent.prototype, "length", void 0); __decorate([ Input(), tuiDefaultProp() ], TuiPaginationComponent.prototype, "size", void 0); __decorate([ Input(), tuiDefaultProp() ], TuiPaginationComponent.prototype, "disabled", void 0); __decorate([ Input(), tuiDefaultProp() ], TuiPaginationComponent.prototype, "activePadding", void 0); __decorate([ Input(), tuiDefaultProp() ], TuiPaginationComponent.prototype, "sidePadding", void 0); __decorate([ Input(), tuiDefaultProp() ], TuiPaginationComponent.prototype, "content", void 0); __decorate([ Input(), tuiDefaultProp(nonNegativeInteger, 'Must be non-negative integer') ], TuiPaginationComponent.prototype, "index", void 0); __decorate([ Output() ], TuiPaginationComponent.prototype, "indexChange", void 0); __decorate([ ViewChildren('element', { read: TUI_FOCUSABLE_ITEM_ACCESSOR }) ], TuiPaginationComponent.prototype, "elements", void 0); TuiPaginationComponent = TuiPaginationComponent_1 = __decorate([ Component({ selector: 'tui-pagination', template: "<div class=\"content\" (tuiActiveZoneChange)=\"onActiveZone($event)\">\n <ng-container *ngIf=\"sizeM && (texts$ | async) as texts; else smallButtons\">\n <button\n tuiIconButton\n type=\"button\"\n tuiPreventDefault=\"mousedown\"\n class=\"button\"\n size=\"s\"\n appearance=\"flat\"\n icon=\"tuiIconChevronLeft\"\n [title]=\"texts[0]\"\n [disabled]=\"arrowIsDisabledLeft\"\n [focusable]=\"false\"\n (click)=\"onArrowClick('left')\"\n ></button>\n <ng-container *tuiRepeatTimes=\"let elementIndex of elementsLength\">\n <ng-container\n *tuiLet=\"getItemIndexByElementIndex(elementIndex) as index\"\n >\n <button\n *ngIf=\"index !== null; else dotsTemplate\"\n #element\n tuiButton\n type=\"button\"\n automation-id=\"tui-pagination__element\"\n class=\"button\"\n shape=\"square\"\n size=\"s\"\n [disabled]=\"disabled\"\n [focusable]=\"elementIsFocusable(index)\"\n [appearance]=\"getElementMode(index)\"\n (click)=\"onElementClick(index)\"\n (keydown.arrowLeft.prevent)=\"onElementKeyDownArrowLeft(element)\"\n (keydown.arrowRight.prevent)=\"onElementKeyDownArrowRight(element)\"\n >\n <div\n polymorpheus-outlet\n [content]=\"content || index + 1\"\n [context]=\"getItemContext(index)\"\n ></div>\n </button>\n </ng-container>\n </ng-container>\n <button\n tuiIconButton\n type=\"button\"\n tuiPreventDefault=\"mousedown\"\n class=\"button\"\n size=\"s\"\n appearance=\"flat\"\n icon=\"tuiIconChevronRight\"\n [title]=\"texts[1]\"\n [disabled]=\"arrowIsDisabledRight\"\n [focusable]=\"false\"\n (click)=\"onArrowClick('right')\"\n ></button>\n </ng-container>\n <ng-template #smallButtons>\n <button\n *tuiRepeatTimes=\"let indexItem of length\"\n #element\n tuiButton\n type=\"button\"\n class=\"button button_small\"\n shape=\"square\"\n [class.button_active]=\"indexItem === index\"\n [disabled]=\"disabled\"\n [focusable]=\"elementIsFocusable(indexItem)\"\n [appearance]=\"getSmallElementMode(indexItem, mode)\"\n (click)=\"onElementClick(indexItem)\"\n (keydown.arrowLeft.prevent)=\"onElementKeyDownArrowLeft(element)\"\n (keydown.arrowRight.prevent)=\"onElementKeyDownArrowRight(element)\"\n ></button>\n </ng-template>\n <ng-template #dotsTemplate>\n <div automation-id=\"tui-pagination__element\" class=\"dots\"></div>\n </ng-template>\n</div>\n", changeDetection: ChangeDetectionStrategy.OnPush, providers: [ { provide: TUI_FOCUSABLE_ITEM_ACCESSOR, useExisting: forwardRef(() => TuiPaginationComponent_1), }, ], styles: [":host{font:var(--tui-font-text-s);color:var(--tui-text-01);display:block;text-align:center}.content{display:flex;justify-content:center}.button{margin:0 2px;flex-shrink:0}.button_active{background:currentColor}.button.button.button_small{width:8px;height:8px;margin:0}.button.button.button_small:not(:first-child){margin-left:8px}.dots{width:var(--tui-height-s);height:var(--tui-height-s);line-height:var(--tui-height-s);margin:0 2px;flex-shrink:0;color:var(--tui-text-03);text-align:center;cursor:default}.dots:before{content:'\\2026'}"] }), __param(0, Inject(ElementRef)), __param(1, Optional()), __param(1, Inject(TuiModeDirective)), __param(2, Inject(TUI_PAGINATION_TEXTS)) ], TuiPaginationComponent); export { TuiPaginationComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pagination.component.js","sourceRoot":"ng://@taiga-ui/kit/components/pagination/","sources":["pagination.component.ts"],"names":[],"mappings":";;AAAA,OAAO,EACH,uBAAuB,EACvB,SAAS,EACT,UAAU,EACV,YAAY,EACZ,UAAU,EACV,MAAM,EACN,KAAK,EACL,QAAQ,EACR,MAAM,EACN,SAAS,EACT,YAAY,GACf,MAAM,eAAe,CAAC;AACvB,OAAO,EACH,sBAAsB,EACtB,KAAK,EACL,WAAW,EACX,iBAAiB,EACjB,gBAAgB,EAChB,2BAA2B,EAE3B,cAAc,GAGjB,MAAM,eAAe,CAAC;AACvB,OAAO,EACH,aAAa,EACb,aAAa,EACb,kBAAkB,EAClB,sBAAsB,EACtB,gBAAgB,EAChB,QAAQ,GACX,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAC,oBAAoB,EAAC,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAC,2BAA2B,EAAC,MAAM,0BAA0B,CAAC;AAErE,OAAO,EAAC,UAAU,EAAC,MAAM,MAAM,CAAC;AAEhC,MAAM,WAAW,GAAG,CAAC,CAAC;AACtB,MAAM,kBAAkB,GAAG,CAAC,CAAC;AAE7B,MAAM,UAAU,kBAAkB,CAAC,MAAc;IAC7C,OAAO,MAAM,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,MAAM,IAAI,CAAC,CAAC;AACnD,CAAC;AAED,WAAW;AAaX,IAAa,sBAAsB,8BAAnC,MAAa,sBACT,SAAQ,sBAAsB;IAgD9B,YACyC,UAAmC,EAGvD,aAAsC,EAChB,MAAoC;QAE3E,KAAK,EAAE,CAAC;QAN6B,eAAU,GAAV,UAAU,CAAyB;QAGvD,kBAAa,GAAb,aAAa,CAAyB;QAChB,WAAM,GAAN,MAAM,CAA8B;QAjD/E,WAAM,GAAG,CAAC,CAAC;QAIX,SAAI,GAAa,GAAG,CAAC;QAIZ,aAAQ,GAAG,KAAK,CAAC;QAE1B;;WAEG;QAGH,kBAAa,GAAG,CAAC,CAAC;QAElB;;WAEG;QAGH,gBAAW,GAAG,CAAC,CAAC;QAEhB;;WAEG;QAGH,YAAO,GAA+D,IAAI,CAAC;QAE3E;;WAEG;QAGH,UAAK,GAAG,CAAC,CAAC;QAGD,gBAAW,GAAG,IAAI,YAAY,EAAU,CAAC;QAGjC,aAAQ,GAA2C,WAAW,CAAC;IAUhF,CAAC;IAED,IAAI,sBAAsB;QACtB,IAAI,IAAI,CAAC,QAAQ,EAAE;YACf,OAAO,IAAI,CAAC;SACf;QAED,IAAI,kBAAkB,GAAG,CAAC,CAAC;QAC3B,MAAM,EAAC,cAAc,EAAC,GAAG,IAAI,CAAC;QAE9B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,cAAc,EAAE,CAAC,EAAE,EAAE;YACrC,MAAM,SAAS,GAAG,IAAI,CAAC,0BAA0B,CAAC,CAAC,CAAC,CAAC;YAErD,IAAI,SAAS,EAAE;gBACX,kBAAkB,EAAE,CAAC;aACxB;YAED,IAAI,SAAS,KAAK,IAAI,CAAC,KAAK,EAAE;gBAC1B,MAAM;aACT;SACJ;QAED,MAAM,aAAa,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CACpC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,CAAC,KAAK,KAAK,kBAAkB,CAC7C,CAAC;QAEF,OAAO,aAAa,CAAC,CAAC,CAAC,aAAa,CAAC,sBAAsB,CAAC,CAAC,CAAC,IAAI,CAAC;IACvE,CAAC;IAED,IAAI,OAAO;QACP,OAAO,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;IAC5D,CAAC;IAED;;OAEG;IACH,IAAI,cAAc;QACd,OAAO,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC;IAChE,CAAC;IAED,IAAI,KAAK;QACL,OAAO,IAAI,CAAC,IAAI,KAAK,GAAG,CAAC;IAC7B,CAAC;IAED,IAAI,IAAI;QACJ,OAAO,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;IAC/D,CAAC;IAED,IAAI,mBAAmB;QACnB,OAAO,IAAI,CAAC,KAAK,KAAK,CAAC,CAAC;IAC5B,CAAC;IAED,IAAI,oBAAoB;QACpB,OAAO,IAAI,CAAC,YAAY,KAAK,CAAC,CAAC;IACnC,CAAC;IAED,kBAAkB,CAAC,KAAa;QAC5B,OAAO,IAAI,CAAC,KAAK,KAAK,KAAK,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC;IACjD,CAAC;IAED,cAAc,CAAC,KAAa;QACxB,OAAO,EAAC,SAAS,EAAE,KAAK,EAAC,CAAC;IAC9B,CAAC;IAED;;;;OAIG;IACH,0BAA0B,CAAC,YAAoB;QAC3C,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;YACb,OAAO,YAAY,CAAC;SACvB;QAED,IAAI,YAAY,GAAG,IAAI,CAAC,WAAW,EAAE;YACjC,OAAO,YAAY,CAAC;SACvB;QAED,IAAI,YAAY,KAAK,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;YACzE,OAAO,IAAI,CAAC;SACf;QAED,MAAM,mBAAmB,GAAG,IAAI,CAAC,gBAAgB,GAAG,YAAY,CAAC;QAEjE,IACI,mBAAmB,KAAK,IAAI,CAAC,WAAW;YACxC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,YAAY,CAAC,EAC3C;YACE,OAAO,IAAI,CAAC;SACf;QAED,IAAI,mBAAmB,GAAG,IAAI,CAAC,WAAW,EAAE;YACxC,OAAO,IAAI,CAAC,SAAS,GAAG,mBAAmB,CAAC;SAC/C;QAED,MAAM,aAAa,GAAG,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,aAAa,GAAG,YAAY,CAAC;QAErE,OAAO,KAAK,CAAC,aAAa,EAAE,YAAY,EAAE,IAAI,CAAC,SAAS,GAAG,mBAAmB,CAAC,CAAC;IACpF,CAAC;IAED,cAAc,CAAC,KAAa;QACxB,OAAO,IAAI,CAAC,KAAK,KAAK,KAAK,CAAC,CAAC,yBAAuB,CAAC,kBAAmB,CAAC;IAC7E,CAAC;IAED,mBAAmB,CAAC,KAAa,EAAE,IAA0B;QACzD,OAAO,IAAI,CAAC,KAAK,KAAK,KAAK,IAAI,IAAI,KAAK,SAAS;YAC7C,CAAC;YACD,CAAC,4BAAwB,CAAC;IAClC,CAAC;IAED,cAAc,CAAC,KAAa;QACxB,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;IAC5B,CAAC;IAED,yBAAyB,CAAC,OAA2B;QACjD,IAAI,OAAO,KAAK,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE;YACjC,OAAO;SACV;QAED,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAC/B,CAAC,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK,OAAO,CACpD,CAAC;QAEF,IAAI,QAAQ,IAAI,QAAQ,CAAC,sBAAsB,EAAE;YAC7C,gBAAgB,CAAC,QAAQ,CAAC,sBAAsB,CAAC,CAAC;SACrD;IACL,CAAC;IAED,0BAA0B,CAAC,OAA2B;QAClD,IAAI,OAAO,KAAK,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE;YAChC,OAAO;SACV;QAED,MAAM,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAC3B,CAAC,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK,OAAO,CACpD,CAAC;QAEF,IAAI,IAAI,IAAI,IAAI,CAAC,sBAAsB,EAAE;YACrC,gBAAgB,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;SACjD;IACL,CAAC;IAED,YAAY,CAAC,SAAiC;QAC1C,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC;QAC5B,IAAI,CAAC,WAAW,EAAE,CAAC;IACvB,CAAC;IAED,YAAY,CAAC,OAAgB;QACzB,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;IAChC,CAAC;IAED;;OAEG;IACH,IAAY,YAAY;QACpB,OAAO,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC;IACvC,CAAC;IAED;;OAEG;IACH,IAAY,aAAa;QACrB,OAAO,IAAI,CAAC,WAAW,GAAG,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC;IAC/D,CAAC;IAED;;OAEG;IACH,IAAY,QAAQ;QAChB,OAAO,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,iBAAiB,CAAC;IACjD,CAAC;IAED;;OAEG;IACH,IAAY,iBAAiB;QACzB,OAAO,IAAI,CAAC,aAAa,GAAG,CAAC,GAAG,kBAAkB,CAAC;IACvD,CAAC;IAED,IAAY,SAAS;QACjB,OAAO,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;IAC3B,CAAC;IAED,IAAY,gBAAgB;QACxB,OAAO,IAAI,CAAC,cAAc,GAAG,CAAC,CAAC;IACnC,CAAC;IAED;;;;OAIG;IACK,iBAAiB,CAAC,KAAa;QACnC,OAAO,CAAC,IAAI,CAAC,QAAQ,IAAI,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC;IACxD,CAAC;IAEO,WAAW,CAAC,SAAiC;QACjD,IAAI,CAAC,WAAW,CACZ,KAAK,CAAC,IAAI,CAAC,KAAK,GAAG,2BAA2B,CAAC,SAAS,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC,CAChF,CAAC;IACN,CAAC;IAEO,WAAW;QACf,MAAM,EAAC,sBAAsB,EAAC,GAAG,IAAI,CAAC;QAEtC,IAAI,sBAAsB,EAAE;YACxB,gBAAgB,CAAC,sBAAsB,CAAC,CAAC;SAC5C;IACL,CAAC;IAEO,WAAW,CAAC,KAAa;QAC7B,IAAI,IAAI,CAAC,KAAK,KAAK,KAAK,EAAE;YACtB,OAAO;SACV;QAED,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;CACJ,CAAA;;YAjOwD,UAAU,uBAA1D,MAAM,SAAC,UAAU;YAGc,gBAAgB,uBAF/C,QAAQ,YACR,MAAM,SAAC,gBAAgB;YAEuB,UAAU,uBAAxD,MAAM,SAAC,oBAAoB;;AAjDhC;IAFC,KAAK,EAAE;IACP,cAAc,CAAC,kBAAkB,EAAE,8BAA8B,CAAC;sDACxD;AAIX;IAFC,KAAK,EAAE;IACP,cAAc,EAAE;oDACI;AAIrB;IAFC,KAAK,EAAE;IACP,cAAc,EAAE;wDACS;AAO1B;IAFC,KAAK,EAAE;IACP,cAAc,EAAE;6DACC;AAOlB;IAFC,KAAK,EAAE;IACP,cAAc,EAAE;2DACD;AAOhB;IAFC,KAAK,EAAE;IACP,cAAc,EAAE;uDAC0D;AAO3E;IAFC,KAAK,EAAE;IACP,cAAc,CAAC,kBAAkB,EAAE,8BAA8B,CAAC;qDACzD;AAGV;IADC,MAAM,EAAE;2DACyC;AAGlD;IADC,YAAY,CAAC,SAAS,EAAE,EAAC,IAAI,EAAE,2BAA2B,EAAC,CAAC;wDACmB;AA/CvE,sBAAsB;IAZlC,SAAS,CAAC;QACP,QAAQ,EAAE,gBAAgB;QAC1B,+nGAAyC;QAEzC,eAAe,EAAE,uBAAuB,CAAC,MAAM;QAC/C,SAAS,EAAE;YACP;gBACI,OAAO,EAAE,2BAA2B;gBACpC,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,wBAAsB,CAAC;aACxD;SACJ;;KACJ,CAAC;IAmDO,WAAA,MAAM,CAAC,UAAU,CAAC,CAAA;IAClB,WAAA,QAAQ,EAAE,CAAA;IACV,WAAA,MAAM,CAAC,gBAAgB,CAAC,CAAA;IAExB,WAAA,MAAM,CAAC,oBAAoB,CAAC,CAAA;GAtDxB,sBAAsB,CAmRlC;SAnRY,sBAAsB","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    Inject,\n    Input,\n    Optional,\n    Output,\n    QueryList,\n    ViewChildren,\n} from '@angular/core';\nimport {\n    AbstractTuiInteractive,\n    clamp,\n    EMPTY_QUERY,\n    isNativeFocusedIn,\n    setNativeFocused,\n    TUI_FOCUSABLE_ITEM_ACCESSOR,\n    TuiContextWithImplicit,\n    tuiDefaultProp,\n    TuiFocusableElementAccessor,\n    TuiNativeFocusableElement,\n} from '@taiga-ui/cdk';\nimport {\n    TuiAppearance,\n    TuiBrightness,\n    TuiButtonComponent,\n    TuiHorizontalDirection,\n    TuiModeDirective,\n    TuiSizeS,\n} from '@taiga-ui/core';\nimport {TUI_PAGINATION_TEXTS} from '@taiga-ui/kit/tokens';\nimport {horizontalDirectionToNumber} from '@taiga-ui/kit/utils/math';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\nimport {Observable} from 'rxjs';\n\nconst DOTS_LENGTH = 1;\nconst ACTIVE_ITEM_LENGTH = 1;\n\nexport function nonNegativeInteger(length: number): boolean {\n    return Number.isInteger(length) && length >= 0;\n}\n\n// @dynamic\n@Component({\n    selector: 'tui-pagination',\n    templateUrl: './pagination.template.html',\n    styleUrls: ['./pagination.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        {\n            provide: TUI_FOCUSABLE_ITEM_ACCESSOR,\n            useExisting: forwardRef(() => TuiPaginationComponent),\n        },\n    ],\n})\nexport class TuiPaginationComponent\n    extends AbstractTuiInteractive\n    implements TuiFocusableElementAccessor {\n    @Input()\n    @tuiDefaultProp(nonNegativeInteger, 'Must be non-negative integer')\n    length = 1;\n\n    @Input()\n    @tuiDefaultProp()\n    size: TuiSizeS = 'm';\n\n    @Input()\n    @tuiDefaultProp()\n    readonly disabled = false;\n\n    /**\n     * Amount of visible pages around active page\n     */\n    @Input()\n    @tuiDefaultProp()\n    activePadding = 1;\n\n    /**\n     * Amount of visible pages at the edges\n     */\n    @Input()\n    @tuiDefaultProp()\n    sidePadding = 1;\n\n    /**\n     * Customization for page number display.\n     */\n    @Input()\n    @tuiDefaultProp()\n    content: PolymorpheusContent<TuiContextWithImplicit<number>> | null = null;\n\n    /**\n     * Active page index\n     */\n    @Input()\n    @tuiDefaultProp(nonNegativeInteger, 'Must be non-negative integer')\n    index = 0;\n\n    @Output()\n    readonly indexChange = new EventEmitter<number>();\n\n    @ViewChildren('element', {read: TUI_FOCUSABLE_ITEM_ACCESSOR})\n    private readonly elements: QueryList<TuiFocusableElementAccessor> = EMPTY_QUERY;\n\n    constructor(\n        @Inject(ElementRef) private readonly elementRef: ElementRef<HTMLElement>,\n        @Optional()\n        @Inject(TuiModeDirective)\n        private readonly modeDirective: TuiModeDirective | null,\n        @Inject(TUI_PAGINATION_TEXTS) readonly texts$: Observable<[string, string]>,\n    ) {\n        super();\n    }\n\n    get nativeFocusableElement(): TuiNativeFocusableElement | null {\n        if (this.disabled) {\n            return null;\n        }\n\n        let activeElementIndex = 0;\n        const {elementsLength} = this;\n\n        for (let i = 0; i < elementsLength; i++) {\n            const itemIndex = this.getItemIndexByElementIndex(i);\n\n            if (itemIndex) {\n                activeElementIndex++;\n            }\n\n            if (itemIndex === this.index) {\n                break;\n            }\n        }\n\n        const activeElement = this.elements.find(\n            (_, index) => index === activeElementIndex,\n        );\n\n        return activeElement ? activeElement.nativeFocusableElement : null;\n    }\n\n    get focused(): boolean {\n        return isNativeFocusedIn(this.elementRef.nativeElement);\n    }\n\n    /**\n     * Number of items in a container.\n     */\n    get elementsLength(): number {\n        return this.itemsFit ? this.length : this.maxElementsLength;\n    }\n\n    get sizeM(): boolean {\n        return this.size === 'm';\n    }\n\n    get mode(): TuiBrightness | null {\n        return this.modeDirective ? this.modeDirective.mode : null;\n    }\n\n    get arrowIsDisabledLeft(): boolean {\n        return this.index === 0;\n    }\n\n    get arrowIsDisabledRight(): boolean {\n        return this.reverseIndex === 0;\n    }\n\n    elementIsFocusable(index: number): boolean {\n        return this.index === index && !this.focused;\n    }\n\n    getItemContext(index: number): TuiContextWithImplicit<number> {\n        return {$implicit: index};\n    }\n\n    /**\n     * Get index by element index\n     * @param elementIndex\n     * @returns index or null (for '…')\n     */\n    getItemIndexByElementIndex(elementIndex: number): number | null {\n        if (!this.sizeM) {\n            return elementIndex;\n        }\n\n        if (elementIndex < this.sidePadding) {\n            return elementIndex;\n        }\n\n        if (elementIndex === this.sidePadding && this.hasCollapsedItems(this.index)) {\n            return null;\n        }\n\n        const reverseElementIndex = this.lastElementIndex - elementIndex;\n\n        if (\n            reverseElementIndex === this.sidePadding &&\n            this.hasCollapsedItems(this.reverseIndex)\n        ) {\n            return null;\n        }\n\n        if (reverseElementIndex < this.sidePadding) {\n            return this.lastIndex - reverseElementIndex;\n        }\n\n        const computedIndex = this.index - this.maxHalfLength + elementIndex;\n\n        return clamp(computedIndex, elementIndex, this.lastIndex - reverseElementIndex);\n    }\n\n    getElementMode(index: number): TuiAppearance {\n        return this.index === index ? TuiAppearance.Primary : TuiAppearance.Flat;\n    }\n\n    getSmallElementMode(index: number, mode: TuiBrightness | null): TuiAppearance {\n        return this.index === index && mode !== 'onLight'\n            ? TuiAppearance.Primary\n            : TuiAppearance.Secondary;\n    }\n\n    onElementClick(index: number) {\n        this.updateIndex(index);\n    }\n\n    onElementKeyDownArrowLeft(element: TuiButtonComponent) {\n        if (element === this.elements.first) {\n            return;\n        }\n\n        const previous = this.elements.find(\n            (_, index, array) => array[index + 1] === element,\n        );\n\n        if (previous && previous.nativeFocusableElement) {\n            setNativeFocused(previous.nativeFocusableElement);\n        }\n    }\n\n    onElementKeyDownArrowRight(element: TuiButtonComponent) {\n        if (element === this.elements.last) {\n            return;\n        }\n\n        const next = this.elements.find(\n            (_, index, array) => array[index - 1] === element,\n        );\n\n        if (next && next.nativeFocusableElement) {\n            setNativeFocused(next.nativeFocusableElement);\n        }\n    }\n\n    onArrowClick(direction: TuiHorizontalDirection) {\n        this.tryChangeTo(direction);\n        this.focusActive();\n    }\n\n    onActiveZone(focused: boolean) {\n        this.updateFocused(focused);\n    }\n\n    /**\n     * Active index from the end\n     */\n    private get reverseIndex(): number {\n        return this.lastIndex - this.index;\n    }\n\n    /**\n     * Max number of elements in half (not counting the middle one).\n     */\n    private get maxHalfLength(): number {\n        return this.sidePadding + DOTS_LENGTH + this.activePadding;\n    }\n\n    /**\n     * Is there '...' anywhere\n     */\n    private get itemsFit(): boolean {\n        return this.length <= this.maxElementsLength;\n    }\n\n    /**\n     * Max number of elements\n     */\n    private get maxElementsLength(): number {\n        return this.maxHalfLength * 2 + ACTIVE_ITEM_LENGTH;\n    }\n\n    private get lastIndex(): number {\n        return this.length - 1;\n    }\n\n    private get lastElementIndex(): number {\n        return this.elementsLength - 1;\n    }\n\n    /**\n     * Are there collapsed items at that index\n     * @param index\n     * @returns there are collapsed items\n     */\n    private hasCollapsedItems(index: number): boolean {\n        return !this.itemsFit && index > this.maxHalfLength;\n    }\n\n    private tryChangeTo(direction: TuiHorizontalDirection) {\n        this.updateIndex(\n            clamp(this.index + horizontalDirectionToNumber(direction), 0, this.lastIndex),\n        );\n    }\n\n    private focusActive() {\n        const {nativeFocusableElement} = this;\n\n        if (nativeFocusableElement) {\n            setNativeFocused(nativeFocusableElement);\n        }\n    }\n\n    private updateIndex(index: number) {\n        if (this.index === index) {\n            return;\n        }\n\n        this.index = index;\n        this.indexChange.emit(index);\n    }\n}\n"]}