@stratio/egeo
Version:
242 lines • 18.5 kB
JavaScript
/**
* @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>
* ```
*/
var StPopComponent = /** @class */ (function () {
function StPopComponent(_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;
}
Object.defineProperty(StPopComponent.prototype, "hidden", {
get: /**
* @return {?}
*/
function () {
return this._hidden;
},
/** @Input {boleean} [hidden=true] TRUE: show pop content, FALSE: hide pop content */
set: /**
* \@Input {boleean} [hidden=true] TRUE: show pop content, FALSE: hide pop content
* @param {?} value
* @return {?}
*/
function (value) {
var _this = this;
setTimeout((/**
* @return {?}
*/
function () {
if (!value) {
_this.calculatePosition();
}
_this._hidden = value;
_this._cd.markForCheck();
}));
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
StPopComponent.prototype.ngAfterViewInit = /**
* @return {?}
*/
function () {
this.calculatePosition();
};
/**
* @param {?} changes
* @return {?}
*/
StPopComponent.prototype.ngOnChanges = /**
* @param {?} changes
* @return {?}
*/
function (changes) {
this.calculatePosition();
};
/**
* @return {?}
*/
StPopComponent.prototype.updateWidth = /**
* @return {?}
*/
function () {
this.calculatePosition();
};
/**
* @private
* @return {?}
*/
StPopComponent.prototype.getContentElement = /**
* @private
* @return {?}
*/
function () {
return this._el.nativeElement.querySelector('[pop-content]');
};
/**
* @private
* @return {?}
*/
StPopComponent.prototype.calculatePosition = /**
* @private
* @return {?}
*/
function () {
/** @type {?} */
var buttonParentEl = this._el.nativeElement.querySelector('[pop-button]');
/** @type {?} */
var contentEl = this.getContentElement();
/** @type {?} */
var buttonEl = buttonParentEl && buttonParentEl.firstElementChild ?
buttonParentEl.firstElementChild : undefined;
if (buttonEl) {
/** @type {?} */
var 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 {?}
*/
StPopComponent.prototype.getCoords = /**
* @private
* @param {?} buttonEl
* @return {?}
*/
function (buttonEl) {
/** @type {?} */
var coords = { x: 0, y: 0, z: 0 };
/** @type {?} */
var direction = this.openToLeft ? this.getContentElement().getBoundingClientRect().width : 0;
/** @type {?} */
var 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 = function () { return [
{ type: ElementRef },
{ type: ChangeDetectorRef }
]; };
StPopComponent.propDecorators = {
placement: [{ type: Input }],
offset: [{ type: Input }],
openToLeft: [{ type: Input }],
hidden: [{ type: Input }],
updateWidth: [{ type: HostListener, args: ['window:load',] }]
};
return StPopComponent;
}());
export { StPopComponent };
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":";;;;;;;;;;;;;;;AAUA,OAAO,EAAiB,uBAAuB,EAAE,iBAAiB,EAAE,SAAS,EAAE,UAAU,EAAE,YAAY,EAAE,KAAK,EAA4B,MAAM,eAAe,CAAC;AAEhK,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;;;;;;;;;;;;;;;;;;AAsB7D;IAkCG,wBAAoB,GAAe,EAAU,GAAsB;QAA/C,QAAG,GAAH,GAAG,CAAY;QAAU,QAAG,GAAH,GAAG,CAAmB;;;;QAzB1D,cAAS,GAAmB,cAAc,CAAC,YAAY,CAAC;;;;QAGxD,WAAM,GAAgB,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;;;;QAErC,eAAU,GAAY,KAAK,CAAC;QAE7B,YAAO,GAAY,IAAI,CAAC;IAmBhC,CAAC;IAhBD,sBACI,kCAAM;;;;QAUV;YACG,OAAO,IAAI,CAAC,OAAO,CAAC;QACvB,CAAC;QAdD,uFAAuF;;;;;;QACvF,UACW,KAAc;YADzB,iBASC;YAPE,UAAU;;;YAAC;gBACR,IAAI,CAAC,KAAK,EAAE;oBACT,KAAI,CAAC,iBAAiB,EAAE,CAAC;iBAC3B;gBACD,KAAI,CAAC,OAAO,GAAG,KAAK,CAAC;gBACrB,KAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;YAC3B,CAAC,EAAC,CAAC;QACN,CAAC;;;OAAA;;;;IASD,wCAAe;;;IAAf;QACG,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC5B,CAAC;;;;;IAED,oCAAW;;;;IAAX,UAAY,OAAsB;QAC/B,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC5B,CAAC;;;;IAGD,oCAAW;;;IADX;QAEG,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC5B,CAAC;;;;;IAEO,0CAAiB;;;;IAAzB;QACG,OAAO,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,aAAa,CAAC,eAAe,CAAC,CAAC;IAChE,CAAC;;;;;IAEO,0CAAiB;;;;IAAzB;;YACS,cAAc,GAAgB,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,aAAa,CAAC,cAAc,CAAC;;YAClF,SAAS,GAAgB,IAAI,CAAC,iBAAiB,EAAE;;YACjD,QAAQ,GAAwB,cAAc,IAAI,cAAc,CAAC,iBAAiB,CAAC,CAAC;YACvF,cAAc,CAAC,iBAAiB,CAAC,CAAC,CAAC,SAAS;QAC/C,IAAI,QAAQ,EAAE;;gBACL,MAAM,GAAa,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC;YAEjD,SAAS,CAAC,KAAK,CAAC,QAAQ,GAAG,UAAU,CAAC;YACtC,SAAS,CAAC,KAAK,CAAC,SAAS,GAAG,iBAAe,MAAM,CAAC,CAAC,YAAO,MAAM,CAAC,CAAC,YAAO,MAAM,CAAC,CAAC,QAAK,CAAC;SACzF;IACJ,CAAC;;;;;;IAEO,kCAAS;;;;;IAAjB,UAAkB,QAAiB;;YAC1B,MAAM,GAAa,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE;;YACvC,SAAS,GAAW,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC,qBAAqB,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;;YAChG,UAAU,GAAe,QAAQ,CAAC,qBAAqB,EAAE;QAE/D,QAAQ,IAAI,CAAC,SAAS,EAAE;YACrB,KAAK,cAAc,CAAC,MAAM;gBACvB,MAAM,CAAC,CAAC,GAAG,UAAU,CAAC,KAAK,GAAG,CAAC,CAAC;gBAChC,MAAM;YACT,KAAK,cAAc,CAAC,UAAU;gBAC3B,MAAM,CAAC,CAAC,GAAG,UAAU,CAAC,KAAK,CAAC;gBAC5B,MAAM;YACT,KAAK,cAAc,CAAC,GAAG;gBACpB,MAAM,CAAC,CAAC,GAAG,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;gBAClC,MAAM,CAAC,CAAC,GAAG,UAAU,CAAC,KAAK,GAAG,CAAC,CAAC;gBAChC,MAAM;YACT,KAAK,cAAc,CAAC,SAAS;gBAC1B,MAAM,CAAC,CAAC,GAAG,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;gBAClC,MAAM;YACT,KAAK,cAAc,CAAC,OAAO;gBACxB,MAAM,CAAC,CAAC,GAAG,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;gBAClC,MAAM,CAAC,CAAC,GAAG,UAAU,CAAC,KAAK,CAAC;gBAC5B,MAAM;YACT;gBACG,MAAM;SACX;QAED,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC;QAC3D,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QAE/C,OAAO,MAAM,CAAC;IACjB,CAAC;;gBAlGH,SAAS,SAAC;oBACR,QAAQ,EAAE,QAAQ;oBAElB,0nBAAsC;oBACtC,eAAe,EAAE,uBAAuB,CAAC,MAAM;;iBACjD;;;;gBA7B8E,UAAU;gBAAxC,iBAAiB;;;4BAiC9D,KAAK;yBAGL,KAAK;6BAEL,KAAK;yBAKL,KAAK;8BA0BL,YAAY,SAAC,aAAa;;IAsD9B,qBAAC;CAAA,AAnGD,IAmGC;SA7FY,cAAc;;;;;;IAGxB,mCAAiE;;;;;IAGjE,gCAA8C;;;;;IAE9C,oCAAqC;;;;;IAErC,iCAAgC;;;;;IAkBpB,6BAAuB;;;;;IAAE,6BAA8B","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"]}