@taiga-ui/kit
Version:
Taiga UI Angular main components kit
263 lines • 33 kB
JavaScript
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":"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","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"]}