UNPKG

@nova-ui/bits

Version:

SolarWinds Nova Framework

147 lines 36.8 kB
// © 2022 SolarWinds Worldwide, LLC. All rights reserved. // // Permission is hereby granted, free of charge, to any person obtaining a copy // of this software and associated documentation files (the "Software"), to // deal in the Software without restriction, including without limitation the // rights to use, copy, modify, merge, publish, distribute, sublicense, and/or // sell copies of the Software, and to permit persons to whom the Software is // furnished to do so, subject to the following conditions: // // The above copyright notice and this permission notice shall be included in // all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN // THE SOFTWARE. import { ChangeDetectorRef, Component, ElementRef, Input, ViewEncapsulation, } from "@angular/core"; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; import * as i2 from "../../icon/icon.component"; import * as i3 from "../tab/tab-heading-custom-template-ref.directive"; // <example-url>./../examples/index.html#/tabgroup</example-url> /** @ignore */ export class TabGroupComponent { /** If true tabs will be placed vertically */ get vertical() { return Boolean(this._vertical); } set vertical(value) { this._vertical = value; } constructor(el, changeDetectorRef) { this.el = el; this.changeDetectorRef = changeDetectorRef; this.tabs = []; this.leftTraverseEnabled = true; this.rightTraverseEnabled = false; this.hasTraverse = false; this.traverseButtonsWidth = 60; this.traverseStepSize = 50; } ngAfterViewInit() { this.checkTraverse(); } checkTraverse() { this.hasTraverse = this.allowTraverse(); this.changeDetectorRef.detectChanges(); if (!this.hasTraverse) { this.setNewShift("0px"); } } addTab(tab) { this.tabs.push(tab); tab.active = this.tabs.length === 1 && typeof tab.active === "undefined"; } selectTab(selectedTab) { if (!selectedTab.disabled) { selectedTab.active = true; this.tabs.forEach((tab) => { if (tab !== selectedTab) { tab.active = false; } }); } } allowTraverse() { const holderSize = this.getElementSize("nui-tabs__holder"); const contentSize = this.getElementSize("nui-tabs__container"); if (this.vertical) { return false; } return holderSize + this.traverseButtonsWidth <= contentSize; } traverseRight() { const margin = this.getCurrentShift(); if (this.isTraverseRightAllowed(margin)) { const traverseStep = Math.abs(this.getNumberFromPixels(margin)) < this.traverseStepSize ? Math.abs(this.getNumberFromPixels(margin)) : this.traverseStepSize; this.setNewShift(this.addPixels(margin, traverseStep)); this.rightTraverseEnabled = this.isTraverseRightAllowed(this.addPixels(margin, traverseStep)); this.leftTraverseEnabled = this.isTraverseLeftAllowed(this.addPixels(margin, traverseStep)); } } traverseLeft() { const margin = this.getCurrentShift(); if (this.isTraverseLeftAllowed(margin)) { const tabsSize = this.getElementSize("nui-tabs__container"); const tabHolderSize = this.getElementSize("nui-tabs__holder"); const maxAllowedMargin = Math.abs(tabsSize - tabHolderSize + this.traverseButtonsWidth); const leftMarginValue = Math.abs(this.getNumberFromPixels(margin)); const traverseStep = Math.min(maxAllowedMargin - leftMarginValue, this.traverseStepSize); this.setNewShift(this.addPixels(margin, -traverseStep)); this.rightTraverseEnabled = this.isTraverseRightAllowed(this.addPixels(margin, -traverseStep)); this.leftTraverseEnabled = this.isTraverseLeftAllowed(this.addPixels(margin, -traverseStep)); } } isTraverseLeftAllowed(leftMargin) { const tabsSize = this.getElementSize("nui-tabs__container"); const tabHolderSize = this.getElementSize("nui-tabs__holder"); const maxAllowedMargin = Math.abs(tabsSize - tabHolderSize + this.traverseButtonsWidth); const margin = Math.abs(this.getNumberFromPixels(leftMargin)); return margin < maxAllowedMargin; } isTraverseRightAllowed(margin) { return this.getNumberFromPixels(margin) < 0; } getElementSize(selector) { return this.el.nativeElement.querySelector("." + selector).offsetWidth; } getNumberFromPixels(pixels) { return pixels.indexOf("px") ? Number(pixels.substring(0, pixels.indexOf("px"))) : 0; } getCurrentShift() { return this.el.nativeElement.querySelector(".nui-tabs__container").style .marginLeft; } setNewShift(newShift) { this.el.nativeElement.querySelector(".nui-tabs__container").style.marginTop = "0px"; this.el.nativeElement.querySelector(".nui-tabs__container").style.marginLeft = newShift; } addPixels(currentValue, increment) { const value = this.getNumberFromPixels(currentValue); return value + increment + "px"; } ngOnDestroy() { this.isDestroyed = true; } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TabGroupComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: TabGroupComponent, selector: "nui-tab-group", inputs: { vertical: "vertical" }, host: { listeners: { "window:resize": "checkTraverse()" } }, ngImport: i0, template: "<div class=\"nui-tabgroup\" [class.flex-column]=\"!vertical\">\n <div\n class=\"nui-tabs__holder\"\n [class.vertical]=\"vertical\"\n (click)=\"$event.preventDefault()\"\n >\n <div\n class=\"btn-caret-left\"\n [class.disabled]=\"!rightTraverseEnabled\"\n *ngIf=\"hasTraverse\"\n (click)=\"traverseRight()\"\n >\n <nui-icon\n [icon]=\"'caret-left'\"\n [iconColor]=\"!rightTraverseEnabled ? 'gray' : 'default'\"\n ></nui-icon>\n </div>\n <div class=\"nui-tabs\">\n <div class=\"nui-tabs__container\" [class.flex-column]=\"vertical\">\n <ng-container *ngFor=\"let tab of tabs\">\n <div\n class=\"nui-tab\"\n [class.active]=\"tab.active && !vertical\"\n [class.horizontal]=\"tab.active && !vertical\"\n [class.disabled]=\"tab.disabled\"\n [class.active__vertical]=\"tab.active && vertical\"\n >\n <span class=\"tab-link\" (click)=\"selectTab(tab)\">\n <span\n [nuiTabHeadingCustomTemplateRef]=\"\n tab.headingRef\n \"\n >{{ tab.heading }}</span\n >\n </span>\n </div>\n </ng-container>\n </div>\n </div>\n <div\n class=\"btn-caret-right\"\n [class.disabled]=\"!leftTraverseEnabled\"\n *ngIf=\"hasTraverse\"\n (click)=\"traverseLeft()\"\n >\n <nui-icon\n [icon]=\"'caret-right'\"\n [iconColor]=\"!leftTraverseEnabled ? 'gray' : 'default'\"\n ></nui-icon>\n </div>\n </div>\n <div class=\"nui-tabgroup__content\">\n <ng-content></ng-content>\n </div>\n</div>\n", styles: [".nui-tabgroup{display:flex;height:100%}.nui-tabgroup .nui-tabs{display:flex;justify-content:flex-start;margin-bottom:0;overflow:hidden}.nui-tabgroup .nui-tabs__holder{display:flex;border-bottom:1px solid #d9d9d9;border-bottom:1px solid var(--nui-color-line-default, #d9d9d9);flex-direction:row;background-color:var(--nui-color-bg-content,#fff)}.nui-tabgroup .nui-tabs__holder.vertical{border-right:1px solid #d9d9d9;border-right:1px solid var(--nui-color-line-default, #d9d9d9);border-bottom:0!important;margin-right:5px;margin-bottom:5px}.nui-tabgroup .nui-tabs__holder .btn-caret-right{align-items:center;justify-content:center;display:flex;flex:1;background:#fff;min-width:30px;max-width:30px;min-height:20px;z-index:2;border-bottom:none;cursor:pointer;border-left:1px solid #d9d9d9;border-left:1px solid var(--nui-color-line-default, #d9d9d9);box-shadow:-2px 0 2px #d9d9d9;box-shadow:-2px 0 2px var(--nui-color-line-default, #d9d9d9)}.nui-tabgroup .nui-tabs__holder .btn-caret-right.disabled{cursor:auto}.nui-tabgroup .nui-tabs__holder .btn-caret-left{align-items:center;justify-content:center;display:flex;flex:1;background:#fff;min-width:30px;max-width:30px;min-height:20px;z-index:2;border-bottom:none;cursor:pointer;border-right:1px solid #d9d9d9;border-right:1px solid var(--nui-color-line-default, #d9d9d9);box-shadow:2px 0 2px #d9d9d9;box-shadow:2px 0 2px var(--nui-color-line-default, #d9d9d9)}.nui-tabgroup .nui-tabs__holder .btn-caret-left.disabled{cursor:auto}.nui-tabgroup .nui-tabs__container{display:flex}.nui-tabgroup .nui-tabs__container .nui-tab{margin-bottom:-1px;white-space:nowrap}.nui-tabgroup .nui-tabs__container .nui-tab.horizontal{border-left:none}.nui-tabgroup .nui-tabs__container .nui-tab.active{border-bottom:3px solid #00c4d2;border-bottom:3px solid var(--nui-color-selected-contrast, #00c4d2)}.nui-tabgroup .nui-tabs__container .nui-tab.active>.tab-link{color:var(--nui-color-text-default,#111);background-color:var(--nui-color-bg-transparent,transparent)}.nui-tabgroup .nui-tabs__container .nui-tab.active__vertical{border-left:3px solid #00c4d2;border-left:3px solid var(--nui-color-selected-contrast, #00c4d2)}.nui-tabgroup .nui-tabs__container .nui-tab.disabled>.tab-link{cursor:not-allowed;color:var(--nui-color-text-disabled,rgba(17, 17, 17, .3))}.nui-tabgroup .nui-tabs__container .nui-tab.disabled>.tab-link:hover{background:transparent}.nui-tabgroup .nui-tabs__container .nui-tab:hover{background:var(--nui-color-bg-light-hover,#f2f2f2)}.nui-tabgroup .nui-tabs__container .nui-tab .tab-link{display:block;padding:5px 10px;cursor:pointer;text-transform:uppercase;font-size:13px;font-weight:600;line-height:18px;color:var(--nui-color-text-secondary,rgba(17, 17, 17, .6))}.nui-tabgroup .nui-tabs__container .nui-tab .tab-link:hover{background:var(--nui-color-bg-light-hover,#f2f2f2)}.nui-tabgroup__content,.full-width{width:100%}.flex-column{flex-direction:column}.caret-button{align-items:center;justify-content:center;display:flex;flex:1;background:#fff;min-width:30px;max-width:30px;min-height:20px;z-index:2;border-bottom:none;cursor:pointer}.caret-button.disabled{cursor:auto}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.IconComponent, selector: "nui-icon", inputs: ["iconColor", "brushType", "iconHoverColor", "iconSize", "cssClass", "fillContainer", "status", "childStatus", "icon", "counter"] }, { kind: "directive", type: i3.TabHeadingCustomTemplateRefDirective, selector: "[nuiTabHeadingCustomTemplateRef]", inputs: ["nuiTabHeadingCustomTemplateRef"] }], encapsulation: i0.ViewEncapsulation.None }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TabGroupComponent, decorators: [{ type: Component, args: [{ selector: "nui-tab-group", host: { "(window:resize)": "checkTraverse()", }, encapsulation: ViewEncapsulation.None, template: "<div class=\"nui-tabgroup\" [class.flex-column]=\"!vertical\">\n <div\n class=\"nui-tabs__holder\"\n [class.vertical]=\"vertical\"\n (click)=\"$event.preventDefault()\"\n >\n <div\n class=\"btn-caret-left\"\n [class.disabled]=\"!rightTraverseEnabled\"\n *ngIf=\"hasTraverse\"\n (click)=\"traverseRight()\"\n >\n <nui-icon\n [icon]=\"'caret-left'\"\n [iconColor]=\"!rightTraverseEnabled ? 'gray' : 'default'\"\n ></nui-icon>\n </div>\n <div class=\"nui-tabs\">\n <div class=\"nui-tabs__container\" [class.flex-column]=\"vertical\">\n <ng-container *ngFor=\"let tab of tabs\">\n <div\n class=\"nui-tab\"\n [class.active]=\"tab.active && !vertical\"\n [class.horizontal]=\"tab.active && !vertical\"\n [class.disabled]=\"tab.disabled\"\n [class.active__vertical]=\"tab.active && vertical\"\n >\n <span class=\"tab-link\" (click)=\"selectTab(tab)\">\n <span\n [nuiTabHeadingCustomTemplateRef]=\"\n tab.headingRef\n \"\n >{{ tab.heading }}</span\n >\n </span>\n </div>\n </ng-container>\n </div>\n </div>\n <div\n class=\"btn-caret-right\"\n [class.disabled]=\"!leftTraverseEnabled\"\n *ngIf=\"hasTraverse\"\n (click)=\"traverseLeft()\"\n >\n <nui-icon\n [icon]=\"'caret-right'\"\n [iconColor]=\"!leftTraverseEnabled ? 'gray' : 'default'\"\n ></nui-icon>\n </div>\n </div>\n <div class=\"nui-tabgroup__content\">\n <ng-content></ng-content>\n </div>\n</div>\n", styles: [".nui-tabgroup{display:flex;height:100%}.nui-tabgroup .nui-tabs{display:flex;justify-content:flex-start;margin-bottom:0;overflow:hidden}.nui-tabgroup .nui-tabs__holder{display:flex;border-bottom:1px solid #d9d9d9;border-bottom:1px solid var(--nui-color-line-default, #d9d9d9);flex-direction:row;background-color:var(--nui-color-bg-content,#fff)}.nui-tabgroup .nui-tabs__holder.vertical{border-right:1px solid #d9d9d9;border-right:1px solid var(--nui-color-line-default, #d9d9d9);border-bottom:0!important;margin-right:5px;margin-bottom:5px}.nui-tabgroup .nui-tabs__holder .btn-caret-right{align-items:center;justify-content:center;display:flex;flex:1;background:#fff;min-width:30px;max-width:30px;min-height:20px;z-index:2;border-bottom:none;cursor:pointer;border-left:1px solid #d9d9d9;border-left:1px solid var(--nui-color-line-default, #d9d9d9);box-shadow:-2px 0 2px #d9d9d9;box-shadow:-2px 0 2px var(--nui-color-line-default, #d9d9d9)}.nui-tabgroup .nui-tabs__holder .btn-caret-right.disabled{cursor:auto}.nui-tabgroup .nui-tabs__holder .btn-caret-left{align-items:center;justify-content:center;display:flex;flex:1;background:#fff;min-width:30px;max-width:30px;min-height:20px;z-index:2;border-bottom:none;cursor:pointer;border-right:1px solid #d9d9d9;border-right:1px solid var(--nui-color-line-default, #d9d9d9);box-shadow:2px 0 2px #d9d9d9;box-shadow:2px 0 2px var(--nui-color-line-default, #d9d9d9)}.nui-tabgroup .nui-tabs__holder .btn-caret-left.disabled{cursor:auto}.nui-tabgroup .nui-tabs__container{display:flex}.nui-tabgroup .nui-tabs__container .nui-tab{margin-bottom:-1px;white-space:nowrap}.nui-tabgroup .nui-tabs__container .nui-tab.horizontal{border-left:none}.nui-tabgroup .nui-tabs__container .nui-tab.active{border-bottom:3px solid #00c4d2;border-bottom:3px solid var(--nui-color-selected-contrast, #00c4d2)}.nui-tabgroup .nui-tabs__container .nui-tab.active>.tab-link{color:var(--nui-color-text-default,#111);background-color:var(--nui-color-bg-transparent,transparent)}.nui-tabgroup .nui-tabs__container .nui-tab.active__vertical{border-left:3px solid #00c4d2;border-left:3px solid var(--nui-color-selected-contrast, #00c4d2)}.nui-tabgroup .nui-tabs__container .nui-tab.disabled>.tab-link{cursor:not-allowed;color:var(--nui-color-text-disabled,rgba(17, 17, 17, .3))}.nui-tabgroup .nui-tabs__container .nui-tab.disabled>.tab-link:hover{background:transparent}.nui-tabgroup .nui-tabs__container .nui-tab:hover{background:var(--nui-color-bg-light-hover,#f2f2f2)}.nui-tabgroup .nui-tabs__container .nui-tab .tab-link{display:block;padding:5px 10px;cursor:pointer;text-transform:uppercase;font-size:13px;font-weight:600;line-height:18px;color:var(--nui-color-text-secondary,rgba(17, 17, 17, .6))}.nui-tabgroup .nui-tabs__container .nui-tab .tab-link:hover{background:var(--nui-color-bg-light-hover,#f2f2f2)}.nui-tabgroup__content,.full-width{width:100%}.flex-column{flex-direction:column}.caret-button{align-items:center;justify-content:center;display:flex;flex:1;background:#fff;min-width:30px;max-width:30px;min-height:20px;z-index:2;border-bottom:none;cursor:pointer}.caret-button.disabled{cursor:auto}\n"] }] }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }], propDecorators: { vertical: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tab-group.component.js","sourceRoot":"","sources":["../../../../../src/lib/tabgroup/tab-group/tab-group.component.ts","../../../../../src/lib/tabgroup/tab-group/tab-group.component.html"],"names":[],"mappings":"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","sourcesContent":["// © 2022 SolarWinds Worldwide, LLC. All rights reserved.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n//  of this software and associated documentation files (the \"Software\"), to\n//  deal in the Software without restriction, including without limitation the\n//  rights to use, copy, modify, merge, publish, distribute, sublicense, and/or\n//  sell copies of the Software, and to permit persons to whom the Software is\n//  furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n//  all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n//  IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n//  FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n//  AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n//  LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n//  OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n//  THE SOFTWARE.\n\nimport {\n    AfterViewInit,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    Input,\n    OnDestroy,\n    ViewEncapsulation,\n} from \"@angular/core\";\n\nimport { TabComponent } from \"../tab/tab.component\";\n\n// <example-url>./../examples/index.html#/tabgroup</example-url>\n/** @ignore */\n@Component({\n    selector: \"nui-tab-group\",\n    templateUrl: \"./tab-group.component.html\",\n    host: {\n        \"(window:resize)\": \"checkTraverse()\",\n    },\n    styleUrls: [\"./tab-group.component.less\"],\n    encapsulation: ViewEncapsulation.None,\n})\nexport class TabGroupComponent implements OnDestroy, AfterViewInit {\n    /** If true tabs will be placed vertically */\n    @Input()\n    get vertical(): boolean {\n        return Boolean(this._vertical);\n    }\n\n    set vertical(value: boolean) {\n        this._vertical = value;\n    }\n\n    public tabs: TabComponent[] = [];\n    public leftTraverseEnabled = true;\n    public rightTraverseEnabled = false;\n    public hasTraverse = false;\n\n    private traverseButtonsWidth = 60;\n    private traverseStepSize = 50;\n\n    protected isDestroyed: boolean;\n    protected _vertical: boolean;\n\n    constructor(\n        private el: ElementRef,\n        private changeDetectorRef: ChangeDetectorRef\n    ) {}\n\n    public ngAfterViewInit(): void {\n        this.checkTraverse();\n    }\n\n    public checkTraverse(): void {\n        this.hasTraverse = this.allowTraverse();\n        this.changeDetectorRef.detectChanges();\n        if (!this.hasTraverse) {\n            this.setNewShift(\"0px\");\n        }\n    }\n\n    public addTab(tab: TabComponent): void {\n        this.tabs.push(tab);\n        tab.active =\n            this.tabs.length === 1 && typeof tab.active === \"undefined\";\n    }\n\n    public selectTab(selectedTab: TabComponent): void {\n        if (!selectedTab.disabled) {\n            selectedTab.active = true;\n            this.tabs.forEach((tab: TabComponent) => {\n                if (tab !== selectedTab) {\n                    tab.active = false;\n                }\n            });\n        }\n    }\n\n    public allowTraverse(): boolean {\n        const holderSize = this.getElementSize(\"nui-tabs__holder\");\n        const contentSize = this.getElementSize(\"nui-tabs__container\");\n        if (this.vertical) {\n            return false;\n        }\n        return holderSize + this.traverseButtonsWidth <= contentSize;\n    }\n\n    public traverseRight(): void {\n        const margin = this.getCurrentShift();\n        if (this.isTraverseRightAllowed(margin)) {\n            const traverseStep =\n                Math.abs(this.getNumberFromPixels(margin)) <\n                this.traverseStepSize\n                    ? Math.abs(this.getNumberFromPixels(margin))\n                    : this.traverseStepSize;\n            this.setNewShift(this.addPixels(margin, traverseStep));\n            this.rightTraverseEnabled = this.isTraverseRightAllowed(\n                this.addPixels(margin, traverseStep)\n            );\n            this.leftTraverseEnabled = this.isTraverseLeftAllowed(\n                this.addPixels(margin, traverseStep)\n            );\n        }\n    }\n\n    public traverseLeft(): void {\n        const margin = this.getCurrentShift();\n        if (this.isTraverseLeftAllowed(margin)) {\n            const tabsSize = this.getElementSize(\"nui-tabs__container\");\n            const tabHolderSize = this.getElementSize(\"nui-tabs__holder\");\n            const maxAllowedMargin = Math.abs(\n                tabsSize - tabHolderSize + this.traverseButtonsWidth\n            );\n            const leftMarginValue = Math.abs(this.getNumberFromPixels(margin));\n            const traverseStep = Math.min(\n                maxAllowedMargin - leftMarginValue,\n                this.traverseStepSize\n            );\n            this.setNewShift(this.addPixels(margin, -traverseStep));\n            this.rightTraverseEnabled = this.isTraverseRightAllowed(\n                this.addPixels(margin, -traverseStep)\n            );\n            this.leftTraverseEnabled = this.isTraverseLeftAllowed(\n                this.addPixels(margin, -traverseStep)\n            );\n        }\n    }\n\n    private isTraverseLeftAllowed(leftMargin: string): boolean {\n        const tabsSize = this.getElementSize(\"nui-tabs__container\");\n        const tabHolderSize = this.getElementSize(\"nui-tabs__holder\");\n        const maxAllowedMargin = Math.abs(\n            tabsSize - tabHolderSize + this.traverseButtonsWidth\n        );\n\n        const margin = Math.abs(this.getNumberFromPixels(leftMargin));\n        return margin < maxAllowedMargin;\n    }\n\n    private isTraverseRightAllowed(margin: string): boolean {\n        return this.getNumberFromPixels(margin) < 0;\n    }\n\n    private getElementSize(selector: string): number {\n        return this.el.nativeElement.querySelector(\".\" + selector).offsetWidth;\n    }\n\n    private getNumberFromPixels(pixels: string): number {\n        return pixels.indexOf(\"px\")\n            ? Number(pixels.substring(0, pixels.indexOf(\"px\")))\n            : 0;\n    }\n\n    private getCurrentShift(): string {\n        return this.el.nativeElement.querySelector(\".nui-tabs__container\").style\n            .marginLeft;\n    }\n\n    private setNewShift(newShift: string): void {\n        this.el.nativeElement.querySelector(\n            \".nui-tabs__container\"\n        ).style.marginTop = \"0px\";\n        this.el.nativeElement.querySelector(\n            \".nui-tabs__container\"\n        ).style.marginLeft = newShift;\n    }\n\n    private addPixels(currentValue: string, increment: number): string {\n        const value = this.getNumberFromPixels(currentValue);\n        return value + increment + \"px\";\n    }\n\n    public ngOnDestroy(): void {\n        this.isDestroyed = true;\n    }\n}\n","<div class=\"nui-tabgroup\" [class.flex-column]=\"!vertical\">\n    <div\n        class=\"nui-tabs__holder\"\n        [class.vertical]=\"vertical\"\n        (click)=\"$event.preventDefault()\"\n    >\n        <div\n            class=\"btn-caret-left\"\n            [class.disabled]=\"!rightTraverseEnabled\"\n            *ngIf=\"hasTraverse\"\n            (click)=\"traverseRight()\"\n        >\n            <nui-icon\n                [icon]=\"'caret-left'\"\n                [iconColor]=\"!rightTraverseEnabled ? 'gray' : 'default'\"\n            ></nui-icon>\n        </div>\n        <div class=\"nui-tabs\">\n            <div class=\"nui-tabs__container\" [class.flex-column]=\"vertical\">\n                <ng-container *ngFor=\"let tab of tabs\">\n                    <div\n                        class=\"nui-tab\"\n                        [class.active]=\"tab.active && !vertical\"\n                        [class.horizontal]=\"tab.active && !vertical\"\n                        [class.disabled]=\"tab.disabled\"\n                        [class.active__vertical]=\"tab.active && vertical\"\n                    >\n                        <span class=\"tab-link\" (click)=\"selectTab(tab)\">\n                            <span\n                                [nuiTabHeadingCustomTemplateRef]=\"\n                                    tab.headingRef\n                                \"\n                                >{{ tab.heading }}</span\n                            >\n                        </span>\n                    </div>\n                </ng-container>\n            </div>\n        </div>\n        <div\n            class=\"btn-caret-right\"\n            [class.disabled]=\"!leftTraverseEnabled\"\n            *ngIf=\"hasTraverse\"\n            (click)=\"traverseLeft()\"\n        >\n            <nui-icon\n                [icon]=\"'caret-right'\"\n                [iconColor]=\"!leftTraverseEnabled ? 'gray' : 'default'\"\n            ></nui-icon>\n        </div>\n    </div>\n    <div class=\"nui-tabgroup__content\">\n        <ng-content></ng-content>\n    </div>\n</div>\n"]}