@catull/igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
350 lines • 31.7 kB
JavaScript
import { __decorate, __metadata } from "tslib";
import { Component, ContentChild, ElementRef, HostBinding, HostListener, Input, TemplateRef, ViewChild, NgZone, AfterViewInit, OnDestroy } from '@angular/core';
import { IgxTabsGroupComponent } from './tabs-group.component';
import { IgxTabItemBase, IgxTabsBase } from './tabs.common';
import { IgxTabItemTemplateDirective } from './tabs.directives';
import ResizeObserver from 'resize-observer-polyfill';
let IgxTabItemComponent = class IgxTabItemComponent extends IgxTabItemBase {
constructor(_tabs, _element, _ngZone) {
super();
this._tabs = _tabs;
this._element = _element;
this._ngZone = _ngZone;
this._changesCount = 0; // changes and updates accordingly applied to the tab.
this._isSelected = false;
this._disabled = false;
/**
* @hidden @internal
*/
this.role = 'tab';
/**
* @hidden @internal
*/
this.id = 'igx-tab-item-' + this.index;
/**
* @hidden @internal
*/
this.ariaLabel = this.label;
/**
* @hidden @internal
*/
this.ariaDisabled = this.disabled;
/**
* @hidden @internal
*/
this.ariaSelected = this.isSelected;
/**
* @hidden @internal
*/
this.ariaControls = 'igx-tab-item-group-' + this.index;
this._nativeTabItem = _element;
}
/**
* 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-tab-item label="Tab 1" icon="home">
*```
*/
get icon() {
return this.relatedGroup ? this.relatedGroup.icon : this._icon;
}
set icon(newValue) {
if (this.relatedGroup) {
this.relatedGroup.icon = newValue;
}
this._icon = newValue;
}
/**
* An @Input property that sets the value of the `label`.
*```html
*<igx-tabs-item label="Tab 2" icon="folder">
*```
*/
get label() {
return this.relatedGroup ? this.relatedGroup.label : this._label;
}
set label(newValue) {
if (this.relatedGroup) {
this.relatedGroup.label = newValue;
}
this._label = newValue;
}
get provideCssClassSelected() {
return this.isSelected;
}
get provideCssClassDisabled() {
return this.disabled;
}
get provideCssClass() {
return (!this.disabled && !this.isSelected);
}
ngAfterViewInit() {
this._ngZone.runOutsideAngular(() => {
this._resizeObserver = new ResizeObserver(() => {
this._tabs.transformIndicatorAnimation(this._nativeTabItem.nativeElement, 0);
});
});
}
ngOnDestroy() {
this._ngZone.runOutsideAngular(() => {
this._resizeObserver.disconnect();
});
}
/**
* @hidden
*/
onClick(event) {
this.select();
}
/**
* @hidden
*/
onKeydownArrowRight(event) {
this.onKeyDown(false);
}
/**
* @hidden
*/
onKeydownArrowLeft(event) {
this.onKeyDown(true);
}
/**
* @hidden
*/
onKeydownHome(event) {
event.preventDefault();
this.onKeyDown(false, 0);
}
/**
* @hidden
*/
onKeydownEnd(event) {
event.preventDefault();
this.onKeyDown(false, this._tabs.tabs.toArray().length - 1);
}
/**
* @hidden
*/
get changesCount() {
return this._changesCount;
}
/**
* @hidden
*/
get nativeTabItem() {
return this._nativeTabItem;
}
/**
* Gets whether the tab is disabled.
* ```
* const disabledItem = this.myTabComponent.tabs.first.disabled;
* ```
*/
get disabled() {
return this.relatedGroup ? this.relatedGroup.disabled : this._disabled;
}
set disabled(newValue) {
if (this.relatedGroup) {
this.relatedGroup.disabled = newValue;
}
else {
this._disabled = newValue;
}
}
/**
* Gets whether the tab is selected.
* ```typescript
* const selectedItem = this.myTabComponent.tabs.first.isSelected;
* ```
*/
get isSelected() {
return this.relatedGroup ? this.relatedGroup.isSelected : this._isSelected;
}
set isSelected(newValue) {
if (!this.disabled && this.isSelected !== newValue) {
this._tabs.performSelectionChange(newValue ? this : null);
}
}
/**
* @hidden
*/
select() {
if (!this.disabled && !this.isSelected) {
this._tabs.performSelectionChange(this);
}
}
/**
* @hidden
*/
get index() {
if (this._tabs.tabs) {
return this._tabs.tabs.toArray().indexOf(this);
}
return -1;
}
/**
* @hidden
*/
setSelectedInternal(newValue) {
this._isSelected = newValue;
this._ngZone.runOutsideAngular(() => {
if (this._resizeObserver) {
if (this._isSelected) {
this._resizeObserver.observe(this._element.nativeElement);
}
else {
this._resizeObserver.disconnect();
}
}
});
this.tabindex = newValue ? 0 : -1;
}
onKeyDown(isLeftArrow, index = null) {
const tabsArray = this._tabs.tabs.toArray();
if (index === null) {
index = (isLeftArrow)
? (this._tabs.selectedIndex === 0) ? tabsArray.length - 1 : this._tabs.selectedIndex - 1
: (this._tabs.selectedIndex === tabsArray.length - 1) ? 0 : this._tabs.selectedIndex + 1;
}
const tab = tabsArray[index];
tab.select();
}
/**
* @hidden
*/
get template() {
if (this.relatedGroup && this.relatedGroup.customTabTemplate) {
return this.relatedGroup.customTabTemplate;
}
if (this.customTabTemplateDir) {
return this.customTabTemplateDir.template;
}
return this.defaultTabTemplate;
}
/**
* @hidden
*/
get context() {
return this.relatedGroup ? this.relatedGroup : this;
}
};
IgxTabItemComponent.ctorParameters = () => [
{ type: IgxTabsBase },
{ type: ElementRef },
{ type: NgZone }
];
__decorate([
Input(),
__metadata("design:type", IgxTabsGroupComponent)
], IgxTabItemComponent.prototype, "relatedGroup", void 0);
__decorate([
Input(),
__metadata("design:type", String),
__metadata("design:paramtypes", [String])
], IgxTabItemComponent.prototype, "icon", null);
__decorate([
Input(),
__metadata("design:type", String),
__metadata("design:paramtypes", [String])
], IgxTabItemComponent.prototype, "label", null);
__decorate([
ViewChild('defaultTabTemplate', { read: TemplateRef, static: true }),
__metadata("design:type", TemplateRef)
], IgxTabItemComponent.prototype, "defaultTabTemplate", void 0);
__decorate([
ContentChild(IgxTabItemTemplateDirective, { read: IgxTabItemTemplateDirective }),
__metadata("design:type", IgxTabItemTemplateDirective)
], IgxTabItemComponent.prototype, "customTabTemplateDir", void 0);
__decorate([
HostBinding('class.igx-tabs__header-menu-item--selected'),
__metadata("design:type", Boolean),
__metadata("design:paramtypes", [])
], IgxTabItemComponent.prototype, "provideCssClassSelected", null);
__decorate([
HostBinding('class.igx-tabs__header-menu-item--disabled'),
__metadata("design:type", Boolean),
__metadata("design:paramtypes", [])
], IgxTabItemComponent.prototype, "provideCssClassDisabled", null);
__decorate([
HostBinding('class.igx-tabs__header-menu-item'),
__metadata("design:type", Boolean),
__metadata("design:paramtypes", [])
], IgxTabItemComponent.prototype, "provideCssClass", null);
__decorate([
HostBinding('attr.role'),
__metadata("design:type", Object)
], IgxTabItemComponent.prototype, "role", void 0);
__decorate([
HostBinding('attr.tabindex'),
__metadata("design:type", Object)
], IgxTabItemComponent.prototype, "tabindex", void 0);
__decorate([
HostBinding('attr.id'),
__metadata("design:type", Object)
], IgxTabItemComponent.prototype, "id", void 0);
__decorate([
HostBinding('attr.aria-label'),
__metadata("design:type", Object)
], IgxTabItemComponent.prototype, "ariaLabel", void 0);
__decorate([
HostBinding('attr.aria-disabled'),
__metadata("design:type", Object)
], IgxTabItemComponent.prototype, "ariaDisabled", void 0);
__decorate([
HostBinding('attr.aria-selected'),
__metadata("design:type", Object)
], IgxTabItemComponent.prototype, "ariaSelected", void 0);
__decorate([
HostBinding('attr.aria-controls'),
__metadata("design:type", Object)
], IgxTabItemComponent.prototype, "ariaControls", void 0);
__decorate([
HostListener('click', ['$event']),
__metadata("design:type", Function),
__metadata("design:paramtypes", [Object]),
__metadata("design:returntype", void 0)
], IgxTabItemComponent.prototype, "onClick", null);
__decorate([
HostListener('keydown.arrowright', ['$event']),
__metadata("design:type", Function),
__metadata("design:paramtypes", [KeyboardEvent]),
__metadata("design:returntype", void 0)
], IgxTabItemComponent.prototype, "onKeydownArrowRight", null);
__decorate([
HostListener('keydown.arrowleft', ['$event']),
__metadata("design:type", Function),
__metadata("design:paramtypes", [KeyboardEvent]),
__metadata("design:returntype", void 0)
], IgxTabItemComponent.prototype, "onKeydownArrowLeft", null);
__decorate([
HostListener('keydown.home', ['$event']),
__metadata("design:type", Function),
__metadata("design:paramtypes", [KeyboardEvent]),
__metadata("design:returntype", void 0)
], IgxTabItemComponent.prototype, "onKeydownHome", null);
__decorate([
HostListener('keydown.end', ['$event']),
__metadata("design:type", Function),
__metadata("design:paramtypes", [KeyboardEvent]),
__metadata("design:returntype", void 0)
], IgxTabItemComponent.prototype, "onKeydownEnd", null);
__decorate([
Input(),
__metadata("design:type", Boolean),
__metadata("design:paramtypes", [Boolean])
], IgxTabItemComponent.prototype, "disabled", null);
__decorate([
Input(),
__metadata("design:type", Boolean),
__metadata("design:paramtypes", [Boolean])
], IgxTabItemComponent.prototype, "isSelected", null);
IgxTabItemComponent = __decorate([
Component({
selector: 'igx-tab-item',
template: "<ng-template #defaultTabTemplate let-context>\n <div *ngIf=\"context.icon\" class=\"igx-tabs__header-menu-item-icon\">\n <igx-icon fontSet=\"material\">{{context.icon}}</igx-icon>\n <igx-badge [value]=\"changesCount\" [hidden]=\"changesCount === 0\"></igx-badge>\n </div>\n <div *ngIf=\"context.label\" ngClass=\"igx-tabs__item-label\">{{context.label}}</div>\n</ng-template>\n<ng-container *ngTemplateOutlet=\"template; context: { $implicit: this.context }\">\n</ng-container>"
}),
__metadata("design:paramtypes", [IgxTabsBase, ElementRef, NgZone])
], IgxTabItemComponent);
export { IgxTabItemComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tab-item.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/tabs/tab-item.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ContentChild,\n    ElementRef,\n    HostBinding,\n    HostListener,\n    Input,\n    TemplateRef,\n    ViewChild,\n    NgZone,\n    AfterViewInit,\n    OnDestroy\n} from '@angular/core';\n\nimport { IgxTabsGroupComponent } from './tabs-group.component';\nimport { IgxTabItemBase, IgxTabsBase } from './tabs.common';\nimport { IgxTabItemTemplateDirective } from './tabs.directives';\nimport ResizeObserver from 'resize-observer-polyfill';\n\n@Component({\n    selector: 'igx-tab-item',\n    templateUrl: 'tab-item.component.html'\n})\n\nexport class IgxTabItemComponent extends IgxTabItemBase implements AfterViewInit, OnDestroy {\n    /**\n    * Gets the group associated with the tab.\n    * ```html\n    * const relatedGroup = this.tabbar.tabs.toArray()[1].relatedGroup;\n    * ```\n    */\n    @Input()\n    public relatedGroup: IgxTabsGroupComponent;\n\n    /**@hidden*/\n    private _icon: string;\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-tab-item label=\"Tab 1\" icon=\"home\">\n    *```\n    */\n    @Input()\n    public get icon(): string {\n        return this.relatedGroup ? this.relatedGroup.icon : this._icon;\n    }\n    public set icon(newValue: string) {\n        if (this.relatedGroup) {\n            this.relatedGroup.icon = newValue;\n        }\n        this._icon = newValue;\n    }\n\n    /**@hidden*/\n    private _label: string;\n\n    /**\n    * An @Input property that sets the value of the `label`.\n    *```html\n    *<igx-tabs-item label=\"Tab 2\" icon=\"folder\">\n    *```\n    */\n    @Input()\n    public get label(): string {\n        return this.relatedGroup ? this.relatedGroup.label : this._label;\n    }\n    public set label(newValue: string) {\n        if (this.relatedGroup) {\n            this.relatedGroup.label = newValue;\n        }\n        this._label = newValue;\n    }\n\n    /**@hidden*/\n    @ViewChild('defaultTabTemplate', { read: TemplateRef, static: true })\n    protected defaultTabTemplate: TemplateRef<any>;\n\n    /**@hidden*/\n    @ContentChild(IgxTabItemTemplateDirective, { read: IgxTabItemTemplateDirective })\n    protected customTabTemplateDir: IgxTabItemTemplateDirective;\n\n    private _nativeTabItem: ElementRef;\n    private _changesCount = 0; // changes and updates accordingly applied to the tab.\n    private _isSelected = false;\n    private _disabled = false;\n    private _resizeObserver: ResizeObserver;\n\n    constructor(private _tabs: IgxTabsBase, private _element: ElementRef, private _ngZone: NgZone) {\n        super();\n        this._nativeTabItem = _element;\n    }\n\n    @HostBinding('class.igx-tabs__header-menu-item--selected')\n    public get provideCssClassSelected(): boolean {\n        return this.isSelected;\n    }\n\n    @HostBinding('class.igx-tabs__header-menu-item--disabled')\n    public get provideCssClassDisabled(): boolean {\n        return this.disabled;\n    }\n\n    @HostBinding('class.igx-tabs__header-menu-item')\n    public get provideCssClass(): boolean {\n        return (!this.disabled && !this.isSelected);\n    }\n\n    /**\n     * @hidden @internal\n     */\n    @HostBinding('attr.role')\n    public role = 'tab';\n\n    /**\n     * @hidden @internal\n     */\n    @HostBinding('attr.tabindex')\n    public tabindex;\n\n    /**\n     * @hidden @internal\n     */\n    @HostBinding('attr.id')\n    public id = 'igx-tab-item-' + this.index;\n\n    /**\n     * @hidden @internal\n     */\n    @HostBinding('attr.aria-label')\n    public ariaLabel = this.label;\n\n    /**\n     * @hidden @internal\n     */\n    @HostBinding('attr.aria-disabled')\n    public ariaDisabled = this.disabled;\n\n    /**\n     * @hidden @internal\n     */\n    @HostBinding('attr.aria-selected')\n    public ariaSelected = this.isSelected;\n\n    /**\n     * @hidden @internal\n     */\n    @HostBinding('attr.aria-controls')\n    public ariaControls = 'igx-tab-item-group-' + this.index;\n\n    ngAfterViewInit(): void {\n        this._ngZone.runOutsideAngular(() => {\n            this._resizeObserver = new ResizeObserver(() => {\n                this._tabs.transformIndicatorAnimation(this._nativeTabItem.nativeElement, 0);\n            });\n        });\n    }\n\n    ngOnDestroy(): void {\n        this._ngZone.runOutsideAngular(() => {\n            this._resizeObserver.disconnect();\n        });\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('click', ['$event'])\n    public onClick(event) {\n        this.select();\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('keydown.arrowright', ['$event'])\n    public onKeydownArrowRight(event: KeyboardEvent) {\n        this.onKeyDown(false);\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('keydown.arrowleft', ['$event'])\n    public onKeydownArrowLeft(event: KeyboardEvent) {\n        this.onKeyDown(true);\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('keydown.home', ['$event'])\n    public onKeydownHome(event: KeyboardEvent) {\n        event.preventDefault();\n        this.onKeyDown(false, 0);\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('keydown.end', ['$event'])\n    public onKeydownEnd(event: KeyboardEvent) {\n        event.preventDefault();\n        this.onKeyDown(false, this._tabs.tabs.toArray().length - 1);\n    }\n\n    /**\n     * @hidden\n     */\n    get changesCount(): number {\n        return this._changesCount;\n    }\n\n    /**\n     * @hidden\n     */\n    get nativeTabItem(): ElementRef {\n        return this._nativeTabItem;\n    }\n\n    /**\n    * \tGets whether the tab is disabled.\n    * ```\n    * const disabledItem = this.myTabComponent.tabs.first.disabled;\n    * ```\n    */\n    @Input()\n    get disabled(): boolean {\n        return this.relatedGroup ? this.relatedGroup.disabled : this._disabled;\n    }\n    set disabled(newValue: boolean) {\n        if (this.relatedGroup) {\n            this.relatedGroup.disabled = newValue;\n        } else {\n            this._disabled = newValue;\n        }\n    }\n\n    /**\n     * Gets whether the tab is selected.\n     * ```typescript\n     * const selectedItem = this.myTabComponent.tabs.first.isSelected;\n     * ```\n     */\n    @Input()\n    get isSelected(): boolean {\n        return this.relatedGroup ? this.relatedGroup.isSelected : this._isSelected;\n    }\n    set isSelected(newValue: boolean) {\n        if (!this.disabled && this.isSelected !== newValue) {\n            this._tabs.performSelectionChange(newValue ? this : null);\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    public select(): void {\n        if (!this.disabled && !this.isSelected) {\n            this._tabs.performSelectionChange(this);\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    get index(): number {\n        if (this._tabs.tabs) {\n            return this._tabs.tabs.toArray().indexOf(this);\n        }\n        return -1;\n    }\n\n    /**\n     * @hidden\n     */\n    public setSelectedInternal(newValue: boolean) {\n        this._isSelected = newValue;\n        this._ngZone.runOutsideAngular(() => {\n            if (this._resizeObserver) {\n                if (this._isSelected) {\n                    this._resizeObserver.observe(this._element.nativeElement);\n                } else {\n                    this._resizeObserver.disconnect();\n                }\n            }\n        });\n        this.tabindex = newValue ? 0 : -1;\n    }\n\n    private onKeyDown(isLeftArrow: boolean, index = null): void {\n        const tabsArray = this._tabs.tabs.toArray();\n        if (index === null) {\n            index = (isLeftArrow)\n                ? (this._tabs.selectedIndex === 0) ? tabsArray.length - 1 : this._tabs.selectedIndex - 1\n                : (this._tabs.selectedIndex === tabsArray.length - 1) ? 0 : this._tabs.selectedIndex + 1;\n        }\n        const tab = tabsArray[index];\n        tab.select();\n    }\n\n    /**\n     * @hidden\n     */\n    public get template(): TemplateRef<any> {\n        if (this.relatedGroup && this.relatedGroup.customTabTemplate) {\n            return this.relatedGroup.customTabTemplate;\n        }\n        if (this.customTabTemplateDir) {\n            return this.customTabTemplateDir.template;\n        }\n        return this.defaultTabTemplate;\n    }\n\n    /**\n     * @hidden\n     */\n    public get context(): any {\n        return this.relatedGroup ? this.relatedGroup : this;\n    }\n\n}\n"]}