igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
358 lines • 24.7 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, ContentChild, ElementRef, HostBinding, Input, HostListener } from '@angular/core';
import { IgxTabItemTemplateDirective } from './tabs.directives';
import { IgxTabsBase } from './tabs.common';
var IgxTabsGroupComponent = /** @class */ (function () {
function IgxTabsGroupComponent(_tabs, _element) {
this._tabs = _tabs;
this._element = _element;
/**
* An \@Input property that allows you to enable/disable the `IgxTabGroupComponent`.
* ```html
* <igx-tabs-group label="Tab 2 Lorem ipsum dolor sit" icon="home" [disabled]="true">
* ```
*/
this.disabled = false;
this.isSelected = false;
/**
* @hidden
*/
this.role = 'tabpanel';
/**
* @hidden
*/
this.styleClass = true;
}
/**
* @param {?} event
* @return {?}
*/
IgxTabsGroupComponent.prototype.onResize = /**
* @param {?} event
* @return {?}
*/
function (event) {
if (this.isSelected) {
this.transformContentAnimation(0);
}
};
Object.defineProperty(IgxTabsGroupComponent.prototype, "relatedTab", {
/**
* An accessor that returns the `IgxTabItemComponent` component.
* ```typescript
* @ViewChild("MyTabsGroup")
* public tab: IgxTabsGroupComponent;
* ngAfterViewInIt(){
* let tabComponent = this.tab.relatedTab;
* }
* ```
*/
get: /**
* An accessor that returns the `IgxTabItemComponent` component.
* ```typescript
* \@ViewChild("MyTabsGroup")
* public tab: IgxTabsGroupComponent;
* ngAfterViewInIt(){
* let tabComponent = this.tab.relatedTab;
* }
* ```
* @return {?}
*/
function () {
if (this._tabs.tabs) {
return (/** @type {?} */ (this._tabs.tabs.toArray()[this.index]));
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxTabsGroupComponent.prototype, "index", {
/**
* An accessor that returns the value of the index of the `IgxTabsGroupComponent`.
* ```typescript
* @ViewChild("MyTabsGroup")
* public tab: IgxTabsGroupComponent;
* ngAfterViewInIt(){
* let tabIndex = this.tab.index;
* }
* ```
*/
get: /**
* An accessor that returns the value of the index of the `IgxTabsGroupComponent`.
* ```typescript
* \@ViewChild("MyTabsGroup")
* public tab: IgxTabsGroupComponent;
* ngAfterViewInIt(){
* let tabIndex = this.tab.index;
* }
* ```
* @return {?}
*/
function () {
if (this._tabs.groups) {
return this._tabs.groups.toArray().indexOf(this);
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxTabsGroupComponent.prototype, "customTabTemplate", {
/**
* @hidden
*/
get: /**
* @hidden
* @return {?}
*/
function () {
return this._tabTemplate;
},
/**
*@hidden
*/
set: /**
* @hidden
* @param {?} template
* @return {?}
*/
function (template) {
this._tabTemplate = template;
},
enumerable: true,
configurable: true
});
/**
* @hidden
*/
/**
* @hidden
* @return {?}
*/
IgxTabsGroupComponent.prototype.ngAfterContentInit = /**
* @hidden
* @return {?}
*/
function () {
if (this.tabTemplate) {
this._tabTemplate = this.tabTemplate.template;
}
};
/**
* @hidden
*/
/**
* @hidden
* @return {?}
*/
IgxTabsGroupComponent.prototype.ngAfterViewChecked = /**
* @hidden
* @return {?}
*/
function () {
this._element.nativeElement.setAttribute('aria-labelledby', "igx-tab-item-" + this.index);
this._element.nativeElement.setAttribute('id', "igx-tabs__group-" + this.index);
if (this.isSelected) {
/** @type {?} */
var tabItem = this.relatedTab.nativeTabItem.nativeElement;
this.transformContentAnimation(0);
this.transformIndicatorAnimation(tabItem);
}
};
/**
* A method that sets the focus on a tab.
* @memberof {@link IgxTabsGroupComponent}
*```typescript
*@ViewChild("MyChild")
*public tab : IgxTabsGroupComponent;
*ngAfterViewInit(){
* this.tab.select();
*}
*```
* @param focusDelay A number representing the expected delay.
*/
/**
* A method that sets the focus on a tab.
* \@memberof {\@link IgxTabsGroupComponent}
* ```typescript
* \@ViewChild("MyChild")
* public tab : IgxTabsGroupComponent;
* ngAfterViewInit(){
* this.tab.select();
* }
* ```
* @param {?=} focusDelay A number representing the expected delay.
* @return {?}
*/
IgxTabsGroupComponent.prototype.select = /**
* A method that sets the focus on a tab.
* \@memberof {\@link IgxTabsGroupComponent}
* ```typescript
* \@ViewChild("MyChild")
* public tab : IgxTabsGroupComponent;
* ngAfterViewInit(){
* this.tab.select();
* }
* ```
* @param {?=} focusDelay A number representing the expected delay.
* @return {?}
*/
function (focusDelay) {
var _this = this;
if (focusDelay === void 0) { focusDelay = 200; }
if (this.disabled || this.isSelected) {
return;
}
this.isSelected = true;
this.relatedTab.tabindex = 0;
if (focusDelay !== 0) {
setTimeout(function () {
_this.relatedTab.nativeTabItem.nativeElement.focus();
}, focusDelay);
}
this.handleSelection();
this._tabs.onTabItemSelected.emit({ tab: this._tabs.tabs.toArray()[this.index], group: this });
};
/**
* @private
* @return {?}
*/
IgxTabsGroupComponent.prototype.handleSelection = /**
* @private
* @return {?}
*/
function () {
/** @type {?} */
var tabElement = this.relatedTab.nativeTabItem.nativeElement;
// Scroll to the left
if (tabElement.offsetLeft < this._tabs.offset) {
this._tabs.scrollElement(tabElement, false);
}
// Scroll to the right
/** @type {?} */
var viewPortOffsetWidth = this._tabs.viewPort.nativeElement.offsetWidth;
/** @type {?} */
var delta = (tabElement.offsetLeft + tabElement.offsetWidth) - (viewPortOffsetWidth + this._tabs.offset);
// Fix for IE 11, a difference is accumulated from the widths calculations
if (delta > 1) {
this._tabs.scrollElement(tabElement, true);
}
this.transformContentAnimation(0.2);
this.transformIndicatorAnimation(tabElement);
};
/**
* @private
* @param {?} duration
* @return {?}
*/
IgxTabsGroupComponent.prototype.transformContentAnimation = /**
* @private
* @param {?} duration
* @return {?}
*/
function (duration) {
/** @type {?} */
var contentOffset = this._tabs.tabsContainer.nativeElement.offsetWidth * this.index;
this._tabs.contentsContainer.nativeElement.style.transitionDuration = duration + "s";
this._tabs.contentsContainer.nativeElement.style.transform = "translate(" + -contentOffset + "px)";
};
/**
* @private
* @param {?} element
* @return {?}
*/
IgxTabsGroupComponent.prototype.transformIndicatorAnimation = /**
* @private
* @param {?} element
* @return {?}
*/
function (element) {
this._tabs.selectedIndicator.nativeElement.style.width = element.offsetWidth + "px";
this._tabs.selectedIndicator.nativeElement.style.transform = "translate(" + element.offsetLeft + "px)";
};
IgxTabsGroupComponent.decorators = [
{ type: Component, args: [{
selector: 'igx-tabs-group',
template: "<ng-content *ngIf=\"isSelected\"></ng-content>\n"
}] }
];
/** @nocollapse */
IgxTabsGroupComponent.ctorParameters = function () { return [
{ type: IgxTabsBase },
{ type: ElementRef }
]; };
IgxTabsGroupComponent.propDecorators = {
disabled: [{ type: Input }],
icon: [{ type: Input }],
label: [{ type: Input }],
tabTemplate: [{ type: ContentChild, args: [IgxTabItemTemplateDirective, { read: IgxTabItemTemplateDirective },] }],
role: [{ type: HostBinding, args: ['attr.role',] }],
styleClass: [{ type: HostBinding, args: ['class.igx-tabs__group',] }],
onResize: [{ type: HostListener, args: ['window:resize', ['$event'],] }]
};
return IgxTabsGroupComponent;
}());
export { IgxTabsGroupComponent };
if (false) {
/**
* An \@Input property that allows you to enable/disable the `IgxTabGroupComponent`.
* ```html
* <igx-tabs-group label="Tab 2 Lorem ipsum dolor sit" icon="home" [disabled]="true">
* ```
* @type {?}
*/
IgxTabsGroupComponent.prototype.disabled;
/**
* An \@Input property that sets the value of the `icon`.
* The value should be valid icon name from {\@link https://material.io/tools/icons/?style=baseline}.
* ```html
* <igx-tabs-group label="Tab 1" icon="home">
* ```
* @type {?}
*/
IgxTabsGroupComponent.prototype.icon;
/**
* An \@Input property that sets the value of the `label`.
* ```html
* <igx-tabs-group label="Tab 1" icon="folder">
* ```
* @type {?}
*/
IgxTabsGroupComponent.prototype.label;
/** @type {?} */
IgxTabsGroupComponent.prototype.isSelected;
/**
* @hidden
* @type {?}
* @protected
*/
IgxTabsGroupComponent.prototype.tabTemplate;
/**
* @type {?}
* @private
*/
IgxTabsGroupComponent.prototype._tabTemplate;
/**
* @hidden
* @type {?}
*/
IgxTabsGroupComponent.prototype.role;
/**
* @hidden
* @type {?}
*/
IgxTabsGroupComponent.prototype.styleClass;
/**
* @type {?}
* @private
*/
IgxTabsGroupComponent.prototype._tabs;
/**
* @type {?}
* @private
*/
IgxTabsGroupComponent.prototype._element;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tabs-group.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/tabs/tabs-group.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterContentInit,\n    AfterViewChecked,\n    Component,\n    ContentChild,\n    ElementRef,\n    HostBinding,\n    Input,\n    TemplateRef,\n    HostListener\n} from '@angular/core';\n\nimport { IgxTabItemComponent } from './tab-item.component';\nimport { IgxTabItemTemplateDirective } from './tabs.directives';\nimport { IgxTabsBase, IgxTabsGroupBase } from './tabs.common';\n\n@Component({\n    selector: 'igx-tabs-group',\n    templateUrl: 'tabs-group.component.html'\n})\n\nexport class IgxTabsGroupComponent implements IgxTabsGroupBase, AfterContentInit, AfterViewChecked {\n\n    /**\n    * An @Input property that allows you to enable/disable the `IgxTabGroupComponent`.\n    *```html\n    *<igx-tabs-group label=\"Tab 2  Lorem ipsum dolor sit\" icon=\"home\" [disabled]=\"true\">\n    *```\n    */\n    @Input()\n    public disabled = false;\n\n    /**\n    * An @Input property that sets the value of the `icon`.\n    * The value should be valid icon name from {@link https://material.io/tools/icons/?style=baseline}.\n    *```html\n    *<igx-tabs-group label=\"Tab 1\" icon=\"home\">\n    *```\n    */\n    @Input()\n    public icon: string;\n\n    /**\n    * An @Input property that sets the value of the `label`.\n    *```html\n    *<igx-tabs-group label=\"Tab 1\" icon=\"folder\">\n    *```\n    */\n    @Input()\n    public label: string;\n\n    public isSelected = false;\n\n    /**\n     * @hidden\n     */\n    @ContentChild(IgxTabItemTemplateDirective, { read: IgxTabItemTemplateDirective })\n    protected tabTemplate: IgxTabItemTemplateDirective;\n\n    private _tabTemplate: TemplateRef<any>;\n\n    constructor(private _tabs: IgxTabsBase, private _element: ElementRef) {\n    }\n\n    /**\n     * @hidden\n     */\n    @HostBinding('attr.role')\n    public role = 'tabpanel';\n\n    /**\n     * @hidden\n     */\n    @HostBinding('class.igx-tabs__group')\n    public styleClass = true;\n\n    @HostListener('window:resize', ['$event'])\n    public onResize(event) {\n        if (this.isSelected) {\n            this.transformContentAnimation(0);\n        }\n    }\n\n    /**\n     * An accessor that returns the `IgxTabItemComponent` component.\n     * ```typescript\n     * @ViewChild(\"MyTabsGroup\")\n     * public tab: IgxTabsGroupComponent;\n     * ngAfterViewInIt(){\n     *    let tabComponent = this.tab.relatedTab;\n     * }\n     * ```\n     */\n    get relatedTab(): IgxTabItemComponent {\n        if (this._tabs.tabs) {\n            return this._tabs.tabs.toArray()[this.index] as IgxTabItemComponent;\n        }\n    }\n\n    /**\n     * An accessor that returns the value of the index of the `IgxTabsGroupComponent`.\n     * ```typescript\n     * @ViewChild(\"MyTabsGroup\")\n     * public tab: IgxTabsGroupComponent;\n     * ngAfterViewInIt(){\n     *    let tabIndex = this.tab.index;\n     * }\n     * ```\n     */\n    get index(): number {\n        if (this._tabs.groups) {\n            return this._tabs.groups.toArray().indexOf(this);\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    get customTabTemplate(): TemplateRef<any> {\n        return this._tabTemplate;\n    }\n\n    /**\n     *@hidden\n     */\n    set customTabTemplate(template: TemplateRef<any>) {\n        this._tabTemplate = template;\n    }\n\n    /**\n     * @hidden\n     */\n    public ngAfterContentInit(): void {\n        if (this.tabTemplate) {\n            this._tabTemplate = this.tabTemplate.template;\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    public ngAfterViewChecked() {\n        this._element.nativeElement.setAttribute('aria-labelledby', `igx-tab-item-${this.index}`);\n        this._element.nativeElement.setAttribute('id', `igx-tabs__group-${this.index}`);\n\n        if (this.isSelected) {\n            const tabItem = this.relatedTab.nativeTabItem.nativeElement;\n            this.transformContentAnimation(0);\n            this.transformIndicatorAnimation(tabItem);\n        }\n    }\n\n    /**\n     * A method that sets the focus on a tab.\n     * @memberof {@link IgxTabsGroupComponent}\n     *```typescript\n     *@ViewChild(\"MyChild\")\n     *public tab : IgxTabsGroupComponent;\n     *ngAfterViewInit(){\n     *    this.tab.select();\n     *}\n     *```\n     * @param focusDelay A number representing the expected delay.\n     */\n    public select(focusDelay = 200): void {\n        if (this.disabled || this.isSelected) {\n            return;\n        }\n\n        this.isSelected = true;\n        this.relatedTab.tabindex = 0;\n\n        if (focusDelay !== 0) {\n            setTimeout(() => {\n                this.relatedTab.nativeTabItem.nativeElement.focus();\n            }, focusDelay);\n        }\n        this.handleSelection();\n        this._tabs.onTabItemSelected.emit({ tab: this._tabs.tabs.toArray()[this.index], group: this });\n    }\n\n    private handleSelection(): void {\n        const tabElement = this.relatedTab.nativeTabItem.nativeElement;\n\n        // Scroll to the left\n        if (tabElement.offsetLeft < this._tabs.offset) {\n            this._tabs.scrollElement(tabElement, false);\n        }\n\n        // Scroll to the right\n        const viewPortOffsetWidth = this._tabs.viewPort.nativeElement.offsetWidth;\n        const delta = (tabElement.offsetLeft + tabElement.offsetWidth) - (viewPortOffsetWidth + this._tabs.offset);\n        // Fix for IE 11, a difference is accumulated from the widths calculations\n        if (delta > 1) {\n            this._tabs.scrollElement(tabElement, true);\n        }\n\n        this.transformContentAnimation(0.2);\n        this.transformIndicatorAnimation(tabElement);\n    }\n\n    private transformContentAnimation(duration: number): void {\n        const contentOffset = this._tabs.tabsContainer.nativeElement.offsetWidth * this.index;\n        this._tabs.contentsContainer.nativeElement.style.transitionDuration = `${duration}s`;\n        this._tabs.contentsContainer.nativeElement.style.transform = `translate(${-contentOffset}px)`;\n    }\n\n    private transformIndicatorAnimation(element: HTMLElement): void {\n        this._tabs.selectedIndicator.nativeElement.style.width = `${element.offsetWidth}px`;\n        this._tabs.selectedIndicator.nativeElement.style.transform = `translate(${element.offsetLeft}px)`;\n    }\n}\n"]}