@uex/web-extensions
Version:
Uex extensions for Angular 6+ web projects
393 lines • 23.1 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: lib/modules/popover/popover.component.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, ElementRef, Input } from '@angular/core';
import * as _ from 'lodash';
import PopperJS from 'popper.js';
import { ResizeSensor } from 'css-element-queries';
var PopoverComponent = /** @class */ (function () {
function PopoverComponent(elementRef) {
this.elementRef = elementRef;
this._visible = false;
this._placement = 'bottom-start';
this._use_target_width = false;
this._use_target_min_width = false;
this._default_size = {
width: null,
minWidth: null,
maxHeight: null
};
this.size = _.clone(this._default_size);
}
Object.defineProperty(PopoverComponent.prototype, "target", {
get: /**
* @return {?}
*/
function () { return this._target; },
set: /**
* @param {?} target
* @return {?}
*/
function (target) {
var _this = this;
setTimeout((/**
* @return {?}
*/
function () {
_this._target = target;
_this.update();
}));
},
enumerable: true,
configurable: true
});
Object.defineProperty(PopoverComponent.prototype, "visible", {
get: /**
* @return {?}
*/
function () { return this._visible; },
set: /**
* @param {?} visible
* @return {?}
*/
function (visible) {
var _this = this;
setTimeout((/**
* @return {?}
*/
function () {
_this._visible = visible;
_this._updatePopper();
}));
},
enumerable: true,
configurable: true
});
Object.defineProperty(PopoverComponent.prototype, "placement", {
get: /**
* @return {?}
*/
function () { return this._placement; },
set: /**
* @param {?} placement
* @return {?}
*/
function (placement) { this._placement = placement; this.update(); },
enumerable: true,
configurable: true
});
Object.defineProperty(PopoverComponent.prototype, "useTargetWidth", {
get: /**
* @return {?}
*/
function () { return this._use_target_width; },
set: /**
* @param {?} use
* @return {?}
*/
function (use) {
var _this = this;
setTimeout((/**
* @return {?}
*/
function () {
_this._use_target_width = use;
_this.update();
}));
},
enumerable: true,
configurable: true
});
Object.defineProperty(PopoverComponent.prototype, "useTargetMinWidth", {
get: /**
* @return {?}
*/
function () { return this._use_target_min_width; },
set: /**
* @param {?} use
* @return {?}
*/
function (use) {
var _this = this;
setTimeout((/**
* @return {?}
*/
function () {
_this._use_target_min_width = use;
_this.update();
}));
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
PopoverComponent.prototype.ngAfterViewInit = /**
* @return {?}
*/
function () {
var _this = this;
this._resize_sensor = new ResizeSensor(this.elementRef.nativeElement, (/**
* @return {?}
*/
function () { return _this._updatePopper(); }));
};
/**
* @return {?}
*/
PopoverComponent.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
if (this._resize_sensor) {
this._resize_sensor.detach();
}
if (this._popper) {
this._popper.destroy();
}
};
/**
* @return {?}
*/
PopoverComponent.prototype.show = /**
* @return {?}
*/
function () {
this.visible = true;
};
/**
* @return {?}
*/
PopoverComponent.prototype.hide = /**
* @return {?}
*/
function () {
this.visible = false;
};
/**
* @return {?}
*/
PopoverComponent.prototype.update = /**
* @return {?}
*/
function () {
if (!this.visible) {
return;
}
this._setPopper();
};
/**
* @private
* @return {?}
*/
PopoverComponent.prototype._setPopper = /**
* @private
* @return {?}
*/
function () {
var _this = this;
if (this._popper) {
this._popper.destroy();
this._popper = null;
}
/** @type {?} */
var target = this._getTarget();
if (!target) {
return;
}
setTimeout((/**
* @return {?}
*/
function () {
_this._popper = new PopperJS(target, _this.elementRef.nativeElement, {
placement: _this._placement,
positionFixed: true,
onUpdate: (/**
* @return {?}
*/
function () { return _this._setSize(); })
});
_this._popper.update();
}));
};
/**
* @private
* @return {?}
*/
PopoverComponent.prototype._updatePopper = /**
* @private
* @return {?}
*/
function () {
if (this._popper) {
this._popper.update();
}
else {
this._setPopper();
}
};
/**
* @private
* @return {?}
*/
PopoverComponent.prototype._setSize = /**
* @private
* @return {?}
*/
function () {
if (!this.target) {
return;
}
this.size = _.clone(this._default_size);
/** @type {?} */
var target = this._getTarget();
/** @type {?} */
var target_rect = target.getBoundingClientRect();
if (this.useTargetWidth) {
this.size.width = target_rect.width;
}
if (this.useTargetMinWidth) {
this.size.minWidth = target_rect.width;
}
this._setMaxHeight();
};
/**
* @private
* @return {?}
*/
PopoverComponent.prototype._setMaxHeight = /**
* @private
* @return {?}
*/
function () {
/** @type {?} */
var scroll_parent = this._getScrollParent();
if (!scroll_parent) {
return;
}
/** @type {?} */
var parent_rect = scroll_parent.getBoundingClientRect();
this.size.maxHeight = parent_rect.height * 0.8;
};
/**
* @private
* @return {?}
*/
PopoverComponent.prototype._getTarget = /**
* @private
* @return {?}
*/
function () {
return this.target.elementRef ? this.target.elementRef.nativeElement : this.target;
};
/**
* @private
* @param {?=} node
* @return {?}
*/
PopoverComponent.prototype._getScrollParent = /**
* @private
* @param {?=} node
* @return {?}
*/
function (node) {
if (node === void 0) { node = this.elementRef.nativeElement; }
if (node == null) {
return null;
}
if (node != this.elementRef.nativeElement && node.scrollHeight > node.clientHeight) {
return node;
}
else {
return this._getScrollParent(node.parentNode);
}
};
PopoverComponent.decorators = [
{ type: Component, args: [{
selector: 'uex-popover',
template: '<ng-content></ng-content>',
host: {
class: 'uex-popover',
'[class.visible]': 'visible',
'[style.width.px]': 'size.width',
'[style.min-width.px]': 'size.minWidth',
'[style.max-height.px]': 'size.maxHeight'
}
}] }
];
/** @nocollapse */
PopoverComponent.ctorParameters = function () { return [
{ type: ElementRef }
]; };
PopoverComponent.propDecorators = {
target: [{ type: Input }],
visible: [{ type: Input }],
placement: [{ type: Input }],
useTargetWidth: [{ type: Input }],
useTargetMinWidth: [{ type: Input }]
};
return PopoverComponent;
}());
export { PopoverComponent };
if (false) {
/**
* @type {?}
* @private
*/
PopoverComponent.prototype._popper;
/**
* @type {?}
* @private
*/
PopoverComponent.prototype._target;
/**
* @type {?}
* @private
*/
PopoverComponent.prototype._visible;
/**
* @type {?}
* @private
*/
PopoverComponent.prototype._placement;
/**
* @type {?}
* @private
*/
PopoverComponent.prototype._use_target_width;
/**
* @type {?}
* @private
*/
PopoverComponent.prototype._use_target_min_width;
/**
* @type {?}
* @private
*/
PopoverComponent.prototype._resize_sensor;
/**
* @type {?}
* @private
*/
PopoverComponent.prototype._default_size;
/** @type {?} */
PopoverComponent.prototype.size;
/** @type {?} */
PopoverComponent.prototype.elementRef;
}
/**
* @record
*/
export function IPopoverSize() { }
if (false) {
/** @type {?} */
IPopoverSize.prototype.width;
/** @type {?} */
IPopoverSize.prototype.minWidth;
/** @type {?} */
IPopoverSize.prototype.maxHeight;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover.component.js","sourceRoot":"ng://@uex/web-extensions/","sources":["lib/modules/popover/popover.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Input, AfterViewInit, OnDestroy } from '@angular/core';\r\n\r\nimport * as _ from 'lodash';\r\nimport PopperJS from 'popper.js';\r\nimport { ResizeSensor } from 'css-element-queries';\r\n\r\n@Component({\r\n  selector: 'uex-popover',\r\n  template: '<ng-content></ng-content>',\r\n  host: {\r\n    class: 'uex-popover',\r\n    '[class.visible]': 'visible',\r\n    '[style.width.px]': 'size.width',\r\n    '[style.min-width.px]': 'size.minWidth',\r\n    '[style.max-height.px]': 'size.maxHeight'\r\n  }\r\n})\r\nexport class PopoverComponent implements AfterViewInit, OnDestroy {\r\n\r\n  @Input()\r\n    set target(target: any) {\r\n      setTimeout(() => {\r\n        this._target = target;\r\n        this.update();\r\n      });\r\n    }\r\n    get target(): any { return this._target; }\r\n  @Input()\r\n    set visible(visible: boolean) {\r\n      setTimeout(() => {\r\n        this._visible = visible;\r\n        this._updatePopper();\r\n      });\r\n    }\r\n    get visible(): boolean { return this._visible; }\r\n  @Input()\r\n    set placement(placement: PopperJS.Placement) { this._placement = placement; this.update(); }\r\n    get placement(): PopperJS.Placement { return this._placement; }\r\n  @Input()\r\n    set useTargetWidth(use: boolean) {\r\n      setTimeout(() => {\r\n        this._use_target_width = use;\r\n        this.update();\r\n      });\r\n    }\r\n    get useTargetWidth(): boolean { return this._use_target_width; }\r\n  @Input()\r\n    set useTargetMinWidth(use: boolean) {\r\n      setTimeout(() => {\r\n        this._use_target_min_width = use;\r\n        this.update();\r\n      });\r\n    }\r\n    get useTargetMinWidth(): boolean { return this._use_target_min_width; }\r\n\r\n  constructor(\r\n    public elementRef: ElementRef\r\n  ) { }\r\n\r\n  private _popper: PopperJS;\r\n  private _target: any;\r\n  private _visible = false;\r\n  private _placement: PopperJS.Placement = 'bottom-start';\r\n  private _use_target_width = false;\r\n  private _use_target_min_width = false;\r\n  private _resize_sensor: ResizeSensor;\r\n\r\n  private _default_size: IPopoverSize = {\r\n    width: null,\r\n    minWidth: null,\r\n    maxHeight: null\r\n  };\r\n  public size: IPopoverSize = _.clone(this._default_size);\r\n\r\n  public ngAfterViewInit() {\r\n    this._resize_sensor = new ResizeSensor(this.elementRef.nativeElement, () => this._updatePopper());\r\n  }\r\n\r\n  public ngOnDestroy() {\r\n    if (this._resize_sensor) { this._resize_sensor.detach(); }\r\n    if (this._popper) { this._popper.destroy(); }\r\n  }\r\n\r\n  public show() {\r\n    this.visible = true;\r\n  }\r\n\r\n  public hide() {\r\n    this.visible = false;\r\n  }\r\n\r\n  public update() {\r\n    if (!this.visible) { return; }\r\n    this._setPopper();\r\n  }\r\n\r\n  private _setPopper() {\r\n    if (this._popper) {\r\n      this._popper.destroy();\r\n      this._popper = null;\r\n    }\r\n\r\n    const target = this._getTarget();\r\n\r\n    if (!target) { return; }\r\n\r\n    setTimeout(() => {\r\n      this._popper = new PopperJS(target, this.elementRef.nativeElement, {\r\n        placement: this._placement,\r\n        positionFixed: true,\r\n        onUpdate: () => this._setSize()\r\n      });\r\n      this._popper.update();\r\n    });\r\n  }\r\n\r\n  private _updatePopper() {\r\n    if (this._popper) {\r\n      this._popper.update();\r\n    } else {\r\n      this._setPopper();\r\n    }\r\n  }\r\n\r\n  private _setSize() {\r\n    if (!this.target) { return; }\r\n\r\n    this.size = _.clone(this._default_size);\r\n\r\n    const target = this._getTarget();\r\n    const target_rect = target.getBoundingClientRect();\r\n\r\n    if (this.useTargetWidth) {\r\n      this.size.width = target_rect.width;\r\n    }\r\n    if (this.useTargetMinWidth) {\r\n      this.size.minWidth = target_rect.width;\r\n    }\r\n\r\n    this._setMaxHeight();\r\n  }\r\n\r\n  private _setMaxHeight() {\r\n    const scroll_parent = this._getScrollParent();\r\n    if (!scroll_parent) { return; }\r\n\r\n    const parent_rect = scroll_parent.getBoundingClientRect();\r\n    this.size.maxHeight = parent_rect.height * 0.8;\r\n  }\r\n\r\n  private _getTarget(): HTMLElement {\r\n    return this.target.elementRef ? this.target.elementRef.nativeElement : this.target;\r\n  }\r\n\r\n  private _getScrollParent(node = this.elementRef.nativeElement) {\r\n    if (node == null) {\r\n      return null;\r\n    }\r\n\r\n    if (node != this.elementRef.nativeElement && node.scrollHeight > node.clientHeight) {\r\n      return node;\r\n    } else {\r\n      return this._getScrollParent(node.parentNode);\r\n    }\r\n  }\r\n}\r\n\r\nexport interface IPopoverSize {\r\n  width: number;\r\n  minWidth: number;\r\n  maxHeight: number;\r\n}\r\n"]}