igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
317 lines • 18.9 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, ElementRef, HostBinding, HostListener, Input } from '@angular/core';
import { IgxTabsGroupComponent } from './tabs-group.component';
import { IgxTabsBase } from './tabs.common';
var IgxTabItemComponent = /** @class */ (function () {
function IgxTabItemComponent(_tabs, _element) {
this._tabs = _tabs;
this._element = _element;
this._changesCount = 0; // changes and updates accordingly applied to the tab.
/**
* @hidden
*/
this.role = 'tab';
this._nativeTabItem = _element;
}
/**
* @hidden
*/
/**
* @hidden
* @param {?} event
* @return {?}
*/
IgxTabItemComponent.prototype.onClick = /**
* @hidden
* @param {?} event
* @return {?}
*/
function (event) {
this.select();
};
/**
* @hidden
*/
/**
* @hidden
* @param {?} event
* @return {?}
*/
IgxTabItemComponent.prototype.onResize = /**
* @hidden
* @param {?} event
* @return {?}
*/
function (event) {
if (this.isSelected) {
this._tabs.selectedIndicator.nativeElement.style.width = this.nativeTabItem.nativeElement.offsetWidth + "px";
this._tabs.selectedIndicator.nativeElement.style.transform = "translate(" + this.nativeTabItem.nativeElement.offsetLeft + "px)";
}
};
/**
* @hidden
*/
/**
* @hidden
* @param {?} event
* @return {?}
*/
IgxTabItemComponent.prototype.onKeydownArrowRight = /**
* @hidden
* @param {?} event
* @return {?}
*/
function (event) {
this.onKeyDown(false);
};
/**
* @hidden
*/
/**
* @hidden
* @param {?} event
* @return {?}
*/
IgxTabItemComponent.prototype.onKeydownArrowLeft = /**
* @hidden
* @param {?} event
* @return {?}
*/
function (event) {
this.onKeyDown(true);
};
/**
* @hidden
*/
/**
* @hidden
* @param {?} event
* @return {?}
*/
IgxTabItemComponent.prototype.onKeydownHome = /**
* @hidden
* @param {?} event
* @return {?}
*/
function (event) {
event.preventDefault();
this.onKeyDown(false, 0);
};
/**
* @hidden
*/
/**
* @hidden
* @param {?} event
* @return {?}
*/
IgxTabItemComponent.prototype.onKeydownEnd = /**
* @hidden
* @param {?} event
* @return {?}
*/
function (event) {
event.preventDefault();
this.onKeyDown(false, this._tabs.tabs.toArray().length - 1);
};
Object.defineProperty(IgxTabItemComponent.prototype, "changesCount", {
/**
* @hidden
*/
get: /**
* @hidden
* @return {?}
*/
function () {
return this._changesCount;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxTabItemComponent.prototype, "nativeTabItem", {
/**
* @hidden
*/
get: /**
* @hidden
* @return {?}
*/
function () {
return this._nativeTabItem;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxTabItemComponent.prototype, "disabled", {
/**
* Gets whether the tab is disabled.
* ```
* const disabledItem = this.myTabComponent.tabs.first.disabled;
* ```
*/
get: /**
* Gets whether the tab is disabled.
* ```
* const disabledItem = this.myTabComponent.tabs.first.disabled;
* ```
* @return {?}
*/
function () {
/** @type {?} */
var group = this.relatedGroup;
if (group) {
return group.disabled;
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxTabItemComponent.prototype, "isSelected", {
/**
* Gets whether the tab is selected.
* ```typescript
* const selectedItem = this.myTabComponent.tabs.first.isSelected;
* ```
*/
get: /**
* Gets whether the tab is selected.
* ```typescript
* const selectedItem = this.myTabComponent.tabs.first.isSelected;
* ```
* @return {?}
*/
function () {
/** @type {?} */
var group = this.relatedGroup;
if (group) {
return group.isSelected;
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxTabItemComponent.prototype, "index", {
/**
* @hidden
*/
get: /**
* @hidden
* @return {?}
*/
function () {
return this._tabs.tabs.toArray().indexOf(this);
},
enumerable: true,
configurable: true
});
/**
* @hidden
*/
/**
* @hidden
* @param {?=} focusDelay
* @return {?}
*/
IgxTabItemComponent.prototype.select = /**
* @hidden
* @param {?=} focusDelay
* @return {?}
*/
function (focusDelay) {
if (focusDelay === void 0) { focusDelay = 200; }
this.relatedGroup.select(focusDelay);
};
/**
* @private
* @param {?} isLeftArrow
* @param {?=} index
* @return {?}
*/
IgxTabItemComponent.prototype.onKeyDown = /**
* @private
* @param {?} isLeftArrow
* @param {?=} index
* @return {?}
*/
function (isLeftArrow, index) {
if (index === void 0) { index = null; }
/** @type {?} */
var 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;
}
/** @type {?} */
var tab = tabsArray[index];
tab.select(200);
};
IgxTabItemComponent.decorators = [
{ type: Component, args: [{
selector: 'igx-tab-item',
template: "<ng-template #defaultTabTemplate>\n <div *ngIf=\"relatedGroup.icon\" class=\"igx-tabs__header-menu-item-icon\">\n <igx-icon fontSet=\"material\">{{relatedGroup.icon}}</igx-icon>\n <igx-badge [value]=\"changesCount\" [hidden]=\"changesCount === 0\"></igx-badge>\n </div>\n <div *ngIf=\"relatedGroup.label\" ngClass=\"igx-tabs__item-label\">{{relatedGroup.label}}</div>\n</ng-template>\n<ng-container\n *ngTemplateOutlet=\"relatedGroup.customTabTemplate ? relatedGroup.customTabTemplate : defaultTabTemplate; context: { $implicit: relatedGroup }\">\n</ng-container>"
}] }
];
/** @nocollapse */
IgxTabItemComponent.ctorParameters = function () { return [
{ type: IgxTabsBase },
{ type: ElementRef }
]; };
IgxTabItemComponent.propDecorators = {
relatedGroup: [{ type: Input }],
role: [{ type: HostBinding, args: ['attr.role',] }],
tabindex: [{ type: HostBinding, args: ['attr.tabindex',] }],
onClick: [{ type: HostListener, args: ['click', ['$event'],] }],
onResize: [{ type: HostListener, args: ['window:resize', ['$event'],] }],
onKeydownArrowRight: [{ type: HostListener, args: ['keydown.arrowright', ['$event'],] }],
onKeydownArrowLeft: [{ type: HostListener, args: ['keydown.arrowleft', ['$event'],] }],
onKeydownHome: [{ type: HostListener, args: ['keydown.home', ['$event'],] }],
onKeydownEnd: [{ type: HostListener, args: ['keydown.end', ['$event'],] }]
};
return IgxTabItemComponent;
}());
export { IgxTabItemComponent };
if (false) {
/**
* Gets the group associated with the tab.
* ```html
* const relatedGroup = this.tabbar.tabs.toArray()[1].relatedGroup;
* ```
* @type {?}
*/
IgxTabItemComponent.prototype.relatedGroup;
/**
* @type {?}
* @private
*/
IgxTabItemComponent.prototype._nativeTabItem;
/**
* @type {?}
* @private
*/
IgxTabItemComponent.prototype._changesCount;
/**
* @hidden
* @type {?}
*/
IgxTabItemComponent.prototype.role;
/**
* @hidden
* @type {?}
*/
IgxTabItemComponent.prototype.tabindex;
/**
* @type {?}
* @private
*/
IgxTabItemComponent.prototype._tabs;
/**
* @type {?}
* @private
*/
IgxTabItemComponent.prototype._element;
}
//# 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    ElementRef,\n    HostBinding,\n    HostListener,\n    Input\n} from '@angular/core';\n\nimport { IgxTabsGroupComponent } from './tabs-group.component';\nimport { IgxTabItemBase, IgxTabsBase } from './tabs.common';\n\n@Component({\n    selector: 'igx-tab-item',\n    templateUrl: 'tab-item.component.html'\n})\n\nexport class IgxTabItemComponent implements IgxTabItemBase {\n\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    private _nativeTabItem: ElementRef;\n    private _changesCount = 0; // changes and updates accordingly applied to the tab.\n\n    constructor(private _tabs: IgxTabsBase, private _element: ElementRef) {\n        this._nativeTabItem = _element;\n    }\n\n    /**\n     * @hidden\n     */\n    @HostBinding('attr.role')\n    public role = 'tab';\n\n    /**\n     * @hidden\n     */\n    @HostBinding('attr.tabindex')\n    public tabindex;\n\n    /**\n     * @hidden\n     */\n    @HostListener('click', ['$event'])\n    public onClick(event) {\n        this.select();\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('window:resize', ['$event'])\n    public onResize(event) {\n        if (this.isSelected) {\n            this._tabs.selectedIndicator.nativeElement.style.width = `${this.nativeTabItem.nativeElement.offsetWidth}px`;\n            this._tabs.selectedIndicator.nativeElement.style.transform = `translate(${this.nativeTabItem.nativeElement.offsetLeft}px)`;\n        }\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    get disabled(): boolean {\n        const group = this.relatedGroup;\n\n        if (group) {\n            return group.disabled;\n        }\n    }\n\n    /**\n     * Gets whether the tab is selected.\n     * ```typescript\n     * const selectedItem = this.myTabComponent.tabs.first.isSelected;\n     * ```\n     */\n    get isSelected(): boolean {\n        const group = this.relatedGroup;\n\n        if (group) {\n            return group.isSelected;\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    get index(): number {\n        return this._tabs.tabs.toArray().indexOf(this);\n    }\n\n    /**\n     * @hidden\n     */\n    public select(focusDelay = 200): void {\n        this.relatedGroup.select(focusDelay);\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(200);\n    }\n}\n"]}