@engie-group/fluid-design-system-angular
Version:
Fluid Design System Angular
167 lines • 23 kB
JavaScript
import { ComponentPortal } from '@angular/cdk/portal';
import { DOCUMENT } from '@angular/common';
import { Directive, HostListener, Inject, Input } from '@angular/core';
import { fromEvent, merge, Subject, takeUntil } from 'rxjs';
import { TooltipComponent } from '../tooltip.component';
import * as i0 from "@angular/core";
import * as i1 from "@angular/cdk/overlay";
export class TooltipDirective {
set tooltipOptions(value) {
this._tooltipOptions = value;
this.setTooltipValues();
const scrollableAncestors = this.scrollDispatcher.getAncestorScrollContainers(this.el);
const positionStrategy = this.overlayPositionBuilder
.flexibleConnectedTo(this.el)
.withPositions([this.getPositionOptions()])
.withScrollableContainers(scrollableAncestors);
this.overlayRef?.updatePositionStrategy(positionStrategy);
}
get tooltipOptions() {
return this._tooltipOptions;
}
constructor(el, overlayPositionBuilder, overlay, scrollDispatcher, doc, zone) {
this.el = el;
this.overlayPositionBuilder = overlayPositionBuilder;
this.overlay = overlay;
this.scrollDispatcher = scrollDispatcher;
this.doc = doc;
this.zone = zone;
this.unsubscribe = new Subject();
}
ngOnInit() {
const scrollableAncestors = this.scrollDispatcher.getAncestorScrollContainers(this.el);
const positionStrategy = this.overlayPositionBuilder
.flexibleConnectedTo(this.el)
.withPositions([this.getPositionOptions()])
.withScrollableContainers(scrollableAncestors);
this.overlayRef = this.overlay.create({
positionStrategy,
scrollStrategy: this.overlay.scrollStrategies.reposition()
});
}
ngOnDestroy() {
this.overlayRef?.dispose();
this.unsubscribe.next();
this.unsubscribe.complete();
}
getPositionOptions() {
const defaultPosition = {
originX: 'center',
originY: 'top',
overlayX: 'center',
overlayY: 'bottom'
};
switch (this.tooltipOptions?.placement) {
case 'bottom':
return {
originX: 'center',
originY: 'bottom',
overlayX: 'center',
overlayY: 'top'
};
case 'top':
return defaultPosition;
case 'left':
return {
originX: 'start',
originY: 'center',
overlayX: 'end',
overlayY: 'center'
};
case 'right':
return {
originX: 'end',
originY: 'center',
overlayX: 'start',
overlayY: 'center'
};
default:
return defaultPosition;
}
}
show() {
if (this.tooltipRef) {
return;
}
this.tooltipRef = this.overlayRef.attach(new ComponentPortal(TooltipComponent));
merge(fromEvent(this.tooltipRef?.location?.nativeElement, 'mouseleave'), fromEvent(this.tooltipRef?.location?.nativeElement, 'focusout'))
.pipe(takeUntil(this.unsubscribe))
.subscribe((event) => {
this.hide(event);
});
this.zone.runOutsideAngular(() => {
this.intersectionObserver = new IntersectionObserver((entries) => {
entries.forEach((entry) => {
const isElementVisible = entry.isIntersecting;
if (!isElementVisible) {
this.zone.run(() => {
this.hide();
});
}
});
});
this.intersectionObserver.observe(this.el?.nativeElement);
});
this.setTooltipValues();
this.el?.nativeElement?.firstElementChild?.setAttribute('aria-describedby', this.tooltipOptions.tooltipId);
}
hide(event) {
const focusedElement = this.doc?.activeElement;
const isFocusedElement = focusedElement && this.el.nativeElement.contains(focusedElement);
const newTarget = event?.relatedTarget;
const isNextTargetTooltip = newTarget && this.overlayRef?.overlayElement?.contains(newTarget);
const isNextTargetElement = newTarget && this.el?.nativeElement?.contains(newTarget);
if (!newTarget || (!isNextTargetTooltip && !isNextTargetElement && !isFocusedElement)) {
this.overlayRef.detach();
this.tooltipRef = null;
this.unsubscribe.next();
this.intersectionObserver.disconnect();
this.el?.nativeElement?.firstElementChild?.removeAttribute('aria-describedby');
}
}
setTooltipValues() {
const tooltipComponent = this.tooltipRef?.instance;
if (!tooltipComponent) {
return;
}
tooltipComponent.label = this.tooltipCustomContent ? null : this.tooltipOptions?.label;
tooltipComponent.isInverse = this.tooltipOptions?.isInverse;
tooltipComponent.hasArrow = this.tooltipOptions?.hasArrow ?? true;
tooltipComponent.tooltipId = this.tooltipOptions?.tooltipId;
tooltipComponent.arrowPlacement = this.tooltipOptions?.arrowPlacement ?? 'center';
tooltipComponent.placement = this.tooltipOptions?.placement ?? 'top';
tooltipComponent.isStandalone = this.tooltipOptions?.isStandalone ?? true;
tooltipComponent.isAnimated = this.tooltipOptions?.isAnimated ?? true;
tooltipComponent.contentTemplateRef = this.tooltipCustomContent;
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TooltipDirective, deps: [{ token: i0.ElementRef }, { token: i1.OverlayPositionBuilder }, { token: i1.Overlay }, { token: i1.ScrollDispatcher }, { token: DOCUMENT }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Directive }); }
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: TooltipDirective, isStandalone: true, selector: "[njTooltip]", inputs: { tooltipOptions: "tooltipOptions", tooltipCustomContent: "tooltipCustomContent" }, host: { listeners: { "mouseenter": "show()", "focusin": "show()", "mouseleave": "hide($event)", "focusout": "hide($event)" } }, exportAs: ["njTooltip"], ngImport: i0 }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TooltipDirective, decorators: [{
type: Directive,
args: [{
selector: '[njTooltip]',
exportAs: 'njTooltip',
standalone: true
}]
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.OverlayPositionBuilder }, { type: i1.Overlay }, { type: i1.ScrollDispatcher }, { type: Document, decorators: [{
type: Inject,
args: [DOCUMENT]
}] }, { type: i0.NgZone }]; }, propDecorators: { tooltipOptions: [{
type: Input
}], tooltipCustomContent: [{
type: Input
}], show: [{
type: HostListener,
args: ['mouseenter']
}, {
type: HostListener,
args: ['focusin']
}], hide: [{
type: HostListener,
args: ['mouseleave', ['$event']]
}, {
type: HostListener,
args: ['focusout', ['$event']]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"","sources":["../../../../../src/components/tooltip/directives/tooltip.directive.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAC3C,OAAO,EAEL,SAAS,EAET,YAAY,EACZ,MAAM,EACN,KAAK,EAKN,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AAC5D,OAAO,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;;;AAQxD,MAAM,OAAO,gBAAgB;IAW3B,IACI,cAAc,CAAC,KAAqB;QACtC,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;QAC7B,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACxB,MAAM,mBAAmB,GAAG,IAAI,CAAC,gBAAgB,CAAC,2BAA2B,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACvF,MAAM,gBAAgB,GAAG,IAAI,CAAC,sBAAsB;aACjD,mBAAmB,CAAC,IAAI,CAAC,EAAE,CAAC;aAC5B,aAAa,CAAC,CAAC,IAAI,CAAC,kBAAkB,EAAE,CAAC,CAAC;aAC1C,wBAAwB,CAAC,mBAAmB,CAAC,CAAC;QACjD,IAAI,CAAC,UAAU,EAAE,sBAAsB,CAAC,gBAAgB,CAAC,CAAC;IAC5D,CAAC;IAED,IAAI,cAAc;QAChB,OAAO,IAAI,CAAC,eAAe,CAAC;IAC9B,CAAC;IAID,YACU,EAAc,EACd,sBAA8C,EAC9C,OAAgB,EAChB,gBAAkC,EAChB,GAAa,EAC/B,IAAY;QALZ,OAAE,GAAF,EAAE,CAAY;QACd,2BAAsB,GAAtB,sBAAsB,CAAwB;QAC9C,YAAO,GAAP,OAAO,CAAS;QAChB,qBAAgB,GAAhB,gBAAgB,CAAkB;QAChB,QAAG,GAAH,GAAG,CAAU;QAC/B,SAAI,GAAJ,IAAI,CAAQ;QAlCd,gBAAW,GAAkB,IAAI,OAAO,EAAQ,CAAC;IAmCtD,CAAC;IAEJ,QAAQ;QACN,MAAM,mBAAmB,GAAG,IAAI,CAAC,gBAAgB,CAAC,2BAA2B,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAEvF,MAAM,gBAAgB,GAAG,IAAI,CAAC,sBAAsB;aACjD,mBAAmB,CAAC,IAAI,CAAC,EAAE,CAAC;aAC5B,aAAa,CAAC,CAAC,IAAI,CAAC,kBAAkB,EAAE,CAAC,CAAC;aAC1C,wBAAwB,CAAC,mBAAmB,CAAC,CAAC;QAEjD,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC;YACpC,gBAAgB;YAChB,cAAc,EAAE,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,UAAU,EAAE;SAC3D,CAAC,CAAC;IACL,CAAC;IAED,WAAW;QACT,IAAI,CAAC,UAAU,EAAE,OAAO,EAAE,CAAC;QAC3B,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC;QACxB,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE,CAAC;IAC9B,CAAC;IAED,kBAAkB;QAChB,MAAM,eAAe,GAAsB;YACzC,OAAO,EAAE,QAAQ;YACjB,OAAO,EAAE,KAAK;YACd,QAAQ,EAAE,QAAQ;YAClB,QAAQ,EAAE,QAAQ;SACnB,CAAC;QACF,QAAQ,IAAI,CAAC,cAAc,EAAE,SAAS,EAAE;YACtC,KAAK,QAAQ;gBACX,OAAO;oBACL,OAAO,EAAE,QAAQ;oBACjB,OAAO,EAAE,QAAQ;oBACjB,QAAQ,EAAE,QAAQ;oBAClB,QAAQ,EAAE,KAAK;iBAChB,CAAC;YACJ,KAAK,KAAK;gBACR,OAAO,eAAe,CAAC;YACzB,KAAK,MAAM;gBACT,OAAO;oBACL,OAAO,EAAE,OAAO;oBAChB,OAAO,EAAE,QAAQ;oBACjB,QAAQ,EAAE,KAAK;oBACf,QAAQ,EAAE,QAAQ;iBACnB,CAAC;YACJ,KAAK,OAAO;gBACV,OAAO;oBACL,OAAO,EAAE,KAAK;oBACd,OAAO,EAAE,QAAQ;oBACjB,QAAQ,EAAE,OAAO;oBACjB,QAAQ,EAAE,QAAQ;iBACnB,CAAC;YACJ;gBACE,OAAO,eAAe,CAAC;SAC1B;IACH,CAAC;IAID,IAAI;QACF,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,OAAO;SACR;QACD,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,eAAe,CAAC,gBAAgB,CAAC,CAAC,CAAC;QAChF,KAAK,CACH,SAAS,CAAC,IAAI,CAAC,UAAU,EAAE,QAAQ,EAAE,aAAa,EAAE,YAAY,CAAC,EACjE,SAAS,CAAC,IAAI,CAAC,UAAU,EAAE,QAAQ,EAAE,aAAa,EAAE,UAAU,CAAC,CAChE;aACE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;aACjC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YACnB,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACnB,CAAC,CAAC,CAAC;QAEL,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,GAAG,EAAE;YAC/B,IAAI,CAAC,oBAAoB,GAAG,IAAI,oBAAoB,CAAC,CAAC,OAAO,EAAE,EAAE;gBAC/D,OAAO,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;oBACxB,MAAM,gBAAgB,GAAG,KAAK,CAAC,cAAc,CAAC;oBAC9C,IAAI,CAAC,gBAAgB,EAAE;wBACrB,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE;4BACjB,IAAI,CAAC,IAAI,EAAE,CAAC;wBACd,CAAC,CAAC,CAAC;qBACJ;gBACH,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,EAAE,aAAa,CAAC,CAAC;QAC5D,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAExB,IAAI,CAAC,EAAE,EAAE,aAAa,EAAE,iBAAiB,EAAE,YAAY,CAAC,kBAAkB,EAAE,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;IAC7G,CAAC;IAID,IAAI,CAAC,KAAM;QACT,MAAM,cAAc,GAAG,IAAI,CAAC,GAAG,EAAE,aAAa,CAAC;QAC/C,MAAM,gBAAgB,GAAG,cAAc,IAAI,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAC;QAC1F,MAAM,SAAS,GAAI,KAAoB,EAAE,aAA4B,CAAC;QACtE,MAAM,mBAAmB,GAAG,SAAS,IAAI,IAAI,CAAC,UAAU,EAAE,cAAc,EAAE,QAAQ,CAAC,SAAS,CAAC,CAAC;QAC9F,MAAM,mBAAmB,GAAG,SAAS,IAAI,IAAI,CAAC,EAAE,EAAE,aAAa,EAAE,QAAQ,CAAC,SAAS,CAAC,CAAC;QACrF,IAAI,CAAC,SAAS,IAAI,CAAC,CAAC,mBAAmB,IAAI,CAAC,mBAAmB,IAAI,CAAC,gBAAgB,CAAC,EAAE;YACrF,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC;YACzB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;YACvB,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC;YACxB,IAAI,CAAC,oBAAoB,CAAC,UAAU,EAAE,CAAC;YACvC,IAAI,CAAC,EAAE,EAAE,aAAa,EAAE,iBAAiB,EAAE,eAAe,CAAC,kBAAkB,CAAC,CAAC;SAChF;IACH,CAAC;IAED,gBAAgB;QACd,MAAM,gBAAgB,GAAG,IAAI,CAAC,UAAU,EAAE,QAAQ,CAAC;QACnD,IAAI,CAAC,gBAAgB,EAAE;YACrB,OAAO;SACR;QAED,gBAAgB,CAAC,KAAK,GAAG,IAAI,CAAC,oBAAoB,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,EAAE,KAAK,CAAC;QACvF,gBAAgB,CAAC,SAAS,GAAG,IAAI,CAAC,cAAc,EAAE,SAAS,CAAC;QAC5D,gBAAgB,CAAC,QAAQ,GAAG,IAAI,CAAC,cAAc,EAAE,QAAQ,IAAI,IAAI,CAAC;QAClE,gBAAgB,CAAC,SAAS,GAAG,IAAI,CAAC,cAAc,EAAE,SAAS,CAAC;QAC5D,gBAAgB,CAAC,cAAc,GAAG,IAAI,CAAC,cAAc,EAAE,cAAc,IAAI,QAAQ,CAAC;QAClF,gBAAgB,CAAC,SAAS,GAAG,IAAI,CAAC,cAAc,EAAE,SAAS,IAAI,KAAK,CAAC;QACrE,gBAAgB,CAAC,YAAY,GAAG,IAAI,CAAC,cAAc,EAAE,YAAY,IAAI,IAAI,CAAC;QAC1E,gBAAgB,CAAC,UAAU,GAAG,IAAI,CAAC,cAAc,EAAE,UAAU,IAAI,IAAI,CAAC;QACtE,gBAAgB,CAAC,kBAAkB,GAAG,IAAI,CAAC,oBAAoB,CAAC;IAClE,CAAC;+GAjKU,gBAAgB,yIAkCjB,QAAQ;mGAlCP,gBAAgB;;4FAAhB,gBAAgB;kBAL5B,SAAS;mBAAC;oBACT,QAAQ,EAAE,aAAa;oBACvB,QAAQ,EAAE,WAAW;oBACrB,UAAU,EAAE,IAAI;iBACjB;;0BAmCI,MAAM;2BAAC,QAAQ;iEAtBd,cAAc;sBADjB,KAAK;gBAgBG,oBAAoB;sBAA5B,KAAK;gBAqEN,IAAI;sBAFH,YAAY;uBAAC,YAAY;;sBACzB,YAAY;uBAAC,SAAS;gBAoCvB,IAAI;sBAFH,YAAY;uBAAC,YAAY,EAAE,CAAC,QAAQ,CAAC;;sBACrC,YAAY;uBAAC,UAAU,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import { ConnectedPosition, Overlay, OverlayPositionBuilder, OverlayRef, ScrollDispatcher } from '@angular/cdk/overlay';\nimport { ComponentPortal } from '@angular/cdk/portal';\nimport { DOCUMENT } from '@angular/common';\nimport {\n  ComponentRef,\n  Directive,\n  ElementRef,\n  HostListener,\n  Inject,\n  Input,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  TemplateRef\n} from '@angular/core';\nimport { fromEvent, merge, Subject, takeUntil } from 'rxjs';\nimport { TooltipComponent } from '../tooltip.component';\nimport { TooltipOptions } from '../tooltip.model';\n\n@Directive({\n  selector: '[njTooltip]',\n  exportAs: 'njTooltip',\n  standalone: true\n})\nexport class TooltipDirective implements OnInit, OnDestroy {\n  private unsubscribe: Subject<void> = new Subject<void>();\n\n  private _tooltipOptions: TooltipOptions;\n\n  private overlayRef: OverlayRef;\n\n  private tooltipRef: ComponentRef<TooltipComponent>;\n\n  private intersectionObserver: IntersectionObserver;\n\n  @Input()\n  set tooltipOptions(value: TooltipOptions) {\n    this._tooltipOptions = value;\n    this.setTooltipValues();\n    const scrollableAncestors = this.scrollDispatcher.getAncestorScrollContainers(this.el);\n    const positionStrategy = this.overlayPositionBuilder\n      .flexibleConnectedTo(this.el)\n      .withPositions([this.getPositionOptions()])\n      .withScrollableContainers(scrollableAncestors);\n    this.overlayRef?.updatePositionStrategy(positionStrategy);\n  }\n\n  get tooltipOptions(): TooltipOptions {\n    return this._tooltipOptions;\n  }\n\n  @Input() tooltipCustomContent: TemplateRef<any>;\n\n  constructor(\n    private el: ElementRef,\n    private overlayPositionBuilder: OverlayPositionBuilder,\n    private overlay: Overlay,\n    private scrollDispatcher: ScrollDispatcher,\n    @Inject(DOCUMENT) private doc: Document,\n    private zone: NgZone\n  ) {}\n\n  ngOnInit(): void {\n    const scrollableAncestors = this.scrollDispatcher.getAncestorScrollContainers(this.el);\n\n    const positionStrategy = this.overlayPositionBuilder\n      .flexibleConnectedTo(this.el)\n      .withPositions([this.getPositionOptions()])\n      .withScrollableContainers(scrollableAncestors);\n\n    this.overlayRef = this.overlay.create({\n      positionStrategy,\n      scrollStrategy: this.overlay.scrollStrategies.reposition()\n    });\n  }\n\n  ngOnDestroy() {\n    this.overlayRef?.dispose();\n    this.unsubscribe.next();\n    this.unsubscribe.complete();\n  }\n\n  getPositionOptions(): ConnectedPosition {\n    const defaultPosition: ConnectedPosition = {\n      originX: 'center',\n      originY: 'top',\n      overlayX: 'center',\n      overlayY: 'bottom'\n    };\n    switch (this.tooltipOptions?.placement) {\n      case 'bottom':\n        return {\n          originX: 'center',\n          originY: 'bottom',\n          overlayX: 'center',\n          overlayY: 'top'\n        };\n      case 'top':\n        return defaultPosition;\n      case 'left':\n        return {\n          originX: 'start',\n          originY: 'center',\n          overlayX: 'end',\n          overlayY: 'center'\n        };\n      case 'right':\n        return {\n          originX: 'end',\n          originY: 'center',\n          overlayX: 'start',\n          overlayY: 'center'\n        };\n      default:\n        return defaultPosition;\n    }\n  }\n\n  @HostListener('mouseenter')\n  @HostListener('focusin')\n  show() {\n    if (this.tooltipRef) {\n      return;\n    }\n    this.tooltipRef = this.overlayRef.attach(new ComponentPortal(TooltipComponent));\n    merge(\n      fromEvent(this.tooltipRef?.location?.nativeElement, 'mouseleave'),\n      fromEvent(this.tooltipRef?.location?.nativeElement, 'focusout')\n    )\n      .pipe(takeUntil(this.unsubscribe))\n      .subscribe((event) => {\n        this.hide(event);\n      });\n\n    this.zone.runOutsideAngular(() => {\n      this.intersectionObserver = new IntersectionObserver((entries) => {\n        entries.forEach((entry) => {\n          const isElementVisible = entry.isIntersecting;\n          if (!isElementVisible) {\n            this.zone.run(() => {\n              this.hide();\n            });\n          }\n        });\n      });\n\n      this.intersectionObserver.observe(this.el?.nativeElement);\n    });\n    this.setTooltipValues();\n\n    this.el?.nativeElement?.firstElementChild?.setAttribute('aria-describedby', this.tooltipOptions.tooltipId);\n  }\n\n  @HostListener('mouseleave', ['$event'])\n  @HostListener('focusout', ['$event'])\n  hide(event?) {\n    const focusedElement = this.doc?.activeElement;\n    const isFocusedElement = focusedElement && this.el.nativeElement.contains(focusedElement);\n    const newTarget = (event as MouseEvent)?.relatedTarget as Node | null;\n    const isNextTargetTooltip = newTarget && this.overlayRef?.overlayElement?.contains(newTarget);\n    const isNextTargetElement = newTarget && this.el?.nativeElement?.contains(newTarget);\n    if (!newTarget || (!isNextTargetTooltip && !isNextTargetElement && !isFocusedElement)) {\n      this.overlayRef.detach();\n      this.tooltipRef = null;\n      this.unsubscribe.next();\n      this.intersectionObserver.disconnect();\n      this.el?.nativeElement?.firstElementChild?.removeAttribute('aria-describedby');\n    }\n  }\n\n  setTooltipValues() {\n    const tooltipComponent = this.tooltipRef?.instance;\n    if (!tooltipComponent) {\n      return;\n    }\n\n    tooltipComponent.label = this.tooltipCustomContent ? null : this.tooltipOptions?.label;\n    tooltipComponent.isInverse = this.tooltipOptions?.isInverse;\n    tooltipComponent.hasArrow = this.tooltipOptions?.hasArrow ?? true;\n    tooltipComponent.tooltipId = this.tooltipOptions?.tooltipId;\n    tooltipComponent.arrowPlacement = this.tooltipOptions?.arrowPlacement ?? 'center';\n    tooltipComponent.placement = this.tooltipOptions?.placement ?? 'top';\n    tooltipComponent.isStandalone = this.tooltipOptions?.isStandalone ?? true;\n    tooltipComponent.isAnimated = this.tooltipOptions?.isAnimated ?? true;\n    tooltipComponent.contentTemplateRef = this.tooltipCustomContent;\n  }\n}\n"]}