UNPKG

@catull/igniteui-angular

Version:

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

149 lines 16.4 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 = {})); let IgxRightButtonStyleDirective = class IgxRightButtonStyleDirective { constructor(tabs) { this.tabs = tabs; } get visibleCSS() { return (this.getRightButtonStyle() === ButtonStyle.VISIBLE) ? true : false; } get hiddenCSS() { return (this.getRightButtonStyle() === ButtonStyle.HIDDEN) ? true : false; } get notDisplayedCSS() { return (this.getRightButtonStyle() === ButtonStyle.NOT_DISPLAYED) ? true : false; } getRightButtonStyle() { const 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. const itemsContainerChildrenCount = this.tabs.itemsContainer.nativeElement.children.length; let itemsContainerWidth = 0; if (itemsContainerChildrenCount > 1) { const lastTab = this.tabs.itemsContainer.nativeElement.children[itemsContainerChildrenCount - 2]; itemsContainerWidth = lastTab.offsetLeft + lastTab.offsetWidth; } const headerContainerWidth = this.tabs.headerContainer.nativeElement.offsetWidth; const offset = this.tabs.offset; const 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 = () => [ { 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); export { IgxRightButtonStyleDirective }; let IgxLeftButtonStyleDirective = class IgxLeftButtonStyleDirective { constructor(tabs) { this.tabs = tabs; } get visibleCSS() { return (this.getLeftButtonStyle() === ButtonStyle.VISIBLE) ? true : false; } get hiddenCSS() { return (this.getLeftButtonStyle() === ButtonStyle.HIDDEN) ? true : false; } get notDisplayedCSS() { return (this.getLeftButtonStyle() === ButtonStyle.NOT_DISPLAYED) ? true : false; } getLeftButtonStyle() { // We use this hacky way to get the width of the itemsContainer, // because there is inconsistency in IE we cannot use offsetWidth or scrollOffset. const itemsContainerChildrenCount = this.tabs.itemsContainer.nativeElement.children.length; let itemsContainerWidth = 0; if (itemsContainerChildrenCount > 1) { const lastTab = this.tabs.itemsContainer.nativeElement.children[itemsContainerChildrenCount - 2]; itemsContainerWidth = lastTab.offsetLeft + lastTab.offsetWidth; } const headerContainerWidth = this.tabs.headerContainer.nativeElement.offsetWidth; const 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 = () => [ { 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); export { IgxLeftButtonStyleDirective }; let IgxTabItemTemplateDirective = class IgxTabItemTemplateDirective { constructor(template) { this.template = template; } }; IgxTabItemTemplateDirective.ctorParameters = () => [ { type: TemplateRef } ]; IgxTabItemTemplateDirective = __decorate([ Directive({ selector: '[igxTab]' }), __metadata("design:paramtypes", [TemplateRef]) ], 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"]}