UNPKG

@catull/igniteui-angular

Version:

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

350 lines 31.7 kB
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"]}