@catull/igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
176 lines • 17.9 kB
JavaScript
import { __decorate, __metadata } from "tslib";
import { Directive, HostBinding, TemplateRef } from '@angular/core';
import { IgxTabsBase } from './tabs.common';
var ButtonStyle;
(function (ButtonStyle) {
ButtonStyle["VISIBLE"] = "visible";
ButtonStyle["HIDDEN"] = "hidden";
ButtonStyle["NOT_DISPLAYED"] = "not_displayed";
})(ButtonStyle || (ButtonStyle = {}));
var IgxRightButtonStyleDirective = /** @class */ (function () {
function IgxRightButtonStyleDirective(tabs) {
this.tabs = tabs;
}
Object.defineProperty(IgxRightButtonStyleDirective.prototype, "visibleCSS", {
get: function () {
return (this.getRightButtonStyle() === ButtonStyle.VISIBLE) ? true : false;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxRightButtonStyleDirective.prototype, "hiddenCSS", {
get: function () {
return (this.getRightButtonStyle() === ButtonStyle.HIDDEN) ? true : false;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxRightButtonStyleDirective.prototype, "notDisplayedCSS", {
get: function () {
return (this.getRightButtonStyle() === ButtonStyle.NOT_DISPLAYED) ? true : false;
},
enumerable: true,
configurable: true
});
IgxRightButtonStyleDirective.prototype.getRightButtonStyle = function () {
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.
var itemsContainerChildrenCount = this.tabs.itemsContainer.nativeElement.children.length;
var itemsContainerWidth = 0;
if (itemsContainerChildrenCount > 1) {
var lastTab = this.tabs.itemsContainer.nativeElement.children[itemsContainerChildrenCount - 2];
itemsContainerWidth = lastTab.offsetLeft + lastTab.offsetWidth;
}
var headerContainerWidth = this.tabs.headerContainer.nativeElement.offsetWidth;
var offset = this.tabs.offset;
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.ctorParameters = function () { return [
{ type: IgxTabsBase }
]; };
__decorate([
HostBinding('class.igx-tabs__header-button'),
__metadata("design:type", Boolean),
__metadata("design:paramtypes", [])
], IgxRightButtonStyleDirective.prototype, "visibleCSS", null);
__decorate([
HostBinding('class.igx-tabs__header-button--hidden'),
__metadata("design:type", Boolean),
__metadata("design:paramtypes", [])
], IgxRightButtonStyleDirective.prototype, "hiddenCSS", null);
__decorate([
HostBinding('class.igx-tabs__header-button--none'),
__metadata("design:type", Boolean),
__metadata("design:paramtypes", [])
], IgxRightButtonStyleDirective.prototype, "notDisplayedCSS", null);
IgxRightButtonStyleDirective = __decorate([
Directive({
selector: '[igxRightButtonStyle]'
}),
__metadata("design:paramtypes", [IgxTabsBase])
], IgxRightButtonStyleDirective);
return IgxRightButtonStyleDirective;
}());
export { IgxRightButtonStyleDirective };
var IgxLeftButtonStyleDirective = /** @class */ (function () {
function IgxLeftButtonStyleDirective(tabs) {
this.tabs = tabs;
}
Object.defineProperty(IgxLeftButtonStyleDirective.prototype, "visibleCSS", {
get: function () {
return (this.getLeftButtonStyle() === ButtonStyle.VISIBLE) ? true : false;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxLeftButtonStyleDirective.prototype, "hiddenCSS", {
get: function () {
return (this.getLeftButtonStyle() === ButtonStyle.HIDDEN) ? true : false;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxLeftButtonStyleDirective.prototype, "notDisplayedCSS", {
get: function () {
return (this.getLeftButtonStyle() === ButtonStyle.NOT_DISPLAYED) ? true : false;
},
enumerable: true,
configurable: true
});
IgxLeftButtonStyleDirective.prototype.getLeftButtonStyle = 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.
var itemsContainerChildrenCount = this.tabs.itemsContainer.nativeElement.children.length;
var itemsContainerWidth = 0;
if (itemsContainerChildrenCount > 1) {
var lastTab = this.tabs.itemsContainer.nativeElement.children[itemsContainerChildrenCount - 2];
itemsContainerWidth = lastTab.offsetLeft + lastTab.offsetWidth;
}
var headerContainerWidth = this.tabs.headerContainer.nativeElement.offsetWidth;
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.ctorParameters = function () { return [
{ type: IgxTabsBase }
]; };
__decorate([
HostBinding('class.igx-tabs__header-button'),
__metadata("design:type", Boolean),
__metadata("design:paramtypes", [])
], IgxLeftButtonStyleDirective.prototype, "visibleCSS", null);
__decorate([
HostBinding('class.igx-tabs__header-button--hidden'),
__metadata("design:type", Boolean),
__metadata("design:paramtypes", [])
], IgxLeftButtonStyleDirective.prototype, "hiddenCSS", null);
__decorate([
HostBinding('class.igx-tabs__header-button--none'),
__metadata("design:type", Boolean),
__metadata("design:paramtypes", [])
], IgxLeftButtonStyleDirective.prototype, "notDisplayedCSS", null);
IgxLeftButtonStyleDirective = __decorate([
Directive({
selector: '[igxLeftButtonStyle]'
}),
__metadata("design:paramtypes", [IgxTabsBase])
], IgxLeftButtonStyleDirective);
return IgxLeftButtonStyleDirective;
}());
export { IgxLeftButtonStyleDirective };
var IgxTabItemTemplateDirective = /** @class */ (function () {
function IgxTabItemTemplateDirective(template) {
this.template = template;
}
IgxTabItemTemplateDirective.ctorParameters = function () { return [
{ type: TemplateRef }
]; };
IgxTabItemTemplateDirective = __decorate([
Directive({
selector: '[igxTab]'
}),
__metadata("design:paramtypes", [TemplateRef])
], IgxTabItemTemplateDirective);
return IgxTabItemTemplateDirective;
}());
export { IgxTabItemTemplateDirective };
//# 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        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"]}