@taiga-ui/kit
Version:
Taiga UI Angular main components kit
213 lines • 44.2 kB
JavaScript
import { AsyncPipe, NgFor, NgIf, NgTemplateOutlet } from '@angular/common';
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChildren, ElementRef, EventEmitter, inject, Input, Output, TemplateRef, ViewChild, } from '@angular/core';
import { EMPTY_QUERY } from '@taiga-ui/cdk/constants';
import { TuiItem } from '@taiga-ui/cdk/directives/item';
import { tuiInjectElement, tuiIsElement } from '@taiga-ui/cdk/utils/dom';
import { tuiGetClosestFocusable, tuiIsNativeFocused } from '@taiga-ui/cdk/utils/focus';
import { tuiClamp, tuiToInt } from '@taiga-ui/cdk/utils/math';
import { tuiPx } from '@taiga-ui/cdk/utils/miscellaneous';
import { TuiDropdown } from '@taiga-ui/core/directives/dropdown';
import { TuiChevron } from '@taiga-ui/kit/directives/chevron';
import { TUI_MORE_WORD } from '@taiga-ui/kit/tokens';
import { PolymorpheusOutlet } from '@taiga-ui/polymorpheus';
import { filter, map, tap } from 'rxjs';
import { TuiTab } from './tab.directive';
import { TUI_TABS_OPTIONS } from './tabs.options';
import { TUI_TABS_PROVIDERS, TUI_TABS_REFRESH } from './tabs.providers';
import { TuiTabsHorizontal } from './tabs-horizontal.directive';
import * as i0 from "@angular/core";
import * as i1 from "@taiga-ui/core/directives/dropdown";
class TuiTabsWithMore {
constructor() {
this.options = inject(TUI_TABS_OPTIONS);
this.refresh$ = inject(TUI_TABS_REFRESH);
this.el = tuiInjectElement();
this.cdr = inject(ChangeDetectorRef);
this.maxIndex = Infinity;
this.items = EMPTY_QUERY;
this.moreWord$ = inject(TUI_MORE_WORD);
this.size = this.options.size;
this.underline = this.options.underline;
this.itemsLimit = this.options.itemsLimit;
this.activeItemIndexChange = new EventEmitter();
this.open = false;
this.activeItemIndex = 0;
}
set itemIndex(activeItemIndex) {
this.activeItemIndex = activeItemIndex;
this.maxIndex = this.getMaxIndex();
}
get lastVisibleIndex() {
if (this.itemsLimit + 1 >= this.items.length) {
return this.maxIndex;
}
const offset = this.itemsLimit - 1 > this.activeItemIndex || !this.options.exposeActive
? 1
: 2;
return Math.min(this.itemsLimit - offset, this.maxIndex);
}
isOverflown(index) {
return index !== this.activeItemIndex || !this.options.exposeActive;
}
shouldShow(index) {
return index > this.lastVisibleIndex && this.isOverflown(index);
}
ngAfterViewInit() {
this.refresh$
.pipe(map(() => this.getMaxIndex()), tap(() => this.refresh()), filter((maxIndex) => this.maxIndex !== maxIndex))
.subscribe((maxIndex) => {
this.maxIndex = maxIndex;
this.cdr.detectChanges();
});
}
ngAfterViewChecked() {
this.refresh();
}
// TODO: Improve performance
get tabs() {
return Array.from(this.el.querySelectorAll('[tuiTab]'));
}
get activeElement() {
const { tabs } = this;
const safeActiveIndex = tuiClamp(this.activeItemIndex || 0, 0, tabs.length - 2);
return this.options.exposeActive || this.lastVisibleIndex >= safeActiveIndex
? tabs[safeActiveIndex] || null
: this.moreButton?.nativeElement || null;
}
get isMoreAlone() {
return this.lastVisibleIndex < 0 && !this.options.exposeActive;
}
get isMoreVisible() {
return this.lastVisibleIndex < this.items.length - 1;
}
get isMoreFocusable() {
return !!this.moreButton && tuiIsNativeFocused(this.moreButton.nativeElement);
}
get isMoreActive() {
return (this.open ||
(!this.options.exposeActive && this.lastVisibleIndex < this.activeItemIndex));
}
onActiveItemIndexChange(activeItemIndex) {
this.updateActiveItemIndex(activeItemIndex);
}
onClick(index) {
this.open = false;
this.focusMore();
this.updateActiveItemIndex(index);
}
onArrowRight(event) {
if (tuiIsElement(event.target) && tuiIsNativeFocused(event.target)) {
this.focusMore();
}
}
onArrowLeft() {
const { tabs } = this;
let index = tabs.length - 2;
while (index >= 0) {
tabs[index]?.focus();
if (tuiIsNativeFocused(tabs[index])) {
return;
}
index--;
}
}
onWrapperArrow(event, wrapper, previous) {
const button = event.target;
const target = tuiGetClosestFocusable({ initial: button, root: wrapper, previous });
if (target) {
target.focus();
}
}
get margin() {
return this.size === 'l' ? 24 : 16;
}
focusMore() {
if (this.moreButton) {
this.moreButton.nativeElement.focus();
}
}
getMaxIndex() {
const { tabs, activeItemIndex, margin } = this;
if (tabs.length < 2) {
return 0;
}
const { exposeActive, minMoreWidth } = this.options;
const { clientWidth } = this.el;
const active = tabs[activeItemIndex];
const activeWidth = active?.scrollWidth ?? 0;
const moreWidth = Math.max(tabs[tabs.length - 1]?.scrollWidth ?? 0, minMoreWidth);
let maxIndex = tabs.length - 2;
let total = tabs.reduce((acc, { scrollWidth }) => acc + scrollWidth, 0) +
maxIndex * margin -
(tabs[tabs.length - 1]?.scrollWidth ?? 0);
if (Number.isNaN(total) || total <= clientWidth) {
return Infinity;
}
while (maxIndex) {
total -= (tabs[maxIndex]?.scrollWidth ?? 0) + margin;
maxIndex--;
const activeDisplaced = exposeActive && activeItemIndex > maxIndex;
const activeOffset = activeDisplaced ? activeWidth + margin : 0;
const currentWidth = total + activeOffset + moreWidth + margin;
// Needed for different rounding of visible and hidden elements scrollWidth
const safetyOffset = tuiToInt(this.maxIndex === maxIndex - 1);
if (currentWidth + safetyOffset < clientWidth) {
return maxIndex;
}
}
return -1;
}
updateActiveItemIndex(activeItemIndex) {
this.itemIndex = activeItemIndex;
this.activeItemIndexChange.emit(activeItemIndex);
}
refresh() {
const { offsetLeft = 0, offsetWidth = 0 } = this.activeElement || {};
this.dir?.nativeElement.style.setProperty('--t-left', tuiPx(offsetLeft));
this.dir?.nativeElement.style.setProperty('--t-width', tuiPx(offsetWidth));
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiTabsWithMore, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiTabsWithMore, isStandalone: true, selector: "tui-tabs-with-more, nav[tuiTabsWithMore]", inputs: { size: "size", moreContent: "moreContent", dropdownContent: "dropdownContent", underline: "underline", itemsLimit: "itemsLimit", itemIndex: ["activeItemIndex", "itemIndex"] }, outputs: { activeItemIndexChange: "activeItemIndexChange" }, host: { properties: { "attr.data-size": "size" } }, providers: TUI_TABS_PROVIDERS, queries: [{ propertyName: "items", predicate: TuiItem, read: TemplateRef }], viewQueries: [{ propertyName: "moreButton", first: true, predicate: TuiTab, descendants: true, read: ElementRef }, { propertyName: "dir", first: true, predicate: TuiTabsHorizontal, descendants: true, read: ElementRef }], ngImport: i0, template: "<ng-container *ngIf=\"items.changes | async\" />\n<tui-tabs\n class=\"t-tabs\"\n [activeItemIndex]=\"activeItemIndex\"\n [size]=\"size\"\n [underline]=\"underline\"\n (activeItemIndexChange)=\"onActiveItemIndexChange($event)\"\n (keydown.arrowRight)=\"onArrowRight($event)\"\n>\n <ng-container *ngFor=\"let item of items; let index = index\">\n <ng-container\n *ngIf=\"index <= lastVisibleIndex; else hidden\"\n [ngTemplateOutlet]=\"item\"\n />\n <ng-template #hidden>\n <div\n class=\"t-flex\"\n [class.t-overflown]=\"isOverflown(index)\"\n >\n <ng-container [ngTemplateOutlet]=\"item\" />\n </div>\n </ng-template>\n </ng-container>\n</tui-tabs>\n\n<button\n *ngIf=\"moreContent; else chevron\"\n tuiTab\n type=\"button\"\n class=\"t-more\"\n [class._active]=\"isMoreActive\"\n [class.t-no-margin]=\"isMoreAlone\"\n [class.t-overflown]=\"!isMoreVisible\"\n [tabIndex]=\"isMoreFocusable ? 0 : -1\"\n [tuiDropdown]=\"dropdownContent || dropdown\"\n [(tuiDropdownOpen)]=\"open\"\n (keydown.arrowLeft.prevent)=\"onArrowLeft()\"\n>\n <ng-container *polymorpheusOutlet=\"moreContent as text\">\n {{ text }}\n </ng-container>\n</button>\n<ng-template #chevron>\n <button\n tuiChevron\n tuiTab\n type=\"button\"\n class=\"t-more\"\n [class._active]=\"isMoreActive\"\n [class.t-no-margin]=\"isMoreAlone\"\n [class.t-overflown]=\"!isMoreVisible\"\n [tabIndex]=\"isMoreFocusable ? 0 : -1\"\n [tuiDropdown]=\"dropdownContent || dropdown\"\n [(tuiDropdownOpen)]=\"open\"\n (keydown.arrowLeft.prevent)=\"onArrowLeft()\"\n >\n {{ moreWord$ | async }}\n </button>\n</ng-template>\n<ng-template #dropdown>\n <div\n #element\n class=\"t-dropdown\"\n [attr.data-size]=\"size\"\n (keydown.arrowDown.prevent)=\"onWrapperArrow($event, element, false)\"\n (keydown.arrowUp.prevent)=\"onWrapperArrow($event, element, true)\"\n >\n <div\n *ngFor=\"let item of items; let index = index\"\n class=\"t-dropdown-item\"\n (tui-tab-activate)=\"onClick(index)\"\n >\n <ng-container *ngIf=\"shouldShow(index)\">\n <ng-container *polymorpheusOutlet=\"item\" />\n </ng-container>\n </div>\n </div>\n</ng-template>\n\n<ng-content />\n", styles: [":host{position:relative;display:flex;font:var(--tui-font-text-m);box-sizing:border-box;color:var(--tui-text-secondary);box-shadow:inset 0 -1px var(--tui-border-normal);overflow:hidden}:host[data-size=m]{font:var(--tui-font-text-s)}.t-tabs{block-size:inherit;font:inherit;overflow:visible;box-shadow:none;color:inherit}.t-flex{display:flex}.t-overflown{margin:0;inline-size:0;max-inline-size:0;overflow:hidden;visibility:hidden}.t-icon{transition-property:transform;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;margin-inline-end:-.25rem;vertical-align:bottom}.t-icon_rotated{transform:rotate(180deg)}.t-dropdown{padding:.25rem 0}.t-dropdown ::ng-deep *[tuiTab]{inline-size:calc(100% - .75rem);block-size:2.75rem;justify-content:flex-start;margin:.125rem .375rem;padding:0 .625rem;line-height:1.5rem;border-radius:var(--tui-radius-s);font:var(--tui-font-text-m);color:var(--tui-text-primary)}.t-dropdown ::ng-deep *[tuiTab]:before{display:none}.t-dropdown ::ng-deep *[tuiTab]:hover,.t-dropdown ::ng-deep *[tuiTab]:focus,.t-dropdown ::ng-deep *[tuiTab]._active{box-shadow:none;outline:none;background:var(--tui-background-neutral-1)}.t-dropdown[data-size=m] ::ng-deep *[tuiTab]{block-size:2.25rem;font:var(--tui-font-text-s)}.t-dropdown-item{display:flex;flex-direction:column}.t-no-margin{margin-inline-start:0}\n"], dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: PolymorpheusOutlet, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }, { kind: "directive", type: TuiChevron, selector: "[tuiChevron]", inputs: ["tuiChevron"] }, { kind: "directive", type: i1.TuiDropdownDirective, selector: "[tuiDropdown]:not(ng-container):not(ng-template)", inputs: ["tuiDropdown"], exportAs: ["tuiDropdown"] }, { kind: "directive", type: i1.TuiDropdownOpen, selector: "[tuiDropdown][tuiDropdownOpen],[tuiDropdown][tuiDropdownOpenChange]", inputs: ["tuiDropdownEnabled", "tuiDropdownOpen"], outputs: ["tuiDropdownOpenChange"] }, { kind: "directive", type: TuiTab, selector: "a[tuiTab]:not([routerLink]), a[tuiTab][routerLink][routerLinkActive], button[tuiTab]" }, { kind: "directive", type: TuiTabsHorizontal, selector: "tui-tabs:not([vertical]), nav[tuiTabs]:not([vertical])", inputs: ["underline"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
}
export { TuiTabsWithMore };
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiTabsWithMore, decorators: [{
type: Component,
args: [{ standalone: true, selector: 'tui-tabs-with-more, nav[tuiTabsWithMore]', imports: [
AsyncPipe,
NgFor,
NgIf,
NgTemplateOutlet,
PolymorpheusOutlet,
TuiChevron,
TuiDropdown,
TuiTab,
TuiTabsHorizontal,
], changeDetection: ChangeDetectionStrategy.OnPush, providers: TUI_TABS_PROVIDERS, host: {
'[attr.data-size]': 'size',
}, template: "<ng-container *ngIf=\"items.changes | async\" />\n<tui-tabs\n class=\"t-tabs\"\n [activeItemIndex]=\"activeItemIndex\"\n [size]=\"size\"\n [underline]=\"underline\"\n (activeItemIndexChange)=\"onActiveItemIndexChange($event)\"\n (keydown.arrowRight)=\"onArrowRight($event)\"\n>\n <ng-container *ngFor=\"let item of items; let index = index\">\n <ng-container\n *ngIf=\"index <= lastVisibleIndex; else hidden\"\n [ngTemplateOutlet]=\"item\"\n />\n <ng-template #hidden>\n <div\n class=\"t-flex\"\n [class.t-overflown]=\"isOverflown(index)\"\n >\n <ng-container [ngTemplateOutlet]=\"item\" />\n </div>\n </ng-template>\n </ng-container>\n</tui-tabs>\n\n<button\n *ngIf=\"moreContent; else chevron\"\n tuiTab\n type=\"button\"\n class=\"t-more\"\n [class._active]=\"isMoreActive\"\n [class.t-no-margin]=\"isMoreAlone\"\n [class.t-overflown]=\"!isMoreVisible\"\n [tabIndex]=\"isMoreFocusable ? 0 : -1\"\n [tuiDropdown]=\"dropdownContent || dropdown\"\n [(tuiDropdownOpen)]=\"open\"\n (keydown.arrowLeft.prevent)=\"onArrowLeft()\"\n>\n <ng-container *polymorpheusOutlet=\"moreContent as text\">\n {{ text }}\n </ng-container>\n</button>\n<ng-template #chevron>\n <button\n tuiChevron\n tuiTab\n type=\"button\"\n class=\"t-more\"\n [class._active]=\"isMoreActive\"\n [class.t-no-margin]=\"isMoreAlone\"\n [class.t-overflown]=\"!isMoreVisible\"\n [tabIndex]=\"isMoreFocusable ? 0 : -1\"\n [tuiDropdown]=\"dropdownContent || dropdown\"\n [(tuiDropdownOpen)]=\"open\"\n (keydown.arrowLeft.prevent)=\"onArrowLeft()\"\n >\n {{ moreWord$ | async }}\n </button>\n</ng-template>\n<ng-template #dropdown>\n <div\n #element\n class=\"t-dropdown\"\n [attr.data-size]=\"size\"\n (keydown.arrowDown.prevent)=\"onWrapperArrow($event, element, false)\"\n (keydown.arrowUp.prevent)=\"onWrapperArrow($event, element, true)\"\n >\n <div\n *ngFor=\"let item of items; let index = index\"\n class=\"t-dropdown-item\"\n (tui-tab-activate)=\"onClick(index)\"\n >\n <ng-container *ngIf=\"shouldShow(index)\">\n <ng-container *polymorpheusOutlet=\"item\" />\n </ng-container>\n </div>\n </div>\n</ng-template>\n\n<ng-content />\n", styles: [":host{position:relative;display:flex;font:var(--tui-font-text-m);box-sizing:border-box;color:var(--tui-text-secondary);box-shadow:inset 0 -1px var(--tui-border-normal);overflow:hidden}:host[data-size=m]{font:var(--tui-font-text-s)}.t-tabs{block-size:inherit;font:inherit;overflow:visible;box-shadow:none;color:inherit}.t-flex{display:flex}.t-overflown{margin:0;inline-size:0;max-inline-size:0;overflow:hidden;visibility:hidden}.t-icon{transition-property:transform;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;margin-inline-end:-.25rem;vertical-align:bottom}.t-icon_rotated{transform:rotate(180deg)}.t-dropdown{padding:.25rem 0}.t-dropdown ::ng-deep *[tuiTab]{inline-size:calc(100% - .75rem);block-size:2.75rem;justify-content:flex-start;margin:.125rem .375rem;padding:0 .625rem;line-height:1.5rem;border-radius:var(--tui-radius-s);font:var(--tui-font-text-m);color:var(--tui-text-primary)}.t-dropdown ::ng-deep *[tuiTab]:before{display:none}.t-dropdown ::ng-deep *[tuiTab]:hover,.t-dropdown ::ng-deep *[tuiTab]:focus,.t-dropdown ::ng-deep *[tuiTab]._active{box-shadow:none;outline:none;background:var(--tui-background-neutral-1)}.t-dropdown[data-size=m] ::ng-deep *[tuiTab]{block-size:2.25rem;font:var(--tui-font-text-s)}.t-dropdown-item{display:flex;flex-direction:column}.t-no-margin{margin-inline-start:0}\n"] }]
}], propDecorators: { moreButton: [{
type: ViewChild,
args: [TuiTab, { read: ElementRef }]
}], dir: [{
type: ViewChild,
args: [TuiTabsHorizontal, { read: ElementRef }]
}], items: [{
type: ContentChildren,
args: [TuiItem, { read: TemplateRef }]
}], size: [{
type: Input
}], moreContent: [{
type: Input
}], dropdownContent: [{
type: Input
}], underline: [{
type: Input
}], itemsLimit: [{
type: Input
}], activeItemIndexChange: [{
type: Output
}], itemIndex: [{
type: Input,
args: ['activeItemIndex']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tabs-with-more.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/tabs/tabs-with-more.component.ts","../../../../../projects/kit/components/tabs/tabs-with-more.template.html"],"names":[],"mappings":"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","sourcesContent":["import {AsyncPipe, NgFor, NgIf, NgTemplateOutlet} from '@angular/common';\nimport {\n    type AfterViewChecked,\n    type AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChildren,\n    ElementRef,\n    EventEmitter,\n    inject,\n    Input,\n    Output,\n    type QueryList,\n    TemplateRef,\n    ViewChild,\n} from '@angular/core';\nimport {EMPTY_QUERY} from '@taiga-ui/cdk/constants';\nimport {type TuiActiveZone} from '@taiga-ui/cdk/directives/active-zone';\nimport {TuiItem} from '@taiga-ui/cdk/directives/item';\nimport {type TuiContext} from '@taiga-ui/cdk/types';\nimport {tuiInjectElement, tuiIsElement} from '@taiga-ui/cdk/utils/dom';\nimport {tuiGetClosestFocusable, tuiIsNativeFocused} from '@taiga-ui/cdk/utils/focus';\nimport {tuiClamp, tuiToInt} from '@taiga-ui/cdk/utils/math';\nimport {tuiPx} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {TuiDropdown} from '@taiga-ui/core/directives/dropdown';\nimport {type TuiSizeL} from '@taiga-ui/core/types';\nimport {TuiChevron} from '@taiga-ui/kit/directives/chevron';\nimport {TUI_MORE_WORD} from '@taiga-ui/kit/tokens';\nimport {type PolymorpheusContent, PolymorpheusOutlet} from '@taiga-ui/polymorpheus';\nimport {filter, map, tap} from 'rxjs';\n\nimport {TuiTab} from './tab.directive';\nimport {TUI_TABS_OPTIONS} from './tabs.options';\nimport {TUI_TABS_PROVIDERS, TUI_TABS_REFRESH} from './tabs.providers';\nimport {TuiTabsHorizontal} from './tabs-horizontal.directive';\n\n@Component({\n    standalone: true,\n    selector: 'tui-tabs-with-more, nav[tuiTabsWithMore]',\n    imports: [\n        AsyncPipe,\n        NgFor,\n        NgIf,\n        NgTemplateOutlet,\n        PolymorpheusOutlet,\n        TuiChevron,\n        TuiDropdown,\n        TuiTab,\n        TuiTabsHorizontal,\n    ],\n    templateUrl: './tabs-with-more.template.html',\n    styleUrls: ['./tabs-with-more.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: TUI_TABS_PROVIDERS,\n    host: {\n        '[attr.data-size]': 'size',\n    },\n})\nexport class TuiTabsWithMore implements AfterViewChecked, AfterViewInit {\n    @ViewChild(TuiTab, {read: ElementRef})\n    private readonly moreButton?: ElementRef<HTMLButtonElement>;\n\n    @ViewChild(TuiTabsHorizontal, {read: ElementRef})\n    private readonly dir?: ElementRef<HTMLButtonElement>;\n\n    private readonly options = inject(TUI_TABS_OPTIONS);\n    private readonly refresh$ = inject(TUI_TABS_REFRESH);\n    private readonly el = tuiInjectElement();\n    private readonly cdr = inject(ChangeDetectorRef);\n    private maxIndex = Infinity;\n\n    @ContentChildren(TuiItem, {read: TemplateRef})\n    protected readonly items: QueryList<TemplateRef<Record<string, unknown>>> =\n        EMPTY_QUERY;\n\n    protected readonly moreWord$ = inject(TUI_MORE_WORD);\n\n    @Input()\n    public size: TuiSizeL = this.options.size;\n\n    @Input()\n    public moreContent: PolymorpheusContent;\n\n    @Input()\n    public dropdownContent: PolymorpheusContent<TuiContext<TuiActiveZone>>;\n\n    @Input()\n    public underline = this.options.underline;\n\n    @Input()\n    public itemsLimit = this.options.itemsLimit;\n\n    @Output()\n    public readonly activeItemIndexChange = new EventEmitter<number>();\n\n    public open = false;\n\n    public activeItemIndex = 0;\n\n    @Input('activeItemIndex')\n    public set itemIndex(activeItemIndex: number) {\n        this.activeItemIndex = activeItemIndex;\n        this.maxIndex = this.getMaxIndex();\n    }\n\n    public get lastVisibleIndex(): number {\n        if (this.itemsLimit + 1 >= this.items.length) {\n            return this.maxIndex;\n        }\n\n        const offset =\n            this.itemsLimit - 1 > this.activeItemIndex || !this.options.exposeActive\n                ? 1\n                : 2;\n\n        return Math.min(this.itemsLimit - offset, this.maxIndex);\n    }\n\n    public isOverflown(index: number): boolean {\n        return index !== this.activeItemIndex || !this.options.exposeActive;\n    }\n\n    public shouldShow(index: number): boolean {\n        return index > this.lastVisibleIndex && this.isOverflown(index);\n    }\n\n    public ngAfterViewInit(): void {\n        this.refresh$\n            .pipe(\n                map(() => this.getMaxIndex()),\n                tap(() => this.refresh()),\n                filter((maxIndex) => this.maxIndex !== maxIndex),\n            )\n            .subscribe((maxIndex) => {\n                this.maxIndex = maxIndex;\n                this.cdr.detectChanges();\n            });\n    }\n\n    public ngAfterViewChecked(): void {\n        this.refresh();\n    }\n\n    // TODO: Improve performance\n    protected get tabs(): readonly HTMLElement[] {\n        return Array.from<HTMLElement>(this.el.querySelectorAll('[tuiTab]'));\n    }\n\n    protected get activeElement(): HTMLElement | null {\n        const {tabs} = this;\n        const safeActiveIndex = tuiClamp(this.activeItemIndex || 0, 0, tabs.length - 2);\n\n        return this.options.exposeActive || this.lastVisibleIndex >= safeActiveIndex\n            ? tabs[safeActiveIndex] || null\n            : this.moreButton?.nativeElement || null;\n    }\n\n    protected get isMoreAlone(): boolean {\n        return this.lastVisibleIndex < 0 && !this.options.exposeActive;\n    }\n\n    protected get isMoreVisible(): boolean {\n        return this.lastVisibleIndex < this.items.length - 1;\n    }\n\n    protected get isMoreFocusable(): boolean {\n        return !!this.moreButton && tuiIsNativeFocused(this.moreButton.nativeElement);\n    }\n\n    protected get isMoreActive(): boolean {\n        return (\n            this.open ||\n            (!this.options.exposeActive && this.lastVisibleIndex < this.activeItemIndex)\n        );\n    }\n\n    protected onActiveItemIndexChange(activeItemIndex: number): void {\n        this.updateActiveItemIndex(activeItemIndex);\n    }\n\n    protected onClick(index: number): void {\n        this.open = false;\n        this.focusMore();\n        this.updateActiveItemIndex(index);\n    }\n\n    protected onArrowRight(event: Event): void {\n        if (tuiIsElement(event.target) && tuiIsNativeFocused(event.target)) {\n            this.focusMore();\n        }\n    }\n\n    protected onArrowLeft(): void {\n        const {tabs} = this;\n        let index = tabs.length - 2;\n\n        while (index >= 0) {\n            tabs[index]?.focus();\n\n            if (tuiIsNativeFocused(tabs[index])) {\n                return;\n            }\n\n            index--;\n        }\n    }\n\n    protected onWrapperArrow(\n        event: Event,\n        wrapper: HTMLElement,\n        previous: boolean,\n    ): void {\n        const button: HTMLButtonElement = event.target as HTMLButtonElement;\n        const target = tuiGetClosestFocusable({initial: button, root: wrapper, previous});\n\n        if (target) {\n            target.focus();\n        }\n    }\n\n    private get margin(): number {\n        return this.size === 'l' ? 24 : 16;\n    }\n\n    private focusMore(): void {\n        if (this.moreButton) {\n            this.moreButton.nativeElement.focus();\n        }\n    }\n\n    private getMaxIndex(): number {\n        const {tabs, activeItemIndex, margin} = this;\n\n        if (tabs.length < 2) {\n            return 0;\n        }\n\n        const {exposeActive, minMoreWidth} = this.options;\n        const {clientWidth} = this.el;\n        const active = tabs[activeItemIndex];\n        const activeWidth = active?.scrollWidth ?? 0;\n        const moreWidth = Math.max(tabs[tabs.length - 1]?.scrollWidth ?? 0, minMoreWidth);\n        let maxIndex = tabs.length - 2;\n        let total =\n            tabs.reduce((acc, {scrollWidth}) => acc + scrollWidth, 0) +\n            maxIndex * margin -\n            (tabs[tabs.length - 1]?.scrollWidth ?? 0);\n\n        if (Number.isNaN(total) || total <= clientWidth) {\n            return Infinity;\n        }\n\n        while (maxIndex) {\n            total -= (tabs[maxIndex]?.scrollWidth ?? 0) + margin;\n            maxIndex--;\n\n            const activeDisplaced = exposeActive && activeItemIndex > maxIndex;\n            const activeOffset = activeDisplaced ? activeWidth + margin : 0;\n            const currentWidth = total + activeOffset + moreWidth + margin;\n            // Needed for different rounding of visible and hidden elements scrollWidth\n            const safetyOffset = tuiToInt(this.maxIndex === maxIndex - 1);\n\n            if (currentWidth + safetyOffset < clientWidth) {\n                return maxIndex;\n            }\n        }\n\n        return -1;\n    }\n\n    private updateActiveItemIndex(activeItemIndex: number): void {\n        this.itemIndex = activeItemIndex;\n        this.activeItemIndexChange.emit(activeItemIndex);\n    }\n\n    private refresh(): void {\n        const {offsetLeft = 0, offsetWidth = 0} = this.activeElement || {};\n\n        this.dir?.nativeElement.style.setProperty('--t-left', tuiPx(offsetLeft));\n        this.dir?.nativeElement.style.setProperty('--t-width', tuiPx(offsetWidth));\n    }\n}\n","<ng-container *ngIf=\"items.changes | async\" />\n<tui-tabs\n    class=\"t-tabs\"\n    [activeItemIndex]=\"activeItemIndex\"\n    [size]=\"size\"\n    [underline]=\"underline\"\n    (activeItemIndexChange)=\"onActiveItemIndexChange($event)\"\n    (keydown.arrowRight)=\"onArrowRight($event)\"\n>\n    <ng-container *ngFor=\"let item of items; let index = index\">\n        <ng-container\n            *ngIf=\"index <= lastVisibleIndex; else hidden\"\n            [ngTemplateOutlet]=\"item\"\n        />\n        <ng-template #hidden>\n            <div\n                class=\"t-flex\"\n                [class.t-overflown]=\"isOverflown(index)\"\n            >\n                <ng-container [ngTemplateOutlet]=\"item\" />\n            </div>\n        </ng-template>\n    </ng-container>\n</tui-tabs>\n\n<button\n    *ngIf=\"moreContent; else chevron\"\n    tuiTab\n    type=\"button\"\n    class=\"t-more\"\n    [class._active]=\"isMoreActive\"\n    [class.t-no-margin]=\"isMoreAlone\"\n    [class.t-overflown]=\"!isMoreVisible\"\n    [tabIndex]=\"isMoreFocusable ? 0 : -1\"\n    [tuiDropdown]=\"dropdownContent || dropdown\"\n    [(tuiDropdownOpen)]=\"open\"\n    (keydown.arrowLeft.prevent)=\"onArrowLeft()\"\n>\n    <ng-container *polymorpheusOutlet=\"moreContent as text\">\n        {{ text }}\n    </ng-container>\n</button>\n<ng-template #chevron>\n    <button\n        tuiChevron\n        tuiTab\n        type=\"button\"\n        class=\"t-more\"\n        [class._active]=\"isMoreActive\"\n        [class.t-no-margin]=\"isMoreAlone\"\n        [class.t-overflown]=\"!isMoreVisible\"\n        [tabIndex]=\"isMoreFocusable ? 0 : -1\"\n        [tuiDropdown]=\"dropdownContent || dropdown\"\n        [(tuiDropdownOpen)]=\"open\"\n        (keydown.arrowLeft.prevent)=\"onArrowLeft()\"\n    >\n        {{ moreWord$ | async }}\n    </button>\n</ng-template>\n<ng-template #dropdown>\n    <div\n        #element\n        class=\"t-dropdown\"\n        [attr.data-size]=\"size\"\n        (keydown.arrowDown.prevent)=\"onWrapperArrow($event, element, false)\"\n        (keydown.arrowUp.prevent)=\"onWrapperArrow($event, element, true)\"\n    >\n        <div\n            *ngFor=\"let item of items; let index = index\"\n            class=\"t-dropdown-item\"\n            (tui-tab-activate)=\"onClick(index)\"\n        >\n            <ng-container *ngIf=\"shouldShow(index)\">\n                <ng-container *polymorpheusOutlet=\"item\" />\n            </ng-container>\n        </div>\n    </div>\n</ng-template>\n\n<ng-content />\n"]}