UNPKG

@catull/igniteui-angular

Version:

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

176 lines 17.9 kB
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"]}