UNPKG

@uex/web-extensions

Version:

Uex extensions for Angular 6+ web projects

393 lines 23.1 kB
/** * @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"]}