UNPKG

@taiga-ui/kit

Version:

Taiga UI Angular main components kit

108 lines 14.1 kB
import { __decorate } from "tslib"; import { ContentChildren, Directive, forwardRef, inject, Input } from '@angular/core'; import { takeUntilDestroyed } from '@angular/core/rxjs-interop'; import { MutationObserverService, WA_MUTATION_OBSERVER_INIT, } from '@ng-web-apis/mutation-observer'; import { EMPTY_QUERY } from '@taiga-ui/cdk/constants'; import { tuiZonefree } from '@taiga-ui/cdk/observables'; import { tuiInjectElement } from '@taiga-ui/cdk/utils/dom'; import { tuiPure, tuiPx } from '@taiga-ui/cdk/utils/miscellaneous'; import { TuiTab } from './tab.directive'; import { TuiTabsDirective } from './tabs.directive'; import { TUI_TABS_OPTIONS } from './tabs.options'; import * as i0 from "@angular/core"; import * as i1 from "./tabs.directive"; class TuiTabsHorizontal { constructor() { this.el = tuiInjectElement(); this.options = inject(TUI_TABS_OPTIONS); this.tabs = inject(TuiTabsDirective); this.children = EMPTY_QUERY; this.sub = inject(MutationObserverService, { self: true }) .pipe(tuiZonefree(), takeUntilDestroyed()) .subscribe(() => this.refresh()); this.underline = this.options.underline; } ngAfterViewChecked() { this.scrollTo(this.tabs.activeItemIndex); this.refresh(); } onKeyDownArrow(current, step) { this.tabs.moveFocus(current, step); } refresh() { const { activeElement } = this.tabs; if (activeElement && !activeElement.isConnected) { return; } const { offsetLeft = 0, offsetWidth = 0 } = activeElement || {}; this.el.style.setProperty('--t-left', tuiPx(offsetLeft)); this.el.style.setProperty('--t-width', tuiPx(offsetWidth)); } scrollTo(index) { const element = this.tabs.tabs[index]; if (!element) { return; } const { offsetLeft, offsetWidth } = element; if (offsetLeft < this.el.scrollLeft) { this.el.scrollLeft = offsetLeft; } if (offsetLeft + offsetWidth > this.el.scrollLeft + this.el.offsetWidth) { this.el.scrollLeft = offsetLeft + offsetWidth - this.el.offsetWidth; } } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiTabsHorizontal, deps: [], target: i0.ɵɵFactoryTarget.Directive }); } static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: TuiTabsHorizontal, isStandalone: true, selector: "tui-tabs:not([vertical]), nav[tuiTabs]:not([vertical])", inputs: { underline: "underline" }, host: { listeners: { "animationend": "refresh()", "keydown.arrowRight.prevent": "onKeyDownArrow($event.target, 1)", "keydown.arrowLeft.prevent": "onKeyDownArrow($event.target, -1)" }, properties: { "class._underline": "underline", "style.--t-color": "underline === true ? 'var(--tui-background-accent-1)' : underline" } }, providers: [ MutationObserverService, { provide: WA_MUTATION_OBSERVER_INIT, useValue: { childList: true, characterData: true, subtree: true, }, }, ], queries: [{ propertyName: "children", predicate: i0.forwardRef(function () { return TuiTab; }) }], hostDirectives: [{ directive: i1.TuiTabsDirective, inputs: ["activeItemIndex", "activeItemIndex", "size", "size"], outputs: ["activeItemIndexChange", "activeItemIndexChange"] }], ngImport: i0 }); } } __decorate([ tuiPure ], TuiTabsHorizontal.prototype, "scrollTo", null); export { TuiTabsHorizontal }; i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiTabsHorizontal, decorators: [{ type: Directive, args: [{ standalone: true, selector: 'tui-tabs:not([vertical]), nav[tuiTabs]:not([vertical])', providers: [ MutationObserverService, { provide: WA_MUTATION_OBSERVER_INIT, useValue: { childList: true, characterData: true, subtree: true, }, }, ], hostDirectives: [ { directive: TuiTabsDirective, inputs: ['activeItemIndex', 'size'], outputs: ['activeItemIndexChange'], }, ], host: { '[class._underline]': 'underline', '[style.--t-color]': "underline === true ? 'var(--tui-background-accent-1)' : underline", '(animationend)': 'refresh()', '(keydown.arrowRight.prevent)': 'onKeyDownArrow($event.target, 1)', '(keydown.arrowLeft.prevent)': 'onKeyDownArrow($event.target, -1)', }, }] }], propDecorators: { children: [{ type: ContentChildren, args: [forwardRef(() => TuiTab)] }], underline: [{ type: Input }], scrollTo: [] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tabs-horizontal.directive.js","sourceRoot":"","sources":["../../../../../projects/kit/components/tabs/tabs-horizontal.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import type {AfterViewChecked, QueryList} from '@angular/core';\nimport {ContentChildren, Directive, forwardRef, inject, Input} from '@angular/core';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\nimport {\n    MutationObserverService,\n    WA_MUTATION_OBSERVER_INIT,\n} from '@ng-web-apis/mutation-observer';\nimport {EMPTY_QUERY} from '@taiga-ui/cdk/constants';\nimport {tuiZonefree} from '@taiga-ui/cdk/observables';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport {tuiPure, tuiPx} from '@taiga-ui/cdk/utils/miscellaneous';\n\nimport {TuiTab} from './tab.directive';\nimport {TuiTabsDirective} from './tabs.directive';\nimport {TUI_TABS_OPTIONS} from './tabs.options';\n\n@Directive({\n    standalone: true,\n    selector: 'tui-tabs:not([vertical]), nav[tuiTabs]:not([vertical])',\n    providers: [\n        MutationObserverService,\n        {\n            provide: WA_MUTATION_OBSERVER_INIT,\n            useValue: {\n                childList: true,\n                characterData: true,\n                subtree: true,\n            },\n        },\n    ],\n    hostDirectives: [\n        {\n            directive: TuiTabsDirective,\n            inputs: ['activeItemIndex', 'size'],\n            outputs: ['activeItemIndexChange'],\n        },\n    ],\n    host: {\n        '[class._underline]': 'underline',\n        '[style.--t-color]':\n            \"underline === true ? 'var(--tui-background-accent-1)' : underline\",\n        '(animationend)': 'refresh()',\n        '(keydown.arrowRight.prevent)': 'onKeyDownArrow($event.target, 1)',\n        '(keydown.arrowLeft.prevent)': 'onKeyDownArrow($event.target, -1)',\n    },\n})\nexport class TuiTabsHorizontal implements AfterViewChecked {\n    private readonly el = tuiInjectElement();\n    private readonly options = inject(TUI_TABS_OPTIONS);\n    private readonly tabs = inject(TuiTabsDirective);\n\n    @ContentChildren(forwardRef(() => TuiTab))\n    protected readonly children: QueryList<unknown> = EMPTY_QUERY;\n\n    protected readonly sub = inject(MutationObserverService, {self: true})\n        .pipe(tuiZonefree(), takeUntilDestroyed())\n        .subscribe(() => this.refresh());\n\n    @Input()\n    public underline = this.options.underline;\n\n    public ngAfterViewChecked(): void {\n        this.scrollTo(this.tabs.activeItemIndex);\n        this.refresh();\n    }\n\n    protected onKeyDownArrow(current: HTMLElement, step: number): void {\n        this.tabs.moveFocus(current, step);\n    }\n\n    protected refresh(): void {\n        const {activeElement} = this.tabs;\n\n        if (activeElement && !activeElement.isConnected) {\n            return;\n        }\n\n        const {offsetLeft = 0, offsetWidth = 0} = activeElement || {};\n\n        this.el.style.setProperty('--t-left', tuiPx(offsetLeft));\n        this.el.style.setProperty('--t-width', tuiPx(offsetWidth));\n    }\n\n    @tuiPure\n    private scrollTo(index: number): void {\n        const element = this.tabs.tabs[index];\n\n        if (!element) {\n            return;\n        }\n\n        const {offsetLeft, offsetWidth} = element;\n\n        if (offsetLeft < this.el.scrollLeft) {\n            this.el.scrollLeft = offsetLeft;\n        }\n\n        if (offsetLeft + offsetWidth > this.el.scrollLeft + this.el.offsetWidth) {\n            this.el.scrollLeft = offsetLeft + offsetWidth - this.el.offsetWidth;\n        }\n    }\n}\n"]}