UNPKG

igniteui-angular

Version:

Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps

358 lines • 24.7 kB
/** * @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"]}