UNPKG

@taiga-ui/kit

Version:
319 lines 36.6 kB
import { __decorate, __extends, __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'; var DOTS_LENGTH = 1; var ACTIVE_ITEM_LENGTH = 1; export function nonNegativeInteger(length) { return Number.isInteger(length) && length >= 0; } // @dynamic var TuiPaginationComponent = /** @class */ (function (_super) { __extends(TuiPaginationComponent, _super); function TuiPaginationComponent(elementRef, modeDirective, texts$) { var _this = _super.call(this) || this; _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; return _this; } TuiPaginationComponent_1 = TuiPaginationComponent; Object.defineProperty(TuiPaginationComponent.prototype, "nativeFocusableElement", { get: function () { if (this.disabled) { return null; } var activeElementIndex = 0; var elementsLength = this.elementsLength; for (var i = 0; i < elementsLength; i++) { var itemIndex = this.getItemIndexByElementIndex(i); if (itemIndex) { activeElementIndex++; } if (itemIndex === this.index) { break; } } var activeElement = this.elements.find(function (_, index) { return index === activeElementIndex; }); return activeElement ? activeElement.nativeFocusableElement : null; }, enumerable: true, configurable: true }); Object.defineProperty(TuiPaginationComponent.prototype, "focused", { get: function () { return isNativeFocusedIn(this.elementRef.nativeElement); }, enumerable: true, configurable: true }); Object.defineProperty(TuiPaginationComponent.prototype, "elementsLength", { /** * Number of items in a container. */ get: function () { return this.itemsFit ? this.length : this.maxElementsLength; }, enumerable: true, configurable: true }); Object.defineProperty(TuiPaginationComponent.prototype, "sizeM", { get: function () { return this.size === 'm'; }, enumerable: true, configurable: true }); Object.defineProperty(TuiPaginationComponent.prototype, "mode", { get: function () { return this.modeDirective ? this.modeDirective.mode : null; }, enumerable: true, configurable: true }); Object.defineProperty(TuiPaginationComponent.prototype, "arrowIsDisabledLeft", { get: function () { return this.index === 0; }, enumerable: true, configurable: true }); Object.defineProperty(TuiPaginationComponent.prototype, "arrowIsDisabledRight", { get: function () { return this.reverseIndex === 0; }, enumerable: true, configurable: true }); TuiPaginationComponent.prototype.elementIsFocusable = function (index) { return this.index === index && !this.focused; }; TuiPaginationComponent.prototype.getItemContext = function (index) { return { $implicit: index }; }; /** * Get index by element index * @param elementIndex * @returns index or null (for '…') */ TuiPaginationComponent.prototype.getItemIndexByElementIndex = function (elementIndex) { if (!this.sizeM) { return elementIndex; } if (elementIndex < this.sidePadding) { return elementIndex; } if (elementIndex === this.sidePadding && this.hasCollapsedItems(this.index)) { return null; } var reverseElementIndex = this.lastElementIndex - elementIndex; if (reverseElementIndex === this.sidePadding && this.hasCollapsedItems(this.reverseIndex)) { return null; } if (reverseElementIndex < this.sidePadding) { return this.lastIndex - reverseElementIndex; } var computedIndex = this.index - this.maxHalfLength + elementIndex; return clamp(computedIndex, elementIndex, this.lastIndex - reverseElementIndex); }; TuiPaginationComponent.prototype.getElementMode = function (index) { return this.index === index ? "primary" /* Primary */ : "flat" /* Flat */; }; TuiPaginationComponent.prototype.getSmallElementMode = function (index, mode) { return this.index === index && mode !== 'onLight' ? "primary" /* Primary */ : "secondary" /* Secondary */; }; TuiPaginationComponent.prototype.onElementClick = function (index) { this.updateIndex(index); }; TuiPaginationComponent.prototype.onElementKeyDownArrowLeft = function (element) { if (element === this.elements.first) { return; } var previous = this.elements.find(function (_, index, array) { return array[index + 1] === element; }); if (previous && previous.nativeFocusableElement) { setNativeFocused(previous.nativeFocusableElement); } }; TuiPaginationComponent.prototype.onElementKeyDownArrowRight = function (element) { if (element === this.elements.last) { return; } var next = this.elements.find(function (_, index, array) { return array[index - 1] === element; }); if (next && next.nativeFocusableElement) { setNativeFocused(next.nativeFocusableElement); } }; TuiPaginationComponent.prototype.onArrowClick = function (direction) { this.tryChangeTo(direction); this.focusActive(); }; TuiPaginationComponent.prototype.onActiveZone = function (focused) { this.updateFocused(focused); }; Object.defineProperty(TuiPaginationComponent.prototype, "reverseIndex", { /** * Active index from the end */ get: function () { return this.lastIndex - this.index; }, enumerable: true, configurable: true }); Object.defineProperty(TuiPaginationComponent.prototype, "maxHalfLength", { /** * Max number of elements in half (not counting the middle one). */ get: function () { return this.sidePadding + DOTS_LENGTH + this.activePadding; }, enumerable: true, configurable: true }); Object.defineProperty(TuiPaginationComponent.prototype, "itemsFit", { /** * Is there '...' anywhere */ get: function () { return this.length <= this.maxElementsLength; }, enumerable: true, configurable: true }); Object.defineProperty(TuiPaginationComponent.prototype, "maxElementsLength", { /** * Max number of elements */ get: function () { return this.maxHalfLength * 2 + ACTIVE_ITEM_LENGTH; }, enumerable: true, configurable: true }); Object.defineProperty(TuiPaginationComponent.prototype, "lastIndex", { get: function () { return this.length - 1; }, enumerable: true, configurable: true }); Object.defineProperty(TuiPaginationComponent.prototype, "lastElementIndex", { get: function () { return this.elementsLength - 1; }, enumerable: true, configurable: true }); /** * Are there collapsed items at that index * @param index * @returns there are collapsed items */ TuiPaginationComponent.prototype.hasCollapsedItems = function (index) { return !this.itemsFit && index > this.maxHalfLength; }; TuiPaginationComponent.prototype.tryChangeTo = function (direction) { this.updateIndex(clamp(this.index + horizontalDirectionToNumber(direction), 0, this.lastIndex)); }; TuiPaginationComponent.prototype.focusActive = function () { var nativeFocusableElement = this.nativeFocusableElement; if (nativeFocusableElement) { setNativeFocused(nativeFocusableElement); } }; TuiPaginationComponent.prototype.updateIndex = function (index) { if (this.index === index) { return; } this.index = index; this.indexChange.emit(index); }; var TuiPaginationComponent_1; TuiPaginationComponent.ctorParameters = function () { return [ { 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(function () { return 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); return TuiPaginationComponent; }(AbstractTuiInteractive)); 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"]}