@catull/igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
181 lines • 15.9 kB
JavaScript
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"]}