UNPKG

@catull/igniteui-angular

Version:

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

162 lines 14.5 kB
import { __decorate, __metadata } from "tslib"; import { AfterContentInit, AfterViewChecked, Component, ContentChild, ElementRef, HostBinding, Input, TemplateRef, HostListener } from '@angular/core'; import { IgxTabItemTemplateDirective } from './tabs.directives'; import { IgxTabsBase, IgxTabsGroupBase } from './tabs.common'; let IgxTabsGroupComponent = class IgxTabsGroupComponent extends IgxTabsGroupBase { constructor(_tabs, _element) { super(); 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; } /** * Sets/gets whether a tab group is selected. * ```typescript * this.tabGroup.isSelected = true; * ``` * ```typescript * let isSelected = this.tabGroup.isSelected; * ``` * @memberof IgxTabsGroupComponent */ get isSelected() { return this._isSelected; } set isSelected(newValue) { if (!this.disabled && this.isSelected !== newValue) { this._tabs.performSelectionChange(newValue ? this.relatedTab : null); } } /** * An accessor that returns the `IgxTabItemComponent` component. * ```typescript * @ViewChild("MyTabsGroup") * public tab: IgxTabsGroupComponent; * ngAfterViewInIt(){ * let tabComponent = this.tab.relatedTab; * } * ``` */ get relatedTab() { if (this._tabs.tabs) { return this._tabs.tabs.toArray()[this.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 index() { if (this._tabs.groups) { return this._tabs.groups.toArray().indexOf(this); } return -1; } /** * @hidden */ get customTabTemplate() { return this._tabTemplate; } /** *@hidden */ set customTabTemplate(template) { this._tabTemplate = template; } /** * @hidden */ ngAfterContentInit() { if (this.tabTemplate) { this._tabTemplate = this.tabTemplate.template; } } /** * @hidden */ ngAfterViewChecked() { this._element.nativeElement.setAttribute('aria-labelledby', `igx-tab-item-${this.index}`); this._element.nativeElement.setAttribute('id', `igx-tabs__group-${this.index}`); } /** * A method that sets the focus on a tab. * @memberof {@link IgxTabsGroupComponent} *```typescript *@ViewChild("MyChild") *public tab : IgxTabsGroupComponent; *ngAfterViewInit(){ * this.tab.select(); *} *``` */ select() { if (!this.disabled && !this.isSelected) { this._tabs.performSelectionChange(this.relatedTab); } } /** * @hidden */ setSelectedInternal(newValue) { this._isSelected = newValue; } }; IgxTabsGroupComponent.ctorParameters = () => [ { type: IgxTabsBase }, { type: ElementRef } ]; __decorate([ Input(), __metadata("design:type", Object) ], IgxTabsGroupComponent.prototype, "disabled", void 0); __decorate([ Input(), __metadata("design:type", String) ], IgxTabsGroupComponent.prototype, "icon", void 0); __decorate([ Input(), __metadata("design:type", String) ], IgxTabsGroupComponent.prototype, "label", void 0); __decorate([ ContentChild(IgxTabItemTemplateDirective, { read: IgxTabItemTemplateDirective }), __metadata("design:type", IgxTabItemTemplateDirective) ], IgxTabsGroupComponent.prototype, "tabTemplate", void 0); __decorate([ HostBinding('attr.role'), __metadata("design:type", Object) ], IgxTabsGroupComponent.prototype, "role", void 0); __decorate([ HostBinding('class.igx-tabs__group'), __metadata("design:type", Object) ], IgxTabsGroupComponent.prototype, "styleClass", void 0); IgxTabsGroupComponent = __decorate([ Component({ selector: 'igx-tabs-group', template: "<ng-content *ngIf=\"isSelected\"></ng-content>\n" }), __metadata("design:paramtypes", [IgxTabsBase, ElementRef]) ], IgxTabsGroupComponent); export { IgxTabsGroupComponent }; //# 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 extends IgxTabsGroupBase implements 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    /**\n     * Sets/gets whether a tab group is selected.\n     * ```typescript\n     * this.tabGroup.isSelected = true;\n     * ```\n     * ```typescript\n     * let isSelected = this.tabGroup.isSelected;\n     * ```\n     * @memberof IgxTabsGroupComponent\n     */\n    public get isSelected(): boolean {\n        return this._isSelected;\n    }\n    public set isSelected(newValue: boolean) {\n        if (!this.disabled && this.isSelected !== newValue) {\n            this._tabs.performSelectionChange(newValue ? this.relatedTab : null);\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    @ContentChild(IgxTabItemTemplateDirective, { read: IgxTabItemTemplateDirective })\n    protected tabTemplate: IgxTabItemTemplateDirective;\n\n    private _tabTemplate: TemplateRef<any>;\n    private _isSelected = false;\n\n    constructor(private _tabs: IgxTabsBase, private _element: ElementRef) {\n        super();\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    /**\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        return -1;\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\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     */\n    public select(): void {\n        if (!this.disabled && !this.isSelected) {\n            this._tabs.performSelectionChange(this.relatedTab);\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    public setSelectedInternal(newValue: boolean) {\n        this._isSelected = newValue;\n    }\n\n}\n"]}