igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
589 lines • 42.8 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
import { CommonModule } from '@angular/common';
import { Component, ContentChildren, ElementRef, EventEmitter, forwardRef, HostBinding, HostListener, Input, NgModule, Output, QueryList, ViewChild, ViewChildren } from '@angular/core';
import { IgxBadgeModule } from '../badge/badge.component';
import { IgxRippleModule } from '../directives/ripple/ripple.directive';
import { IgxIconModule } from '../icon/index';
import { IgxTabItemComponent } from './tab-item.component';
import { IgxTabsGroupComponent } from './tabs-group.component';
import { IgxLeftButtonStyleDirective, IgxRightButtonStyleDirective, IgxTabItemTemplateDirective } from './tabs.directives';
import { IgxTabsBase } from './tabs.common';
/** @enum {string} */
var TabsType = {
FIXED: 'fixed',
CONTENTFIT: 'contentfit',
};
export { TabsType };
var IgxTabsComponent = /** @class */ (function () {
function IgxTabsComponent(_element) {
this._element = _element;
/**
* Defines the tab header sizing mode. You can choose between `contentfit` or `fixed`.
* By default the header sizing mode is `contentfit`.
* ```html
* <igx-tabs tabsType="fixed">
* <igx-tabs-group label="HOME">Home</igx-tabs-group>
* </igx-tabs>
* ```
*/
this.tabsType = 'contentfit';
/**
* @hidden
*/
this.class = '';
/**
* Emitted when a tab item is deselected.
* ```html
* <igx-tabs (onTabItemDeselected)="itemDeselected($event)">
* <igx-tabs-group label="Tab 1">This is Tab 1 content.</igx-tabs-group>
* <igx-tabs-group label="Tab 2">This is Tab 2 content.</igx-tabs-group>
* </igx-tabs>
* ```
* ```typescript
* itemDeselected(e){
* const tabGroup = e.group;
* const tabItem = e.tab;
* }
* ```
*/
this.onTabItemDeselected = new EventEmitter();
/**
* Emitted when a tab item is selected.
* ```html
* <igx-tabs (onTabItemSelected)="itemSelected($event)">
* <igx-tabs-group label="Tab 1">This is Tab 1 content.</igx-tabs-group>
* <igx-tabs-group label="Tab 2">This is Tab 2 content.</igx-tabs-group>
* </igx-tabs>
* ```
* ```typescript
* itemSelected(e){
* const tabGroup = e.group;
* const tabItem = e.tab;
* }
* ```
*/
this.onTabItemSelected = new EventEmitter();
/**
* @hidden
*/
this.offset = 0;
this._selectedIndex = 0;
}
Object.defineProperty(IgxTabsComponent.prototype, "selectedIndex", {
/**
* An @Input property that sets the value of the `selectedIndex`.
* Default value is 0.
* ```html
* <igx-tabs selectedIndex="1">
* ```
*/
get: /**
* An \@Input property that sets the value of the `selectedIndex`.
* Default value is 0.
* ```html
* <igx-tabs selectedIndex="1">
* ```
* @return {?}
*/
function () {
return this._selectedIndex;
},
set: /**
* @param {?} index
* @return {?}
*/
function (index) {
this._selectedIndex = index;
this.setSelectedGroup();
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxTabsComponent.prototype, "cssClass", {
/**
* @hidden
*/
get: /**
* @hidden
* @return {?}
*/
function () {
/** @type {?} */
var defaultStyle = "igx-tabs";
/** @type {?} */
var fixedStyle = "igx-tabs--fixed";
/** @type {?} */
var iconStyle = "igx-tabs--icons";
/** @type {?} */
var iconLabelFound = this.groups.find(function (group) { return group.icon != null && group.label != null; });
/** @type {?} */
var css;
switch (TabsType[this.tabsType.toUpperCase()]) {
case TabsType.FIXED: {
css = fixedStyle;
break;
}
default: {
css = defaultStyle;
break;
}
}
// Layout fix for items with icons
if (iconLabelFound !== undefined) {
css = css + " " + iconStyle;
}
return css + " " + this.class;
},
enumerable: true,
configurable: true
});
/**
* @hidden
*/
/**
* @hidden
* @param {?} args
* @return {?}
*/
IgxTabsComponent.prototype.selectedGroupHandler = /**
* @hidden
* @param {?} args
* @return {?}
*/
function (args) {
var _this = this;
/** @type {?} */
var prevSelectedIndex = this.selectedIndex;
if (prevSelectedIndex !== -1 && this.groups.toArray()[prevSelectedIndex] !== undefined) {
this.onTabItemDeselected.emit({
tab: this.groups.toArray()[prevSelectedIndex].relatedTab,
group: this.groups.toArray()[prevSelectedIndex]
});
}
this.selectedIndex = args.group.index;
this.groups.forEach(function (p) {
if (p.index !== _this.selectedIndex) {
_this.deselectGroup(p);
}
});
};
/**
* @hidden
*/
/**
* @hidden
* @param {?} event
* @return {?}
*/
IgxTabsComponent.prototype.scrollLeft = /**
* @hidden
* @param {?} event
* @return {?}
*/
function (event) {
this.scroll(false);
};
/**
* @hidden
*/
/**
* @hidden
* @param {?} event
* @return {?}
*/
IgxTabsComponent.prototype.scrollRight = /**
* @hidden
* @param {?} event
* @return {?}
*/
function (event) {
this.scroll(true);
};
/**
* @hidden
*/
/**
* @hidden
* @param {?} element
* @param {?} scrollRight
* @return {?}
*/
IgxTabsComponent.prototype.scrollElement = /**
* @hidden
* @param {?} element
* @param {?} scrollRight
* @return {?}
*/
function (element, scrollRight) {
/** @type {?} */
var viewPortWidth = this.viewPort.nativeElement.offsetWidth;
this.offset = (scrollRight) ? element.offsetWidth + element.offsetLeft - viewPortWidth : element.offsetLeft;
this.itemsContainer.nativeElement.style.transform = "translate(" + -this.offset + "px)";
};
Object.defineProperty(IgxTabsComponent.prototype, "selectedTabItem", {
/**
* Gets the selected `IgxTabItemComponent`.
* ```
* const selectedItem = this.myTabComponent.selectedTabItem;
* ```
*/
get: /**
* Gets the selected `IgxTabItemComponent`.
* ```
* const selectedItem = this.myTabComponent.selectedTabItem;
* ```
* @return {?}
*/
function () {
if (this.tabs && this.selectedIndex !== undefined) {
return this.tabs.toArray()[this.selectedIndex];
}
},
enumerable: true,
configurable: true
});
/**
* @hidden
*/
/**
* @hidden
* @return {?}
*/
IgxTabsComponent.prototype.ngAfterViewInit = /**
* @hidden
* @return {?}
*/
function () {
var _this = this;
this.setSelectedGroup();
this._groupChanges$ = this.groups.changes.subscribe(function () {
_this.resetSelectionOnCollectionChanged();
});
};
/**
* @hidden
*/
/**
* @hidden
* @return {?}
*/
IgxTabsComponent.prototype.ngOnDestroy = /**
* @hidden
* @return {?}
*/
function () {
if (this._groupChanges$) {
this._groupChanges$.unsubscribe();
}
};
/**
* @private
* @return {?}
*/
IgxTabsComponent.prototype.setSelectedGroup = /**
* @private
* @return {?}
*/
function () {
var _this = this;
requestAnimationFrame(function () {
if (_this.selectedIndex <= 0 || _this.selectedIndex >= _this.groups.length) {
// if nothing is selected - select the first tabs group
_this.selectGroupByIndex(0);
}
else {
_this.selectGroupByIndex(_this.selectedIndex);
}
});
};
/**
* @private
* @return {?}
*/
IgxTabsComponent.prototype.resetSelectionOnCollectionChanged = /**
* @private
* @return {?}
*/
function () {
var _this = this;
setTimeout(function () {
if (_this.groups.toArray()[_this.selectedIndex] !== undefined) {
// persist the selected index and applied it to the new collection
_this.selectGroupByIndex(_this.selectedIndex);
}
else {
if (_this.selectedIndex >= _this.groups.length) {
// in case the selected index is no longer valid, select the last group in the new collection
_this.selectGroupByIndex(_this.groups.length - 1);
}
}
}, 0);
};
/**
* @private
* @param {?} selectedIndex
* @return {?}
*/
IgxTabsComponent.prototype.selectGroupByIndex = /**
* @private
* @param {?} selectedIndex
* @return {?}
*/
function (selectedIndex) {
/** @type {?} */
var selectableGroups = this.groups.filter(function (selectableGroup) { return !selectableGroup.disabled; });
/** @type {?} */
var group = selectableGroups[selectedIndex];
if (group) {
group.select(0);
}
};
/**
* @private
* @param {?} group
* @return {?}
*/
IgxTabsComponent.prototype.deselectGroup = /**
* @private
* @param {?} group
* @return {?}
*/
function (group) {
// Cannot deselect the selected tab - this will mean that there will be not selected tab left
if (group.disabled || this.selectedTabItem.index === group.index) {
return;
}
group.isSelected = false;
group.relatedTab.tabindex = -1;
};
/**
* @private
* @param {?} scrollRight
* @return {?}
*/
IgxTabsComponent.prototype.scroll = /**
* @private
* @param {?} scrollRight
* @return {?}
*/
function (scrollRight) {
var e_1, _a;
/** @type {?} */
var tabsArray = this.tabs.toArray();
try {
for (var tabsArray_1 = tslib_1.__values(tabsArray), tabsArray_1_1 = tabsArray_1.next(); !tabsArray_1_1.done; tabsArray_1_1 = tabsArray_1.next()) {
var tab = tabsArray_1_1.value;
/** @type {?} */
var element = tab.nativeTabItem.nativeElement;
if (scrollRight) {
if (element.offsetWidth + element.offsetLeft > this.viewPort.nativeElement.offsetWidth + this.offset) {
this.scrollElement(element, scrollRight);
break;
}
}
else {
if (element.offsetWidth + element.offsetLeft >= this.offset) {
this.scrollElement(element, scrollRight);
break;
}
}
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (tabsArray_1_1 && !tabsArray_1_1.done && (_a = tabsArray_1.return)) _a.call(tabsArray_1);
}
finally { if (e_1) throw e_1.error; }
}
};
IgxTabsComponent.decorators = [
{ type: Component, args: [{
selector: 'igx-tabs',
template: "<!-- TODO Remove tab container from here -->\n<div #tabsContainer>\n <div class=\"igx-tabs__header\" #headerContainer>\n <button igxRipple class=\"igx-tabs__header-button\" igxButton=\"icon\" (click)=\"scrollLeft($event)\" igxLeftButtonStyle>\n <igx-icon fontSet=\"material\">navigate_before</igx-icon>\n </button>\n <div class=\"igx-tabs__header-wrapper-fixed\" #viewPort>\n <div #itemsContainer class=\"igx-tabs__header-wrapper-fluid\">\n <igx-tab-item igxRipple *ngFor=\"let group of groups\" [id]=\"'igx-tab-item-' + group.index\" [attr.aria-label]=\"group.label\"\n [attr.aria-disabled]=\"group.disabled\" [attr.aria-selected]=\"group.isSelected\" [attr.aria-controls]=\"'igx-tab-item-group-'+ group.index\"\n [ngClass]=\"{\n 'igx-tabs__header-menu-item': !group.isSelected && !group.disabled,\n 'igx-tabs__header-menu-item--selected': group.isSelected,\n 'igx-tabs__header-menu-item--disabled': group.disabled }\" [relatedGroup]=\"group\" role=\"tab\">\n </igx-tab-item>\n <div #selectedIndicator *ngIf=\"groups.length > 0\" class=\"igx-tabs__header-menu-item-indicator\"></div>\n </div>\n </div>\n <button igxRipple class=\"igx-tabs__header-button\" igxButton=\"icon\" (click)=\"scrollRight($event)\" igxRightButtonStyle>\n <igx-icon fontSet=\"material\">navigate_next</igx-icon>\n </button>\n </div>\n <div class=\"igx-tabs__content-fixed\">\n <div #contentsContainer class=\"igx-tabs__content-fluid\">\n <ng-content></ng-content>\n </div>\n </div>\n</div>",
providers: [{ provide: IgxTabsBase, useExisting: IgxTabsComponent }]
}] }
];
/** @nocollapse */
IgxTabsComponent.ctorParameters = function () { return [
{ type: ElementRef }
]; };
IgxTabsComponent.propDecorators = {
groups: [{ type: ContentChildren, args: [forwardRef(function () { return IgxTabsGroupComponent; }),] }],
selectedIndex: [{ type: Input }],
tabsType: [{ type: Input, args: ['tabsType',] }],
class: [{ type: Input }],
onTabItemDeselected: [{ type: Output }],
onTabItemSelected: [{ type: Output }],
contentsContainer: [{ type: ViewChild, args: ['contentsContainer',] }],
headerContainer: [{ type: ViewChild, args: ['headerContainer',] }],
itemsContainer: [{ type: ViewChild, args: ['itemsContainer',] }],
selectedIndicator: [{ type: ViewChild, args: ['selectedIndicator',] }],
tabsContainer: [{ type: ViewChild, args: ['tabsContainer',] }],
viewPort: [{ type: ViewChild, args: ['viewPort',] }],
tabs: [{ type: ViewChildren, args: [forwardRef(function () { return IgxTabItemComponent; }),] }],
cssClass: [{ type: HostBinding, args: ['attr.class',] }],
selectedGroupHandler: [{ type: HostListener, args: ['onTabItemSelected', ['$event'],] }]
};
return IgxTabsComponent;
}());
export { IgxTabsComponent };
if (false) {
/**
* Provides an observable collection of all `IgxTabsGroupComponent`s.
* ```typescript
* const groupItems = this.myTabComponent.tabs;
* ```
* @type {?}
*/
IgxTabsComponent.prototype.groups;
/**
* Defines the tab header sizing mode. You can choose between `contentfit` or `fixed`.
* By default the header sizing mode is `contentfit`.
* ```html
* <igx-tabs tabsType="fixed">
* <igx-tabs-group label="HOME">Home</igx-tabs-group>
* </igx-tabs>
* ```
* @type {?}
*/
IgxTabsComponent.prototype.tabsType;
/**
* @hidden
* @type {?}
*/
IgxTabsComponent.prototype.class;
/**
* Emitted when a tab item is deselected.
* ```html
* <igx-tabs (onTabItemDeselected)="itemDeselected($event)">
* <igx-tabs-group label="Tab 1">This is Tab 1 content.</igx-tabs-group>
* <igx-tabs-group label="Tab 2">This is Tab 2 content.</igx-tabs-group>
* </igx-tabs>
* ```
* ```typescript
* itemDeselected(e){
* const tabGroup = e.group;
* const tabItem = e.tab;
* }
* ```
* @type {?}
*/
IgxTabsComponent.prototype.onTabItemDeselected;
/**
* Emitted when a tab item is selected.
* ```html
* <igx-tabs (onTabItemSelected)="itemSelected($event)">
* <igx-tabs-group label="Tab 1">This is Tab 1 content.</igx-tabs-group>
* <igx-tabs-group label="Tab 2">This is Tab 2 content.</igx-tabs-group>
* </igx-tabs>
* ```
* ```typescript
* itemSelected(e){
* const tabGroup = e.group;
* const tabItem = e.tab;
* }
* ```
* @type {?}
*/
IgxTabsComponent.prototype.onTabItemSelected;
/**
* @hidden
* @type {?}
*/
IgxTabsComponent.prototype.contentsContainer;
/**
* @hidden
* @type {?}
*/
IgxTabsComponent.prototype.headerContainer;
/**
* @hidden
* @type {?}
*/
IgxTabsComponent.prototype.itemsContainer;
/**
* @hidden
* @type {?}
*/
IgxTabsComponent.prototype.selectedIndicator;
/**
* @hidden
* @type {?}
*/
IgxTabsComponent.prototype.tabsContainer;
/**
* @hidden
* @type {?}
*/
IgxTabsComponent.prototype.viewPort;
/**
* Provides an observable collection of all `IgxTabItemComponent`s.
* ```typescript
* const tabItems = this.myTabComponent.tabs;
* ```
* @type {?}
*/
IgxTabsComponent.prototype.tabs;
/**
* @hidden
* @type {?}
*/
IgxTabsComponent.prototype.calculatedWidth;
/**
* @hidden
* @type {?}
*/
IgxTabsComponent.prototype.visibleItemsWidth;
/**
* @hidden
* @type {?}
*/
IgxTabsComponent.prototype.offset;
/**
* @type {?}
* @private
*/
IgxTabsComponent.prototype._groupChanges$;
/**
* @type {?}
* @private
*/
IgxTabsComponent.prototype._selectedIndex;
/**
* @type {?}
* @private
*/
IgxTabsComponent.prototype._element;
}
/**
* @hidden
*/
var IgxTabsModule = /** @class */ (function () {
function IgxTabsModule() {
}
IgxTabsModule.decorators = [
{ type: NgModule, args: [{
declarations: [IgxTabsComponent,
IgxTabsGroupComponent,
IgxTabItemComponent,
IgxTabItemTemplateDirective,
IgxRightButtonStyleDirective,
IgxLeftButtonStyleDirective],
exports: [IgxTabsComponent,
IgxTabsGroupComponent,
IgxTabItemComponent,
IgxTabItemTemplateDirective,
IgxRightButtonStyleDirective,
IgxLeftButtonStyleDirective],
imports: [CommonModule, IgxBadgeModule, IgxIconModule, IgxRippleModule]
},] }
];
return IgxTabsModule;
}());
export { IgxTabsModule };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tabs.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/tabs/tabs.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n    AfterViewInit,\n    Component,\n    ContentChildren,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    HostBinding,\n    HostListener,\n    Input,\n    NgModule,\n    Output,\n    QueryList,\n    ViewChild,\n    ViewChildren,\n    OnDestroy\n} from '@angular/core';\nimport { Subscription } from 'rxjs';\nimport { IgxBadgeModule } from '../badge/badge.component';\nimport { IgxRippleModule } from '../directives/ripple/ripple.directive';\nimport { IgxIconModule } from '../icon/index';\nimport { IgxTabItemComponent } from './tab-item.component';\nimport { IgxTabsGroupComponent } from './tabs-group.component';\nimport { IgxLeftButtonStyleDirective, IgxRightButtonStyleDirective, IgxTabItemTemplateDirective } from './tabs.directives';\nimport { IgxTabsBase } from './tabs.common';\n\nexport enum TabsType {\n    FIXED = 'fixed',\n    CONTENTFIT = 'contentfit'\n}\n\n@Component({\n    selector: 'igx-tabs',\n    templateUrl: 'tabs.component.html',\n    providers: [{ provide: IgxTabsBase, useExisting: IgxTabsComponent }]\n})\n\nexport class IgxTabsComponent implements IgxTabsBase, AfterViewInit, OnDestroy {\n\n    /**\n    * Provides an observable collection of all `IgxTabsGroupComponent`s.\n    * ```typescript\n    * const groupItems = this.myTabComponent.tabs;\n    * ```\n    */\n    @ContentChildren(forwardRef(() => IgxTabsGroupComponent))\n    public groups: QueryList<IgxTabsGroupComponent>;\n\n    /**\n    * An @Input property that sets the value of the `selectedIndex`.\n    * Default value is 0.\n    * ```html\n    * <igx-tabs selectedIndex=\"1\">\n    * ```\n    */\n    @Input()\n    public get selectedIndex(): number {\n        return this._selectedIndex;\n    }\n\n    public set selectedIndex(index: number) {\n        this._selectedIndex = index;\n        this.setSelectedGroup();\n    }\n\n    /**\n     * Defines the tab header sizing mode. You can choose between `contentfit` or `fixed`.\n     * By default the header sizing mode is `contentfit`.\n     * ```html\n     * <igx-tabs tabsType=\"fixed\">\n     *     <igx-tabs-group label=\"HOME\">Home</igx-tabs-group>\n     * </igx-tabs>\n     * ```\n     */\n    @Input('tabsType')\n    public tabsType: string | TabsType = 'contentfit';\n\n    /**\n    * @hidden\n    */\n    @Input()\n    public class = '';\n\n    /**\n     * Emitted when a tab item is deselected.\n     * ```html\n     * <igx-tabs (onTabItemDeselected)=\"itemDeselected($event)\">\n     *      <igx-tabs-group label=\"Tab 1\">This is Tab 1 content.</igx-tabs-group>\n     *      <igx-tabs-group label=\"Tab 2\">This is Tab 2 content.</igx-tabs-group>\n     * </igx-tabs>\n     * ```\n     * ```typescript\n     * itemDeselected(e){\n     *      const tabGroup = e.group;\n     *      const tabItem = e.tab;\n     * }\n     * ```\n     */\n    @Output() public onTabItemDeselected = new EventEmitter();\n\n    /**\n    * Emitted when a tab item is selected.\n    * ```html\n    * <igx-tabs (onTabItemSelected)=\"itemSelected($event)\">\n    *      <igx-tabs-group label=\"Tab 1\">This is Tab 1 content.</igx-tabs-group>\n    *      <igx-tabs-group label=\"Tab 2\">This is Tab 2 content.</igx-tabs-group>\n    * </igx-tabs>\n    * ```\n    * ```typescript\n    * itemSelected(e){\n    *      const tabGroup = e.group;\n    *      const tabItem = e.tab;\n    * }\n    * ```\n    */\n    @Output() public onTabItemSelected = new EventEmitter();\n\n    /**\n     * @hidden\n     */\n    @ViewChild('contentsContainer')\n    public contentsContainer: ElementRef;\n\n    /**\n     * @hidden\n     */\n    @ViewChild('headerContainer')\n    public headerContainer: ElementRef;\n\n    /**\n     * @hidden\n     */\n    @ViewChild('itemsContainer')\n    public itemsContainer: ElementRef;\n\n    /**\n     * @hidden\n     */\n    @ViewChild('selectedIndicator')\n    public selectedIndicator: ElementRef;\n\n    /**\n    * @hidden\n    */\n    @ViewChild('tabsContainer')\n    public tabsContainer: ElementRef;\n\n    /**\n     * @hidden\n     */\n    @ViewChild('viewPort')\n    public viewPort: ElementRef;\n\n    /**\n     * Provides an observable collection of all `IgxTabItemComponent`s.\n     * ```typescript\n     * const tabItems = this.myTabComponent.tabs;\n     * ```\n     */\n    @ViewChildren(forwardRef(() => IgxTabItemComponent))\n    public tabs: QueryList<IgxTabItemComponent>;\n\n    /**\n     * @hidden\n     */\n    public calculatedWidth: number;\n\n    /**\n     * @hidden\n     */\n    public visibleItemsWidth: number;\n\n    /**\n     * @hidden\n     */\n    public offset = 0;\n\n    private _groupChanges$: Subscription;\n    private _selectedIndex = 0;\n\n    /**\n     * @hidden\n     */\n    @HostBinding('attr.class')\n    public get cssClass() {\n        const defaultStyle = `igx-tabs`;\n        const fixedStyle = `igx-tabs--fixed`;\n        const iconStyle = `igx-tabs--icons`;\n        const iconLabelFound = this.groups.find((group) => group.icon != null && group.label != null);\n        let css;\n        switch (TabsType[this.tabsType.toUpperCase()]) {\n            case TabsType.FIXED: {\n                css = fixedStyle;\n                break;\n            }\n            default: {\n                css = defaultStyle;\n                break;\n            }\n        }\n\n        // Layout fix for items with icons\n        if (iconLabelFound !== undefined) {\n            css = `${css} ${iconStyle}`;\n        }\n\n        return `${css} ${this.class}`;\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('onTabItemSelected', ['$event'])\n    public selectedGroupHandler(args) {\n        const prevSelectedIndex = this.selectedIndex;\n        if (prevSelectedIndex !== -1 && this.groups.toArray()[prevSelectedIndex] !== undefined) {\n            this.onTabItemDeselected.emit(\n                {\n                    tab: this.groups.toArray()[prevSelectedIndex].relatedTab,\n                    group: this.groups.toArray()[prevSelectedIndex]\n                });\n        }\n\n        this.selectedIndex = args.group.index;\n        this.groups.forEach((p) => {\n            if (p.index !== this.selectedIndex) {\n                this.deselectGroup(p);\n            }\n        });\n    }\n\n    /**\n     * @hidden\n     */\n    public scrollLeft(event): void {\n        this.scroll(false);\n    }\n\n    /**\n     * @hidden\n     */\n    public scrollRight(event): void {\n        this.scroll(true);\n    }\n\n    /**\n     * @hidden\n     */\n    public scrollElement(element: any, scrollRight: boolean): void {\n        const viewPortWidth = this.viewPort.nativeElement.offsetWidth;\n\n        this.offset = (scrollRight) ? element.offsetWidth + element.offsetLeft - viewPortWidth : element.offsetLeft;\n        this.itemsContainer.nativeElement.style.transform = `translate(${-this.offset}px)`;\n    }\n\n    /**\n     * Gets the selected `IgxTabItemComponent`.\n     * ```\n     * const selectedItem = this.myTabComponent.selectedTabItem;\n     * ```\n     */\n    get selectedTabItem(): IgxTabItemComponent {\n        if (this.tabs && this.selectedIndex !== undefined) {\n            return this.tabs.toArray()[this.selectedIndex];\n        }\n    }\n\n    constructor(private _element: ElementRef) {\n    }\n\n    /**\n     * @hidden\n     */\n    public ngAfterViewInit() {\n        this.setSelectedGroup();\n        this._groupChanges$ = this.groups.changes.subscribe(() => {\n            this.resetSelectionOnCollectionChanged();\n        });\n    }\n\n    /**\n     * @hidden\n     */\n    public ngOnDestroy(): void {\n        if (this._groupChanges$) {\n            this._groupChanges$.unsubscribe();\n        }\n    }\n\n    private setSelectedGroup(): void {\n        requestAnimationFrame(() => {\n            if (this.selectedIndex <= 0 || this.selectedIndex >= this.groups.length) {\n                // if nothing is selected - select the first tabs group\n                this.selectGroupByIndex(0);\n            } else {\n                this.selectGroupByIndex(this.selectedIndex);\n            }\n        });\n    }\n\n    private resetSelectionOnCollectionChanged(): void {\n        setTimeout(() => {\n            if (this.groups.toArray()[this.selectedIndex] !== undefined) {\n                // persist the selected index and applied it to the new collection\n                this.selectGroupByIndex(this.selectedIndex);\n            } else {\n                if (this.selectedIndex >= this.groups.length) {\n                    // in case the selected index is no longer valid, select the last group in the new collection\n                    this.selectGroupByIndex(this.groups.length - 1);\n                }\n            }\n        }, 0);\n    }\n\n    private selectGroupByIndex(selectedIndex: number): void {\n        const selectableGroups = this.groups.filter((selectableGroup) => !selectableGroup.disabled);\n        const group = selectableGroups[selectedIndex];\n\n        if (group) {\n            group.select(0);\n        }\n    }\n\n    private deselectGroup(group: IgxTabsGroupComponent): void {\n        // Cannot deselect the selected tab - this will mean that there will be not selected tab left\n        if (group.disabled || this.selectedTabItem.index === group.index) {\n            return;\n        }\n\n        group.isSelected = false;\n        group.relatedTab.tabindex = -1;\n    }\n\n    private scroll(scrollRight: boolean): void {\n        const tabsArray = this.tabs.toArray();\n        for (const tab of tabsArray) {\n            const element = tab.nativeTabItem.nativeElement;\n            if (scrollRight) {\n                if (element.offsetWidth + element.offsetLeft > this.viewPort.nativeElement.offsetWidth + this.offset) {\n                    this.scrollElement(element, scrollRight);\n                    break;\n                }\n            } else {\n                if (element.offsetWidth + element.offsetLeft >= this.offset) {\n                    this.scrollElement(element, scrollRight);\n                    break;\n                }\n            }\n        }\n    }\n}\n\n/**\n * @hidden\n */\n@NgModule({\n    declarations: [IgxTabsComponent,\n        IgxTabsGroupComponent,\n        IgxTabItemComponent,\n        IgxTabItemTemplateDirective,\n        IgxRightButtonStyleDirective,\n        IgxLeftButtonStyleDirective],\n    exports: [IgxTabsComponent,\n        IgxTabsGroupComponent,\n        IgxTabItemComponent,\n        IgxTabItemTemplateDirective,\n        IgxRightButtonStyleDirective,\n        IgxLeftButtonStyleDirective],\n    imports: [CommonModule, IgxBadgeModule, IgxIconModule, IgxRippleModule]\n})\n\nexport class IgxTabsModule {\n}\n"]}