igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
217 lines • 17.7 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Directive, HostBinding, TemplateRef } from '@angular/core';
import { IgxTabsBase } from './tabs.common';
/** @enum {string} */
var ButtonStyle = {
VISIBLE: 'visible',
HIDDEN: 'hidden',
NOT_DISPLAYED: 'not_displayed',
};
var IgxRightButtonStyleDirective = /** @class */ (function () {
function IgxRightButtonStyleDirective(tabs) {
this.tabs = tabs;
}
Object.defineProperty(IgxRightButtonStyleDirective.prototype, "visibleCSS", {
get: /**
* @return {?}
*/
function () {
return (this.getRightButtonStyle() === ButtonStyle.VISIBLE) ? true : false;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxRightButtonStyleDirective.prototype, "hiddenCSS", {
get: /**
* @return {?}
*/
function () {
return (this.getRightButtonStyle() === ButtonStyle.HIDDEN) ? true : false;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxRightButtonStyleDirective.prototype, "notDisplayedCSS", {
get: /**
* @return {?}
*/
function () {
return (this.getRightButtonStyle() === ButtonStyle.NOT_DISPLAYED) ? true : false;
},
enumerable: true,
configurable: true
});
/**
* @private
* @return {?}
*/
IgxRightButtonStyleDirective.prototype.getRightButtonStyle = /**
* @private
* @return {?}
*/
function () {
/** @type {?} */
var viewPortWidth = this.tabs.viewPort.nativeElement.offsetWidth;
// We use this hacky way to get the width of the itemsContainer,
// because there is inconsistency in IE we cannot use offsetWidth or scrollOffset.
/** @type {?} */
var itemsContainerChildrenCount = this.tabs.itemsContainer.nativeElement.children.length;
/** @type {?} */
var itemsContainerWidth = 0;
if (itemsContainerChildrenCount > 1) {
/** @type {?} */
var lastTab = this.tabs.itemsContainer.nativeElement.children[itemsContainerChildrenCount - 2];
itemsContainerWidth = lastTab.offsetLeft + lastTab.offsetWidth;
}
/** @type {?} */
var headerContainerWidth = this.tabs.headerContainer.nativeElement.offsetWidth;
/** @type {?} */
var offset = this.tabs.offset;
/** @type {?} */
var total = offset + viewPortWidth;
// Fix for IE 11, a difference is accumulated from the widths calculations.
if (itemsContainerWidth - headerContainerWidth <= 1 && offset === 0) {
return ButtonStyle.NOT_DISPLAYED;
}
if (itemsContainerWidth > total) {
return ButtonStyle.VISIBLE;
}
else {
return ButtonStyle.HIDDEN;
}
};
IgxRightButtonStyleDirective.decorators = [
{ type: Directive, args: [{
selector: '[igxRightButtonStyle]'
},] }
];
/** @nocollapse */
IgxRightButtonStyleDirective.ctorParameters = function () { return [
{ type: IgxTabsBase }
]; };
IgxRightButtonStyleDirective.propDecorators = {
visibleCSS: [{ type: HostBinding, args: ['class.igx-tabs__header-button',] }],
hiddenCSS: [{ type: HostBinding, args: ['class.igx-tabs__header-button--hidden',] }],
notDisplayedCSS: [{ type: HostBinding, args: ['class.igx-tabs__header-button--none',] }]
};
return IgxRightButtonStyleDirective;
}());
export { IgxRightButtonStyleDirective };
if (false) {
/** @type {?} */
IgxRightButtonStyleDirective.prototype.tabs;
}
var IgxLeftButtonStyleDirective = /** @class */ (function () {
function IgxLeftButtonStyleDirective(tabs) {
this.tabs = tabs;
}
Object.defineProperty(IgxLeftButtonStyleDirective.prototype, "visibleCSS", {
get: /**
* @return {?}
*/
function () {
return (this.getLeftButtonStyle() === ButtonStyle.VISIBLE) ? true : false;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxLeftButtonStyleDirective.prototype, "hiddenCSS", {
get: /**
* @return {?}
*/
function () {
return (this.getLeftButtonStyle() === ButtonStyle.HIDDEN) ? true : false;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxLeftButtonStyleDirective.prototype, "notDisplayedCSS", {
get: /**
* @return {?}
*/
function () {
return (this.getLeftButtonStyle() === ButtonStyle.NOT_DISPLAYED) ? true : false;
},
enumerable: true,
configurable: true
});
/**
* @private
* @return {?}
*/
IgxLeftButtonStyleDirective.prototype.getLeftButtonStyle = /**
* @private
* @return {?}
*/
function () {
// We use this hacky way to get the width of the itemsContainer,
// because there is inconsistency in IE we cannot use offsetWidth or scrollOffset.
/** @type {?} */
var itemsContainerChildrenCount = this.tabs.itemsContainer.nativeElement.children.length;
/** @type {?} */
var itemsContainerWidth = 0;
if (itemsContainerChildrenCount > 1) {
/** @type {?} */
var lastTab = this.tabs.itemsContainer.nativeElement.children[itemsContainerChildrenCount - 2];
itemsContainerWidth = lastTab.offsetLeft + lastTab.offsetWidth;
}
/** @type {?} */
var headerContainerWidth = this.tabs.headerContainer.nativeElement.offsetWidth;
/** @type {?} */
var offset = this.tabs.offset;
if (offset === 0) {
// Fix for IE 11, a difference is accumulated from the widths calculations.
if (itemsContainerWidth - headerContainerWidth <= 1) {
return ButtonStyle.NOT_DISPLAYED;
}
return ButtonStyle.HIDDEN;
}
else {
return ButtonStyle.VISIBLE;
}
};
IgxLeftButtonStyleDirective.decorators = [
{ type: Directive, args: [{
selector: '[igxLeftButtonStyle]'
},] }
];
/** @nocollapse */
IgxLeftButtonStyleDirective.ctorParameters = function () { return [
{ type: IgxTabsBase }
]; };
IgxLeftButtonStyleDirective.propDecorators = {
visibleCSS: [{ type: HostBinding, args: ['class.igx-tabs__header-button',] }],
hiddenCSS: [{ type: HostBinding, args: ['class.igx-tabs__header-button--hidden',] }],
notDisplayedCSS: [{ type: HostBinding, args: ['class.igx-tabs__header-button--none',] }]
};
return IgxLeftButtonStyleDirective;
}());
export { IgxLeftButtonStyleDirective };
if (false) {
/** @type {?} */
IgxLeftButtonStyleDirective.prototype.tabs;
}
var IgxTabItemTemplateDirective = /** @class */ (function () {
function IgxTabItemTemplateDirective(template) {
this.template = template;
}
IgxTabItemTemplateDirective.decorators = [
{ type: Directive, args: [{
selector: '[igxTab]'
},] }
];
/** @nocollapse */
IgxTabItemTemplateDirective.ctorParameters = function () { return [
{ type: TemplateRef }
]; };
return IgxTabItemTemplateDirective;
}());
export { IgxTabItemTemplateDirective };
if (false) {
/** @type {?} */
IgxTabItemTemplateDirective.prototype.template;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tabs.directives.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/tabs/tabs.directives.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Directive,\n    HostBinding,\n    TemplateRef\n} from '@angular/core';\nimport { IgxTabsBase } from './tabs.common';\n\nenum ButtonStyle {\n    VISIBLE = 'visible',\n    HIDDEN = 'hidden',\n    NOT_DISPLAYED = 'not_displayed'\n}\n\n@Directive({\n    selector: '[igxRightButtonStyle]'\n})\n\nexport class IgxRightButtonStyleDirective {\n    constructor(public tabs: IgxTabsBase) {\n    }\n\n    @HostBinding('class.igx-tabs__header-button')\n    get visibleCSS(): boolean {\n        return (this.getRightButtonStyle() === ButtonStyle.VISIBLE) ? true : false;\n    }\n\n    @HostBinding('class.igx-tabs__header-button--hidden')\n    get hiddenCSS(): boolean {\n        return (this.getRightButtonStyle() === ButtonStyle.HIDDEN) ? true : false;\n    }\n\n    @HostBinding('class.igx-tabs__header-button--none')\n    get notDisplayedCSS(): boolean {\n        return (this.getRightButtonStyle() === ButtonStyle.NOT_DISPLAYED) ? true : false;\n    }\n\n    private getRightButtonStyle(): string {\n        const viewPortWidth = this.tabs.viewPort.nativeElement.offsetWidth;\n\n        // We use this hacky way to get the width of the itemsContainer,\n        // because there is inconsistency in IE we cannot use offsetWidth or scrollOffset.\n        const itemsContainerChildrenCount = this.tabs.itemsContainer.nativeElement.children.length;\n        let itemsContainerWidth = 0;\n        if (itemsContainerChildrenCount > 1) {\n            const lastTab = this.tabs.itemsContainer.nativeElement.children[itemsContainerChildrenCount - 2];\n            itemsContainerWidth = lastTab.offsetLeft + lastTab.offsetWidth;\n        }\n        const headerContainerWidth = this.tabs.headerContainer.nativeElement.offsetWidth;\n        const offset = this.tabs.offset;\n        const total = offset + viewPortWidth;\n\n        // Fix for IE 11, a difference is accumulated from the widths calculations.\n        if (itemsContainerWidth - headerContainerWidth <= 1 && offset === 0) {\n            return ButtonStyle.NOT_DISPLAYED;\n        }\n\n        if (itemsContainerWidth > total) {\n            return ButtonStyle.VISIBLE;\n        } else {\n            return ButtonStyle.HIDDEN;\n        }\n    }\n}\n\n@Directive({\n    selector: '[igxLeftButtonStyle]'\n})\n\nexport class IgxLeftButtonStyleDirective {\n    constructor(public tabs: IgxTabsBase) {\n    }\n\n    @HostBinding('class.igx-tabs__header-button')\n    get visibleCSS(): boolean {\n        return (this.getLeftButtonStyle() === ButtonStyle.VISIBLE) ? true : false;\n    }\n\n    @HostBinding('class.igx-tabs__header-button--hidden')\n    get hiddenCSS(): boolean {\n        return (this.getLeftButtonStyle() === ButtonStyle.HIDDEN) ? true : false;\n    }\n\n    @HostBinding('class.igx-tabs__header-button--none')\n    get notDisplayedCSS(): boolean {\n        return (this.getLeftButtonStyle() === ButtonStyle.NOT_DISPLAYED) ? true : false;\n    }\n\n    private getLeftButtonStyle(): string {\n        // We use this hacky way to get the width of the itemsContainer,\n        // because there is inconsistency in IE we cannot use offsetWidth or scrollOffset.\n        const itemsContainerChildrenCount = this.tabs.itemsContainer.nativeElement.children.length;\n        let itemsContainerWidth = 0;\n        if (itemsContainerChildrenCount > 1) {\n            const lastTab = this.tabs.itemsContainer.nativeElement.children[itemsContainerChildrenCount - 2];\n            itemsContainerWidth = lastTab.offsetLeft + lastTab.offsetWidth;\n        }\n        const headerContainerWidth = this.tabs.headerContainer.nativeElement.offsetWidth;\n        const offset = this.tabs.offset;\n\n        if (offset === 0) {\n            // Fix for IE 11, a difference is accumulated from the widths calculations.\n            if (itemsContainerWidth - headerContainerWidth <= 1) {\n                return ButtonStyle.NOT_DISPLAYED;\n            }\n            return ButtonStyle.HIDDEN;\n        } else {\n            return ButtonStyle.VISIBLE;\n        }\n    }\n}\n\n@Directive({\n    selector: '[igxTab]'\n})\nexport class IgxTabItemTemplateDirective {\n\n    constructor(public template: TemplateRef<any>) {\n    }\n}\n"]}