UNPKG

igniteui-angular

Version:

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

217 lines • 17.7 kB
/** * @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"]}