UNPKG

@stratio/egeo

Version:
215 lines 17.3 kB
/** * @fileoverview added by tsickle * Generated from: lib/st-pop/st-pop.component.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ /* * © 2017 Stratio Big Data Inc., Sucursal en España. * * This software is licensed under the Apache License, Version 2.0. * This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. * See the terms of the License for more details. * * SPDX-License-Identifier: Apache-2.0. */ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, HostListener, Input } from '@angular/core'; import { StPopOffset, StPopPlacement } from './st-pop.model'; /** * \@description {Component} [Pop] * * The pop is a component for manage floating elements like popups or dropdown-menu. This element need two element inside, * a button element that launch popper and a content element that whose position will be relativo to button element. * * \@example * * {html} * * ``` * <st-pop [hidden]="false" placement="bottom"> * <div pop-button>Button</div> * <div pop-content>Content</div> * </st-pop> * ``` */ export class StPopComponent { /** * @param {?} _el * @param {?} _cd */ constructor(_el, _cd) { this._el = _el; this._cd = _cd; /** * \@Input {StPopPlacement} [placement=StPopPlacement.BOTOM_START] Define position of content relative to button */ this.placement = StPopPlacement.BOTTOM_START; /** * \@Input {StPopOffset} [offset={x: 0 , y: 0}] For position with offset in x o y axis */ this.offset = { x: 0, y: 0 }; /** * \@Input {boolean} [openToLeft=false] For calculating all positions from the right corner */ this.openToLeft = false; this._hidden = true; } /** * \@Input {boleean} [hidden=true] TRUE: show pop content, FALSE: hide pop content * @param {?} value * @return {?} */ set hidden(value) { setTimeout((/** * @return {?} */ () => { if (!value) { this.calculatePosition(); } this._hidden = value; this._cd.markForCheck(); })); } /** * @return {?} */ get hidden() { return this._hidden; } /** * @return {?} */ ngAfterViewInit() { this.calculatePosition(); } /** * @param {?} changes * @return {?} */ ngOnChanges(changes) { this.calculatePosition(); } /** * @return {?} */ updateWidth() { this.calculatePosition(); } /** * @private * @return {?} */ getContentElement() { return this._el.nativeElement.querySelector('[pop-content]'); } /** * @private * @return {?} */ calculatePosition() { /** @type {?} */ const buttonParentEl = this._el.nativeElement.querySelector('[pop-button]'); /** @type {?} */ const contentEl = this.getContentElement(); /** @type {?} */ const buttonEl = buttonParentEl && buttonParentEl.firstElementChild ? buttonParentEl.firstElementChild : undefined; if (buttonEl) { /** @type {?} */ const coords = this.getCoords(buttonEl); contentEl.style.position = 'absolute'; contentEl.style.transform = `translate3d(${coords.x}px, ${coords.y}px, ${coords.z}px)`; } } /** * @private * @param {?} buttonEl * @return {?} */ getCoords(buttonEl) { /** @type {?} */ const coords = { x: 0, y: 0, z: 0 }; /** @type {?} */ const direction = this.openToLeft ? this.getContentElement().getBoundingClientRect().width : 0; /** @type {?} */ const clientRect = buttonEl.getBoundingClientRect(); switch (this.placement) { case StPopPlacement.BOTTOM: coords.x = clientRect.width / 2; break; case StPopPlacement.BOTTOM_END: coords.x = clientRect.width; break; case StPopPlacement.TOP: coords.y = clientRect.height * -1; coords.x = clientRect.width / 2; break; case StPopPlacement.TOP_START: coords.y = clientRect.height * -1; break; case StPopPlacement.TOP_END: coords.y = clientRect.height * -1; coords.x = clientRect.width; break; default: break; } coords.x = Math.ceil(coords.x + this.offset.x - direction); coords.y = Math.ceil(coords.y + this.offset.y); return coords; } } StPopComponent.decorators = [ { type: Component, args: [{ selector: 'st-pop', template: "<!--\n\n \u00A9 2017 Stratio Big Data Inc., Sucursal en Espa\u00F1a.\n\n This software is licensed under the Apache License, Version 2.0.\n This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;\n without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n See the terms of the License for more details.\n\n SPDX-License-Identifier: Apache-2.0.\n\n-->\n<ng-content select=[pop-button]></ng-content>\n<div [style.visibility]=\"hidden ? 'hidden' : 'visible'\" class=\"content\">\n <ng-content select=[pop-content]></ng-content>\n</div>\n", changeDetection: ChangeDetectionStrategy.OnPush, styles: ["@charset \"UTF-8\";.content{height:0}"] }] } ]; /** @nocollapse */ StPopComponent.ctorParameters = () => [ { type: ElementRef }, { type: ChangeDetectorRef } ]; StPopComponent.propDecorators = { placement: [{ type: Input }], offset: [{ type: Input }], openToLeft: [{ type: Input }], hidden: [{ type: Input }], updateWidth: [{ type: HostListener, args: ['window:load',] }] }; if (false) { /** * \@Input {StPopPlacement} [placement=StPopPlacement.BOTOM_START] Define position of content relative to button * @type {?} */ StPopComponent.prototype.placement; /** * \@Input {StPopOffset} [offset={x: 0 , y: 0}] For position with offset in x o y axis * @type {?} */ StPopComponent.prototype.offset; /** * \@Input {boolean} [openToLeft=false] For calculating all positions from the right corner * @type {?} */ StPopComponent.prototype.openToLeft; /** * @type {?} * @private */ StPopComponent.prototype._hidden; /** * @type {?} * @private */ StPopComponent.prototype._el; /** * @type {?} * @private */ StPopComponent.prototype._cd; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"st-pop.component.js","sourceRoot":"ng://@stratio/egeo/","sources":["lib/st-pop/st-pop.component.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * © 2017 Stratio Big Data Inc., Sucursal en España.\n *\n * This software is licensed under the Apache License, Version 2.0.\n * This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;\n * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n * See the terms of the License for more details.\n *\n * SPDX-License-Identifier: Apache-2.0.\n */\nimport { AfterViewInit, ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, HostListener, Input, OnChanges, SimpleChanges } from '@angular/core';\n\nimport { StPopOffset, StPopPlacement } from './st-pop.model';\n\n// Internal type\ntype StCoords = { x: number, y: number, z: number };\n\n/**\n * @description {Component} [Pop]\n *\n * The pop is a component for manage floating elements like popups or dropdown-menu. This element need two element inside,\n * a button element that launch popper and a content element that whose position will be relativo to button element.\n *\n * @example\n *\n * {html}\n *\n * ```\n * <st-pop [hidden]=\"false\" placement=\"bottom\">\n *    <div pop-button>Button</div>\n *    <div pop-content>Content</div>\n * </st-pop>\n * ```\n */\n@Component({\n   selector: 'st-pop',\n   styleUrls: ['./st-pop.component.scss'],\n   templateUrl: './st-pop.component.html',\n   changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class StPopComponent implements AfterViewInit {\n\n   /** @Input {StPopPlacement} [placement=StPopPlacement.BOTOM_START] Define position of content relative to button */\n   @Input() placement: StPopPlacement = StPopPlacement.BOTTOM_START;\n\n   /** @Input {StPopOffset} [offset={x: 0 , y: 0}] For position with offset in x o y axis */\n   @Input() offset: StPopOffset = { x: 0, y: 0 };\n   /** @Input {boolean} [openToLeft=false] For calculating all positions from the right corner */\n   @Input() openToLeft: boolean = false;\n\n   private _hidden: boolean = true;\n\n   /** @Input {boleean} [hidden=true]  TRUE: show pop content, FALSE: hide pop content  */\n   @Input()\n   set hidden(value: boolean) {\n      setTimeout(() => {\n         if (!value) {\n            this.calculatePosition();\n         }\n         this._hidden = value;\n         this._cd.markForCheck();\n      });\n   }\n\n   get hidden(): boolean {\n      return this._hidden;\n   }\n\n   constructor(private _el: ElementRef, private _cd: ChangeDetectorRef) {\n   }\n\n   ngAfterViewInit(): void {\n      this.calculatePosition();\n   }\n\n   ngOnChanges(changes: SimpleChanges): void {\n      this.calculatePosition();\n   }\n\n   @HostListener('window:load')\n   updateWidth(): void {\n      this.calculatePosition();\n   }\n\n   private getContentElement(): HTMLElement {\n      return this._el.nativeElement.querySelector('[pop-content]');\n   }\n\n   private calculatePosition(): void {\n      const buttonParentEl: HTMLElement = this._el.nativeElement.querySelector('[pop-button]');\n      const contentEl: HTMLElement = this.getContentElement();\n      const buttonEl: Element | undefined = buttonParentEl && buttonParentEl.firstElementChild ?\n         buttonParentEl.firstElementChild : undefined;\n      if (buttonEl) {\n         const coords: StCoords = this.getCoords(buttonEl);\n\n         contentEl.style.position = 'absolute';\n         contentEl.style.transform = `translate3d(${coords.x}px, ${coords.y}px, ${coords.z}px)`;\n      }\n   }\n\n   private getCoords(buttonEl: Element): StCoords {\n      const coords: StCoords = { x: 0, y: 0, z: 0 };\n      const direction: number = this.openToLeft ? this.getContentElement().getBoundingClientRect().width : 0;\n      const clientRect: ClientRect = buttonEl.getBoundingClientRect();\n\n      switch (this.placement) {\n         case StPopPlacement.BOTTOM:\n            coords.x = clientRect.width / 2;\n            break;\n         case StPopPlacement.BOTTOM_END:\n            coords.x = clientRect.width;\n            break;\n         case StPopPlacement.TOP:\n            coords.y = clientRect.height * -1;\n            coords.x = clientRect.width / 2;\n            break;\n         case StPopPlacement.TOP_START:\n            coords.y = clientRect.height * -1;\n            break;\n         case StPopPlacement.TOP_END:\n            coords.y = clientRect.height * -1;\n            coords.x = clientRect.width;\n            break;\n         default:\n            break;\n      }\n\n      coords.x = Math.ceil(coords.x + this.offset.x - direction);\n      coords.y = Math.ceil(coords.y + this.offset.y);\n\n      return coords;\n   }\n}\n"]}