@mozaic-ds/angular 0.28.0 → 0.29.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (39) hide show
  1. package/adeo/components/phone-number/phone-number.component.d.ts +2 -1
  2. package/adeo/components/tooltip/directive/tooltip.directive.d.ts +8 -4
  3. package/adeo/components/tooltip/service/tooltip.service.d.ts +14 -0
  4. package/adeo/esm2020/components/autocomplete/autocomplete.component.mjs +3 -3
  5. package/adeo/esm2020/components/dropdown/dropdown.component.mjs +3 -3
  6. package/adeo/esm2020/components/phone-number/phone-number.component.mjs +7 -4
  7. package/adeo/esm2020/components/tooltip/directive/tooltip.directive.mjs +18 -14
  8. package/adeo/esm2020/components/tooltip/service/tooltip.service.mjs +35 -0
  9. package/adeo/fesm2015/mozaic-ds-angular.mjs +57 -19
  10. package/adeo/fesm2015/mozaic-ds-angular.mjs.map +1 -1
  11. package/adeo/fesm2020/mozaic-ds-angular.mjs +56 -19
  12. package/adeo/fesm2020/mozaic-ds-angular.mjs.map +1 -1
  13. package/adeo/package.json +1 -1
  14. package/bricoman/components/phone-number/phone-number.component.d.ts +2 -1
  15. package/bricoman/components/tooltip/directive/tooltip.directive.d.ts +8 -4
  16. package/bricoman/components/tooltip/service/tooltip.service.d.ts +14 -0
  17. package/bricoman/esm2020/components/autocomplete/autocomplete.component.mjs +3 -3
  18. package/bricoman/esm2020/components/dropdown/dropdown.component.mjs +3 -3
  19. package/bricoman/esm2020/components/phone-number/phone-number.component.mjs +7 -4
  20. package/bricoman/esm2020/components/tooltip/directive/tooltip.directive.mjs +18 -14
  21. package/bricoman/esm2020/components/tooltip/service/tooltip.service.mjs +35 -0
  22. package/bricoman/fesm2015/mozaic-ds-angular.mjs +57 -19
  23. package/bricoman/fesm2015/mozaic-ds-angular.mjs.map +1 -1
  24. package/bricoman/fesm2020/mozaic-ds-angular.mjs +56 -19
  25. package/bricoman/fesm2020/mozaic-ds-angular.mjs.map +1 -1
  26. package/bricoman/package.json +1 -1
  27. package/components/phone-number/phone-number.component.d.ts +2 -1
  28. package/components/tooltip/directive/tooltip.directive.d.ts +8 -4
  29. package/components/tooltip/service/tooltip.service.d.ts +14 -0
  30. package/esm2020/components/autocomplete/autocomplete.component.mjs +3 -3
  31. package/esm2020/components/dropdown/dropdown.component.mjs +3 -3
  32. package/esm2020/components/phone-number/phone-number.component.mjs +7 -4
  33. package/esm2020/components/tooltip/directive/tooltip.directive.mjs +18 -14
  34. package/esm2020/components/tooltip/service/tooltip.service.mjs +35 -0
  35. package/fesm2015/mozaic-ds-angular.mjs +57 -19
  36. package/fesm2015/mozaic-ds-angular.mjs.map +1 -1
  37. package/fesm2020/mozaic-ds-angular.mjs +56 -19
  38. package/fesm2020/mozaic-ds-angular.mjs.map +1 -1
  39. package/package.json +1 -1
@@ -1,22 +1,16 @@
1
- import { Directive, Input, HostListener } from '@angular/core';
1
+ import { Directive, HostListener, Input, } from '@angular/core';
2
+ import { tap } from 'rxjs';
2
3
  import * as i0 from "@angular/core";
4
+ import * as i1 from "../service/tooltip.service";
3
5
  export class TooltipDirective {
4
- constructor(el, renderer) {
6
+ constructor(el, renderer, tooltipService) {
5
7
  this.el = el;
6
8
  this.renderer = renderer;
9
+ this.tooltipService = tooltipService;
7
10
  this.tooltipContent = '';
8
11
  this.tooltipPosition = 'top';
9
12
  this.tooltip = null;
10
13
  this.offset = 16;
11
- this.mutationObserver = new MutationObserver(() => {
12
- if (!document.body.contains(this.el.nativeElement)) {
13
- this.hideTooltip();
14
- }
15
- });
16
- this.mutationObserver.observe(document.body, {
17
- childList: true,
18
- subtree: true,
19
- });
20
14
  }
21
15
  onMouseIn() {
22
16
  if (!this.tooltip)
@@ -26,7 +20,17 @@ export class TooltipDirective {
26
20
  if (this.tooltip)
27
21
  this.hideTooltip();
28
22
  }
23
+ ngOnInit() {
24
+ this.hideTooltipSubscription = this.tooltipService.hideTooltip$
25
+ .pipe(tap(() => this.hideTooltip()))
26
+ .subscribe();
27
+ }
28
+ ngOnDestroy() {
29
+ this.hideTooltip();
30
+ this.hideTooltipSubscription?.unsubscribe();
31
+ }
29
32
  showTooltip() {
33
+ this.tooltipService.setCurrentTooltip(this.el);
30
34
  this.tooltip = this.renderer.createElement('span');
31
35
  this.renderer.appendChild(this.tooltip, this.renderer.createText(this.tooltipContent));
32
36
  this.renderer.appendChild(document.body, this.tooltip);
@@ -74,14 +78,14 @@ export class TooltipDirective {
74
78
  }
75
79
  }
76
80
  }
77
- TooltipDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TooltipDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
81
+ TooltipDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TooltipDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i1.TooltipService }], target: i0.ɵɵFactoryTarget.Directive });
78
82
  TooltipDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.10", type: TooltipDirective, selector: "[mozTooltipDirective]", inputs: { tooltipContent: ["mozTooltipDirective", "tooltipContent"], tooltipPosition: "tooltipPosition" }, host: { listeners: { "mouseover": "onMouseIn()", "mouseleave": "onMouseOut()" } }, ngImport: i0 });
79
83
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TooltipDirective, decorators: [{
80
84
  type: Directive,
81
85
  args: [{
82
86
  selector: '[mozTooltipDirective]',
83
87
  }]
84
- }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { tooltipContent: [{
88
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i1.TooltipService }]; }, propDecorators: { tooltipContent: [{
85
89
  type: Input,
86
90
  args: ['mozTooltipDirective']
87
91
  }], tooltipPosition: [{
@@ -93,4 +97,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
93
97
  type: HostListener,
94
98
  args: ['mouseleave']
95
99
  }] } });
96
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"","sources":["../../../../../../projects/kit/components/tooltip/directive/tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, Input, ElementRef, HostListener, Renderer2 } from '@angular/core';\n\n@Directive({\n  selector: '[mozTooltipDirective]',\n})\nexport class TooltipDirective {\n  @Input('mozTooltipDirective') tooltipContent: string = '';\n  @Input() tooltipPosition: string = 'top';\n  public tooltip: HTMLElement | null = null;\n  public offset: number = 16;\n  private mutationObserver: MutationObserver;\n\n  constructor(private el: ElementRef, private renderer: Renderer2) {\n    this.mutationObserver = new MutationObserver(() => {\n      if (!document.body.contains(this.el.nativeElement)) {\n        this.hideTooltip();\n      }\n    });\n\n    this.mutationObserver.observe(document.body, {\n      childList: true,\n      subtree: true,\n    });\n  }\n\n  @HostListener('mouseover')\n  onMouseIn(): void {\n    if (!this.tooltip) this.showTooltip();\n  }\n\n  @HostListener('mouseleave')\n  onMouseOut(): void {\n    if (this.tooltip) this.hideTooltip();\n  }\n\n  showTooltip(): void {\n    this.tooltip = this.renderer.createElement('span');\n\n    this.renderer.appendChild(this.tooltip, this.renderer.createText(this.tooltipContent));\n\n    this.renderer.appendChild(document.body, this.tooltip);\n\n    this.renderer.addClass(this.tooltip, 'mc-tooltip__content');\n    this.renderer.addClass(this.tooltip, `mc-tooltip__content-${this.tooltipPosition}`);\n\n    this.renderer.setStyle(this.tooltip, '-webkit-transition', `opacity 500ms`);\n    this.renderer.setStyle(this.tooltip, '-moz-transition', `opacity 500ms`);\n    this.renderer.setStyle(this.tooltip, '-o-transition', `opacity 500ms`);\n    this.renderer.setStyle(this.tooltip, 'transition', `opacity 500ms`);\n\n    this.setPosition();\n    this.renderer.addClass(this.tooltip, 'mc-tooltip__content-show');\n  }\n\n  hideTooltip(): void {\n    if (this.renderer && this.tooltip) {\n      this.renderer.removeChild(document.body, this.tooltip);\n      this.tooltip = null;\n    }\n  }\n\n  setPosition(): void {\n    if (this.tooltip) {\n      const hostPos = this.el.nativeElement.getBoundingClientRect();\n      const tooltipPos = this.tooltip.getBoundingClientRect();\n      const scrollPos =\n        window.scrollY || document.documentElement.scrollTop || document.body.scrollTop || 0;\n\n      let top, left;\n\n      if (this.tooltipPosition === 'top') {\n        top = hostPos.top - tooltipPos.height - this.offset;\n        left = hostPos.left + (hostPos.width - tooltipPos.width) / 2;\n      }\n\n      if (this.tooltipPosition === 'bottom') {\n        top = hostPos.bottom + this.offset;\n        left = hostPos.left + (hostPos.width - tooltipPos.width) / 2;\n      }\n\n      if (this.tooltipPosition === 'left') {\n        top = hostPos.top + (hostPos.height - tooltipPos.height) / 2;\n        left = hostPos.left - tooltipPos.width - this.offset;\n      }\n\n      if (this.tooltipPosition === 'right') {\n        top = hostPos.top + (hostPos.height - tooltipPos.height) / 2;\n        left = hostPos.right + this.offset;\n      }\n\n      if (top) {\n        this.renderer.setStyle(this.tooltip, 'top', `${top + scrollPos}px`);\n        this.renderer.setStyle(this.tooltip, 'left', `${left}px`);\n      }\n    }\n  }\n}\n"]}
100
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"","sources":["../../../../../../projects/kit/components/tooltip/directive/tooltip.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EAET,YAAY,EACZ,KAAK,GAIN,MAAM,eAAe,CAAC;AACvB,OAAO,EAAgB,GAAG,EAAE,MAAM,MAAM,CAAC;;;AAMzC,MAAM,OAAO,gBAAgB;IAO3B,YACU,EAAc,EACd,QAAmB,EACV,cAA8B;QAFvC,OAAE,GAAF,EAAE,CAAY;QACd,aAAQ,GAAR,QAAQ,CAAW;QACV,mBAAc,GAAd,cAAc,CAAgB;QATnB,mBAAc,GAAW,EAAE,CAAC;QACjD,oBAAe,GAAW,KAAK,CAAC;QAClC,YAAO,GAAuB,IAAI,CAAC;QACnC,WAAM,GAAW,EAAE,CAAC;IAOxB,CAAC;IAGJ,SAAS;QACP,IAAI,CAAC,IAAI,CAAC,OAAO;YAAE,IAAI,CAAC,WAAW,EAAE,CAAC;IACxC,CAAC;IAGD,UAAU;QACR,IAAI,IAAI,CAAC,OAAO;YAAE,IAAI,CAAC,WAAW,EAAE,CAAC;IACvC,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,uBAAuB,GAAG,IAAI,CAAC,cAAc,CAAC,YAAY;aAC5D,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;aACnC,SAAS,EAAE,CAAC;IACjB,CAAC;IAED,WAAW;QACT,IAAI,CAAC,WAAW,EAAE,CAAC;QACnB,IAAI,CAAC,uBAAuB,EAAE,WAAW,EAAE,CAAC;IAC9C,CAAC;IAED,WAAW;QACT,IAAI,CAAC,cAAc,CAAC,iBAAiB,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAC/C,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;QAEnD,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC;QAEvF,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,QAAQ,CAAC,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;QAEvD,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,qBAAqB,CAAC,CAAC;QAC5D,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,uBAAuB,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC;QAEpF,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,oBAAoB,EAAE,eAAe,CAAC,CAAC;QAC5E,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,iBAAiB,EAAE,eAAe,CAAC,CAAC;QACzE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,eAAe,EAAE,eAAe,CAAC,CAAC;QACvE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,YAAY,EAAE,eAAe,CAAC,CAAC;QAEpE,IAAI,CAAC,WAAW,EAAE,CAAC;QACnB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,0BAA0B,CAAC,CAAC;IACnE,CAAC;IAED,WAAW;QACT,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,OAAO,EAAE;YACjC,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,QAAQ,CAAC,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;YACvD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;SACrB;IACH,CAAC;IAED,WAAW;QACT,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,MAAM,OAAO,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC;YAC9D,MAAM,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,qBAAqB,EAAE,CAAC;YACxD,MAAM,SAAS,GACb,MAAM,CAAC,OAAO,IAAI,QAAQ,CAAC,eAAe,CAAC,SAAS,IAAI,QAAQ,CAAC,IAAI,CAAC,SAAS,IAAI,CAAC,CAAC;YAEvF,IAAI,GAAG,EAAE,IAAI,CAAC;YAEd,IAAI,IAAI,CAAC,eAAe,KAAK,KAAK,EAAE;gBAClC,GAAG,GAAG,OAAO,CAAC,GAAG,GAAG,UAAU,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;gBACpD,IAAI,GAAG,OAAO,CAAC,IAAI,GAAG,CAAC,OAAO,CAAC,KAAK,GAAG,UAAU,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;aAC9D;YAED,IAAI,IAAI,CAAC,eAAe,KAAK,QAAQ,EAAE;gBACrC,GAAG,GAAG,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;gBACnC,IAAI,GAAG,OAAO,CAAC,IAAI,GAAG,CAAC,OAAO,CAAC,KAAK,GAAG,UAAU,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;aAC9D;YAED,IAAI,IAAI,CAAC,eAAe,KAAK,MAAM,EAAE;gBACnC,GAAG,GAAG,OAAO,CAAC,GAAG,GAAG,CAAC,OAAO,CAAC,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;gBAC7D,IAAI,GAAG,OAAO,CAAC,IAAI,GAAG,UAAU,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC;aACtD;YAED,IAAI,IAAI,CAAC,eAAe,KAAK,OAAO,EAAE;gBACpC,GAAG,GAAG,OAAO,CAAC,GAAG,GAAG,CAAC,OAAO,CAAC,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;gBAC7D,IAAI,GAAG,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC;aACpC;YAED,IAAI,GAAG,EAAE;gBACP,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,KAAK,EAAE,GAAG,GAAG,GAAG,SAAS,IAAI,CAAC,CAAC;gBACpE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI,IAAI,CAAC,CAAC;aAC3D;SACF;IACH,CAAC;;8GA/FU,gBAAgB;kGAAhB,gBAAgB;4FAAhB,gBAAgB;kBAH5B,SAAS;mBAAC;oBACT,QAAQ,EAAE,uBAAuB;iBAClC;sJAE+B,cAAc;sBAA3C,KAAK;uBAAC,qBAAqB;gBACnB,eAAe;sBAAvB,KAAK;gBAYN,SAAS;sBADR,YAAY;uBAAC,WAAW;gBAMzB,UAAU;sBADT,YAAY;uBAAC,YAAY","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  HostListener,\n  Input,\n  OnDestroy,\n  OnInit,\n  Renderer2,\n} from '@angular/core';\nimport { Subscription, tap } from 'rxjs';\nimport { TooltipService } from '../service/tooltip.service';\n\n@Directive({\n  selector: '[mozTooltipDirective]',\n})\nexport class TooltipDirective implements OnInit, OnDestroy {\n  @Input('mozTooltipDirective') tooltipContent: string = '';\n  @Input() tooltipPosition: string = 'top';\n  public tooltip: HTMLElement | null = null;\n  public offset: number = 16;\n  private hideTooltipSubscription: Subscription | undefined;\n\n  constructor(\n    private el: ElementRef,\n    private renderer: Renderer2,\n    private readonly tooltipService: TooltipService\n  ) {}\n\n  @HostListener('mouseover')\n  onMouseIn(): void {\n    if (!this.tooltip) this.showTooltip();\n  }\n\n  @HostListener('mouseleave')\n  onMouseOut(): void {\n    if (this.tooltip) this.hideTooltip();\n  }\n\n  ngOnInit(): void {\n    this.hideTooltipSubscription = this.tooltipService.hideTooltip$\n      .pipe(tap(() => this.hideTooltip()))\n      .subscribe();\n  }\n\n  ngOnDestroy(): void {\n    this.hideTooltip();\n    this.hideTooltipSubscription?.unsubscribe();\n  }\n\n  showTooltip(): void {\n    this.tooltipService.setCurrentTooltip(this.el);\n    this.tooltip = this.renderer.createElement('span');\n\n    this.renderer.appendChild(this.tooltip, this.renderer.createText(this.tooltipContent));\n\n    this.renderer.appendChild(document.body, this.tooltip);\n\n    this.renderer.addClass(this.tooltip, 'mc-tooltip__content');\n    this.renderer.addClass(this.tooltip, `mc-tooltip__content-${this.tooltipPosition}`);\n\n    this.renderer.setStyle(this.tooltip, '-webkit-transition', `opacity 500ms`);\n    this.renderer.setStyle(this.tooltip, '-moz-transition', `opacity 500ms`);\n    this.renderer.setStyle(this.tooltip, '-o-transition', `opacity 500ms`);\n    this.renderer.setStyle(this.tooltip, 'transition', `opacity 500ms`);\n\n    this.setPosition();\n    this.renderer.addClass(this.tooltip, 'mc-tooltip__content-show');\n  }\n\n  hideTooltip(): void {\n    if (this.renderer && this.tooltip) {\n      this.renderer.removeChild(document.body, this.tooltip);\n      this.tooltip = null;\n    }\n  }\n\n  setPosition(): void {\n    if (this.tooltip) {\n      const hostPos = this.el.nativeElement.getBoundingClientRect();\n      const tooltipPos = this.tooltip.getBoundingClientRect();\n      const scrollPos =\n        window.scrollY || document.documentElement.scrollTop || document.body.scrollTop || 0;\n\n      let top, left;\n\n      if (this.tooltipPosition === 'top') {\n        top = hostPos.top - tooltipPos.height - this.offset;\n        left = hostPos.left + (hostPos.width - tooltipPos.width) / 2;\n      }\n\n      if (this.tooltipPosition === 'bottom') {\n        top = hostPos.bottom + this.offset;\n        left = hostPos.left + (hostPos.width - tooltipPos.width) / 2;\n      }\n\n      if (this.tooltipPosition === 'left') {\n        top = hostPos.top + (hostPos.height - tooltipPos.height) / 2;\n        left = hostPos.left - tooltipPos.width - this.offset;\n      }\n\n      if (this.tooltipPosition === 'right') {\n        top = hostPos.top + (hostPos.height - tooltipPos.height) / 2;\n        left = hostPos.right + this.offset;\n      }\n\n      if (top) {\n        this.renderer.setStyle(this.tooltip, 'top', `${top + scrollPos}px`);\n        this.renderer.setStyle(this.tooltip, 'left', `${left}px`);\n      }\n    }\n  }\n}\n"]}
@@ -0,0 +1,35 @@
1
+ import { Injectable } from '@angular/core';
2
+ import { Subject } from 'rxjs';
3
+ import * as i0 from "@angular/core";
4
+ export class TooltipService {
5
+ constructor() {
6
+ this.currentTooltip = null;
7
+ this.hideTooltipSubject = new Subject();
8
+ this.mutationObserver = null;
9
+ this.mutationObserver = new MutationObserver(this.mutationObserverCallback.bind(this));
10
+ this.mutationObserver.observe(document.body, {
11
+ childList: true,
12
+ subtree: true,
13
+ });
14
+ }
15
+ get hideTooltip$() {
16
+ return this.hideTooltipSubject.asObservable();
17
+ }
18
+ setCurrentTooltip(tooltip) {
19
+ this.currentTooltip = tooltip;
20
+ }
21
+ mutationObserverCallback() {
22
+ if (this.currentTooltip && !document.body.contains(this.currentTooltip.nativeElement)) {
23
+ this.hideTooltipSubject.next();
24
+ }
25
+ }
26
+ }
27
+ TooltipService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TooltipService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
28
+ TooltipService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TooltipService, providedIn: 'root' });
29
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TooltipService, decorators: [{
30
+ type: Injectable,
31
+ args: [{
32
+ providedIn: 'root',
33
+ }]
34
+ }], ctorParameters: function () { return []; } });
35
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2l0L2NvbXBvbmVudHMvdG9vbHRpcC9zZXJ2aWNlL3Rvb2x0aXAuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQWMsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3ZELE9BQU8sRUFBYyxPQUFPLEVBQUUsTUFBTSxNQUFNLENBQUM7O0FBSzNDLE1BQU0sT0FBTyxjQUFjO0lBS3pCO1FBSlEsbUJBQWMsR0FBc0IsSUFBSSxDQUFDO1FBQ3pDLHVCQUFrQixHQUFHLElBQUksT0FBTyxFQUFRLENBQUM7UUFDekMscUJBQWdCLEdBQTRCLElBQUksQ0FBQztRQUd2RCxJQUFJLENBQUMsZ0JBQWdCLEdBQUcsSUFBSSxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsd0JBQXdCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7UUFFdkYsSUFBSSxDQUFDLGdCQUFnQixDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFO1lBQzNDLFNBQVMsRUFBRSxJQUFJO1lBQ2YsT0FBTyxFQUFFLElBQUk7U0FDZCxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsSUFBVyxZQUFZO1FBQ3JCLE9BQU8sSUFBSSxDQUFDLGtCQUFrQixDQUFDLFlBQVksRUFBRSxDQUFDO0lBQ2hELENBQUM7SUFFTSxpQkFBaUIsQ0FBQyxPQUFtQjtRQUMxQyxJQUFJLENBQUMsY0FBYyxHQUFHLE9BQU8sQ0FBQztJQUNoQyxDQUFDO0lBRU8sd0JBQXdCO1FBQzlCLElBQUksSUFBSSxDQUFDLGNBQWMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsYUFBYSxDQUFDLEVBQUU7WUFDckYsSUFBSSxDQUFDLGtCQUFrQixDQUFDLElBQUksRUFBRSxDQUFDO1NBQ2hDO0lBQ0gsQ0FBQzs7NEdBMUJVLGNBQWM7Z0hBQWQsY0FBYyxjQUZiLE1BQU07NEZBRVAsY0FBYztrQkFIMUIsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFbGVtZW50UmVmLCBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBPYnNlcnZhYmxlLCBTdWJqZWN0IH0gZnJvbSAncnhqcyc7XG5cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxufSlcbmV4cG9ydCBjbGFzcyBUb29sdGlwU2VydmljZSB7XG4gIHByaXZhdGUgY3VycmVudFRvb2x0aXA6IEVsZW1lbnRSZWYgfCBudWxsID0gbnVsbDtcbiAgcHJpdmF0ZSBoaWRlVG9vbHRpcFN1YmplY3QgPSBuZXcgU3ViamVjdDx2b2lkPigpO1xuICBwcml2YXRlIG11dGF0aW9uT2JzZXJ2ZXI6IE11dGF0aW9uT2JzZXJ2ZXIgfCBudWxsID0gbnVsbDtcblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgICB0aGlzLm11dGF0aW9uT2JzZXJ2ZXIgPSBuZXcgTXV0YXRpb25PYnNlcnZlcih0aGlzLm11dGF0aW9uT2JzZXJ2ZXJDYWxsYmFjay5iaW5kKHRoaXMpKTtcblxuICAgIHRoaXMubXV0YXRpb25PYnNlcnZlci5vYnNlcnZlKGRvY3VtZW50LmJvZHksIHtcbiAgICAgIGNoaWxkTGlzdDogdHJ1ZSxcbiAgICAgIHN1YnRyZWU6IHRydWUsXG4gICAgfSk7XG4gIH1cblxuICBwdWJsaWMgZ2V0IGhpZGVUb29sdGlwJCgpOiBPYnNlcnZhYmxlPHZvaWQ+IHtcbiAgICByZXR1cm4gdGhpcy5oaWRlVG9vbHRpcFN1YmplY3QuYXNPYnNlcnZhYmxlKCk7XG4gIH1cblxuICBwdWJsaWMgc2V0Q3VycmVudFRvb2x0aXAodG9vbHRpcDogRWxlbWVudFJlZik6IHZvaWQge1xuICAgIHRoaXMuY3VycmVudFRvb2x0aXAgPSB0b29sdGlwO1xuICB9XG5cbiAgcHJpdmF0ZSBtdXRhdGlvbk9ic2VydmVyQ2FsbGJhY2soKTogdm9pZCB7XG4gICAgaWYgKHRoaXMuY3VycmVudFRvb2x0aXAgJiYgIWRvY3VtZW50LmJvZHkuY29udGFpbnModGhpcy5jdXJyZW50VG9vbHRpcC5uYXRpdmVFbGVtZW50KSkge1xuICAgICAgdGhpcy5oaWRlVG9vbHRpcFN1YmplY3QubmV4dCgpO1xuICAgIH1cbiAgfVxufVxuIl19