UNPKG

@catull/igniteui-angular

Version:

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

181 lines 15.9 kB
import { __decorate, __extends, __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'; var IgxTabsGroupComponent = /** @class */ (function (_super) { __extends(IgxTabsGroupComponent, _super); function IgxTabsGroupComponent(_tabs, _element) { var _this = _super.call(this) || this; _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; return _this; } Object.defineProperty(IgxTabsGroupComponent.prototype, "isSelected", { /** * Sets/gets whether a tab group is selected. * ```typescript * this.tabGroup.isSelected = true; * ``` * ```typescript * let isSelected = this.tabGroup.isSelected; * ``` * @memberof IgxTabsGroupComponent */ get: function () { return this._isSelected; }, set: function (newValue) { if (!this.disabled && this.isSelected !== newValue) { this._tabs.performSelectionChange(newValue ? this.relatedTab : null); } }, enumerable: true, configurable: true }); 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: function () { if (this._tabs.tabs) { return 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: function () { if (this._tabs.groups) { return this._tabs.groups.toArray().indexOf(this); } return -1; }, enumerable: true, configurable: true }); Object.defineProperty(IgxTabsGroupComponent.prototype, "customTabTemplate", { /** * @hidden */ get: function () { return this._tabTemplate; }, /** *@hidden */ set: function (template) { this._tabTemplate = template; }, enumerable: true, configurable: true }); /** * @hidden */ IgxTabsGroupComponent.prototype.ngAfterContentInit = function () { if (this.tabTemplate) { this._tabTemplate = this.tabTemplate.template; } }; /** * @hidden */ IgxTabsGroupComponent.prototype.ngAfterViewChecked = function () { 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(); *} *``` */ IgxTabsGroupComponent.prototype.select = function () { if (!this.disabled && !this.isSelected) { this._tabs.performSelectionChange(this.relatedTab); } }; /** * @hidden */ IgxTabsGroupComponent.prototype.setSelectedInternal = function (newValue) { this._isSelected = newValue; }; IgxTabsGroupComponent.ctorParameters = function () { return [ { 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); return IgxTabsGroupComponent; }(IgxTabsGroupBase)); 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"]}