@energycap/components 0.32.24 → 0.32.25

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.
@@ -4,9 +4,10 @@ import { delay, switchMap, takeUntil } from 'rxjs/operators';
4
4
  import * as i0 from "@angular/core";
5
5
  import * as i1 from "./../tooltip/tooltip.service";
6
6
  export class TooltipDirective {
7
- constructor(tooltipService, element) {
7
+ constructor(tooltipService, element, renderer2) {
8
8
  this.tooltipService = tooltipService;
9
9
  this.element = element;
10
+ this.renderer2 = renderer2;
10
11
  //TooltipConfig: receives all the tooltip options to overwrite the
11
12
  //default configuration of the tooltip
12
13
  this.tooltipConfig = undefined;
@@ -26,6 +27,10 @@ export class TooltipDirective {
26
27
  //Object with the tooltip options builded with the Input parameters
27
28
  //and use it in tooltipService - show()
28
29
  this.tooltipOptions = {};
30
+ /**Set when we show a tooltip, to allow us to unsubscribe to mouse move when hide fires.
31
+ * if we never showed the tooltip this will remain null and we won't have an event to unsubscribe to
32
+ */
33
+ this.mouseMoveUnsubscribe = null;
29
34
  }
30
35
  ngOnInit() {
31
36
  //checkInputsValue(): if there is an error it will prevent to execute
@@ -46,7 +51,9 @@ export class TooltipDirective {
46
51
  console.error('There are too many parameters or none parameter to config the tooltip options');
47
52
  }
48
53
  }
49
- //Detects where the mouse is to trigger the leave/hide process
54
+ /**Detects where the mouse is to trigger the leave/hide process
55
+ * This is a backstop protection against us missing the mouseleave event and leaving a hanging chad.
56
+ * On some browsers, and on some actions (especially scroll) the mouseLeave seems to never fire */
50
57
  onMouseMove(event) {
51
58
  let callCallback = false;
52
59
  if (this.contentRect) {
@@ -114,6 +121,7 @@ export class TooltipDirective {
114
121
  //tooltipPosition is never undefined, default value = "top-center"
115
122
  if (!this.tooltip) {
116
123
  this.tooltip = this.tooltipService.show(element, this.tooltipPosition, this.tooltipOptions);
124
+ this.mouseMoveUnsubscribe = this.renderer2.listen(document, 'mousemove', this.onMouseMove.bind(this));
117
125
  }
118
126
  }
119
127
  hide() {
@@ -124,6 +132,9 @@ export class TooltipDirective {
124
132
  //Call the hide() from the tooltip component
125
133
  this.tooltip.hide();
126
134
  this.tooltip = undefined;
135
+ if (this.mouseMoveUnsubscribe) {
136
+ this.mouseMoveUnsubscribe();
137
+ }
127
138
  }
128
139
  //Interrupt the flow of mouseover with a delay and triggers the
129
140
  //flow to hide the tooltip with a delay
@@ -137,14 +148,14 @@ export class TooltipDirective {
137
148
  this.interrupt.next();
138
149
  }
139
150
  }
140
- TooltipDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: TooltipDirective, deps: [{ token: i1.TooltipService }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
141
- TooltipDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.0", type: TooltipDirective, selector: "[ecTooltip]", inputs: { tooltipConfig: "tooltipConfig", tooltipText: "tooltipText", tooltipCustomContent: "tooltipCustomContent", tooltipPosition: "tooltipPosition" }, host: { listeners: { "document:mousemove": "onMouseMove($event)", "mouseover": "onMouseOver()", "mouseleave": "onLeave()" } }, ngImport: i0 });
151
+ TooltipDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: TooltipDirective, deps: [{ token: i1.TooltipService }, { token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
152
+ TooltipDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.0", type: TooltipDirective, selector: "[ecTooltip]", inputs: { tooltipConfig: "tooltipConfig", tooltipText: "tooltipText", tooltipCustomContent: "tooltipCustomContent", tooltipPosition: "tooltipPosition" }, host: { listeners: { "mouseover": "onMouseOver()", "mouseleave": "onLeave()" } }, ngImport: i0 });
142
153
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: TooltipDirective, decorators: [{
143
154
  type: Directive,
144
155
  args: [{
145
156
  selector: '[ecTooltip]'
146
157
  }]
147
- }], ctorParameters: function () { return [{ type: i1.TooltipService }, { type: i0.ElementRef }]; }, propDecorators: { tooltipConfig: [{
158
+ }], ctorParameters: function () { return [{ type: i1.TooltipService }, { type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { tooltipConfig: [{
148
159
  type: Input
149
160
  }], tooltipText: [{
150
161
  type: Input
@@ -152,9 +163,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
152
163
  type: Input
153
164
  }], tooltipPosition: [{
154
165
  type: Input
155
- }], onMouseMove: [{
156
- type: HostListener,
157
- args: ['document:mousemove', ['$event']]
158
166
  }], onMouseOver: [{
159
167
  type: HostListener,
160
168
  args: ['mouseover']
@@ -162,4 +170,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
162
170
  type: HostListener,
163
171
  args: ['mouseleave']
164
172
  }] } });
165
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"","sources":["../../../../../../projects/components/src/lib/display/tooltip-directive/tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, HostListener, Input, OnInit, TemplateRef} from '@angular/core';\r\nimport { TooltipComponent, TooltipOptions, TooltipPosition } from './../tooltip/tooltip.component';\r\nimport { TooltipService } from './../tooltip/tooltip.service';\r\nimport { Subject,of } from 'rxjs';\r\nimport { delay, switchMap, takeUntil } from 'rxjs/operators';\r\n\r\n@Directive({\r\n  selector: '[ecTooltip]'\r\n})\r\n\r\nexport class TooltipDirective implements OnInit {\r\n\r\n  //TooltipConfig: receives all the tooltip options to overwrite the\r\n  //default configuration of the tooltip\r\n  @Input() public tooltipConfig?: TooltipOptions = undefined\r\n\r\n  //TooltipText: receives plain text to display in the default tooltip\r\n  @Input() public tooltipText?: string = undefined; \r\n\r\n  //TooltipCustomContent: receives a template reference to display\r\n  //into the tooltip content\r\n  @Input() public tooltipCustomContent?: TemplateRef<any> = undefined;\r\n  \r\n  \r\n  //This Input will remain as Input because tooltipPosition is not part\r\n  //of TooltipOptions type of object\r\n  @Input() public tooltipPosition: TooltipPosition = \"top-center\";\r\n\r\n\r\n\r\n  //************************************************************//\r\n\r\n  //Events related\r\n  private mouseOver = new Subject<number>();\r\n  private interrupt = new Subject();\r\n  private hideCompleted = new Subject();\r\n  private contentRect: DOMRect | undefined;\r\n\r\n  //************************************************************//\r\n\r\n  //Reference to TooltipComponent, will be defined below in this.show()\r\n  private tooltip?: TooltipComponent;\r\n\r\n  //Object with the tooltip options builded with the Input parameters\r\n  //and use it in tooltipService - show()\r\n  private tooltipOptions?:TooltipOptions = {}\r\n  \r\n\r\n\r\n  constructor(\r\n    private tooltipService: TooltipService,\r\n    private element: ElementRef, \r\n  ) {}\r\n\r\n  ngOnInit() {\r\n    //checkInputsValue(): if there is an error it will prevent to execute\r\n    //any code related with the tooltip setup\r\n    if(this.checkInputsValue()) {\r\n      //Create the object with the tooltip options provided as @Inputs\r\n      this.createTooltipOptions();\r\n\r\n      //MouseOver flow: start the process of showing the tooltip\r\n      //until the mouse leaves the anchor element with this.interrupt\r\n      this.mouseOver\r\n      .pipe(\r\n        switchMap(v =>\r\n          of(v).pipe(\r\n            delay(300), //delays the time previous of showing the tooltip\r\n            takeUntil(this.interrupt)\r\n          )\r\n        )\r\n      )\r\n      .subscribe(() => this.show()); //Calls the function responsable of using the tooltipService\r\n  \r\n      //Mouse leave flow: start the process of removing the tooltip when the mouse is away of the anchor element\r\n      this.interrupt.pipe(\r\n        switchMap(v => \r\n          of(v).pipe(\r\n            delay(50),\r\n            takeUntil(this.hideCompleted)\r\n          ))\r\n      ).subscribe(() => this.hide()); //hide the tooltip and triggers the completed cycle flag this.hideCompleted\r\n    } else {\r\n      console.error('There are too many parameters or none parameter to config the tooltip options');\r\n    }\r\n  }\r\n\r\n  //Detects where the mouse is to trigger the leave/hide process\r\n  @HostListener('document:mousemove', ['$event']) \r\n  public onMouseMove(event:MouseEvent) {\r\n    let callCallback = false;\r\n    if(this.contentRect) {\r\n      callCallback = this.tooltipService.onMove(event, this.contentRect!);\r\n      if(callCallback) {\r\n        //trigger on hide process\r\n        this.interrupt.next(); \r\n        //reset the contentRec for a new tooltip\r\n        this.contentRect = undefined\r\n      }\r\n    }\r\n  }\r\n\r\n  //Trigger the process to show the tooltip\r\n  @HostListener('mouseover')\r\n  public onMouseOver() {\r\n    this.mouseOver.next();\r\n  }\r\n  \r\n  //Trigger the process to hide and later the process\r\n  //to mark as complete the cycle of show and hide the tooltip\r\n  @HostListener('mouseleave')\r\n  public onLeave() {\r\n    this.interrupt.next();\r\n  }\r\n\r\n  private checkInputsValue():boolean {\r\n    let parametersWithValue = 0;\r\n    if(this.tooltipText) {\r\n      parametersWithValue = parametersWithValue + 1\r\n    } \r\n    if(this.tooltipCustomContent) {\r\n      parametersWithValue = parametersWithValue + 1\r\n    }\r\n    if(this.tooltipConfig) {\r\n      parametersWithValue = parametersWithValue + 1\r\n    }\r\n    if(parametersWithValue === 1) {\r\n      return true;\r\n    } else {\r\n      return false;\r\n    }\r\n  }\r\n  /**\r\n   * createTooltipOptions\r\n   * will only be executed after manageError() verifies \r\n   * if the parameters are not overlapping each other\r\n   * and it will build the tooltipOptions object\r\n   */\r\n  private createTooltipOptions(): void {\r\n    this.tooltipOptions = {\r\n      id: `tooltip_${this.tooltipConfig?.id? this.tooltipConfig?.id: ''}`,\r\n      text: this.tooltipConfig?.text || this.tooltipText,\r\n      title: this.tooltipConfig?.title,\r\n      subtitle: this.tooltipConfig?.subtitle,\r\n      customContent: this.tooltipConfig?.customContent || this.tooltipCustomContent,\r\n      dismissible: this.tooltipConfig?.dismissible || false,\r\n      maxWidth: this.tooltipConfig?.maxWidth,\r\n      width: this.tooltipConfig?.width,\r\n      backgroundColor: this.tooltipConfig?.backgroundColor,\r\n    };\r\n  }\r\n\r\n\r\n  private show():void {\r\n    //Reference to the element where to tooltip is attached\r\n    const element = this.element.nativeElement;\r\n    //contentRect will be assing only after showing a tooltip/popover and it will be\r\n    //reset after hide the same tooltip/popover\r\n    this.contentRect = this.element.nativeElement.getBoundingClientRect();\r\n    //tooltipPosition is never undefined, default value = \"top-center\"\r\n    if(!this.tooltip) {\r\n      this.tooltip = this.tooltipService.show(element as HTMLElement, this.tooltipPosition, this.tooltipOptions)\r\n    }\r\n  }\r\n\r\n  private hide():void {\r\n    //There is a timing issue between the show - hide with \r\n    //liner tooltip elements, so the below line\r\n    //makes sure the app doesn't break\r\n    if(this.tooltip) {\r\n      //Call the hide() from the tooltip component\r\n      this.tooltip.hide();\r\n      this.tooltip = undefined;\r\n    }\r\n      //Interrupt the flow of mouseover with a delay and triggers the \r\n      //flow to hide the tooltip with a delay \r\n      this.interrupt.next();\r\n      //Work as a flag to indicate the flow of show and hide has been completed\r\n      this.hideCompleted.next();\r\n  }\r\n\r\n  //When the element where the tooltip is attached disappears\r\n  //the tooltip should be destroy as well  \r\n  ngOnDestroy(): void {\r\n   this.interrupt.next();\r\n  }\r\n\r\n}\r\n"]}
173
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"","sources":["../../../../../../projects/components/src/lib/display/tooltip-directive/tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, HostListener, Input, OnInit, Renderer2, TemplateRef} from '@angular/core';\r\nimport { TooltipComponent, TooltipOptions, TooltipPosition } from './../tooltip/tooltip.component';\r\nimport { TooltipService } from './../tooltip/tooltip.service';\r\nimport { Subject,of } from 'rxjs';\r\nimport { delay, switchMap, takeUntil } from 'rxjs/operators';\r\n\r\n@Directive({\r\n  selector: '[ecTooltip]'\r\n})\r\n\r\nexport class TooltipDirective implements OnInit {\r\n\r\n  //TooltipConfig: receives all the tooltip options to overwrite the\r\n  //default configuration of the tooltip\r\n  @Input() public tooltipConfig?: TooltipOptions = undefined\r\n\r\n  //TooltipText: receives plain text to display in the default tooltip\r\n  @Input() public tooltipText?: string = undefined; \r\n\r\n  //TooltipCustomContent: receives a template reference to display\r\n  //into the tooltip content\r\n  @Input() public tooltipCustomContent?: TemplateRef<any> = undefined;\r\n  \r\n  \r\n  //This Input will remain as Input because tooltipPosition is not part\r\n  //of TooltipOptions type of object\r\n  @Input() public tooltipPosition: TooltipPosition = \"top-center\";\r\n\r\n\r\n\r\n  //************************************************************//\r\n\r\n  //Events related\r\n  private mouseOver = new Subject<number>();\r\n  private interrupt = new Subject();\r\n  private hideCompleted = new Subject();\r\n  private contentRect: DOMRect | undefined;\r\n\r\n  //************************************************************//\r\n\r\n  //Reference to TooltipComponent, will be defined below in this.show()\r\n  private tooltip?: TooltipComponent;\r\n\r\n  //Object with the tooltip options builded with the Input parameters\r\n  //and use it in tooltipService - show()\r\n  private tooltipOptions?:TooltipOptions = {}\r\n  \r\n\r\n  /**Set when we show a tooltip, to allow us to unsubscribe to mouse move when hide fires.\r\n   * if we never showed the tooltip this will remain null and we won't have an event to unsubscribe to\r\n   */\r\n  private mouseMoveUnsubscribe: (()=> void) | null = null;\r\n\r\n  constructor(\r\n    private tooltipService: TooltipService,\r\n    private element: ElementRef, \r\n    private renderer2: Renderer2\r\n  ) {}\r\n\r\n  ngOnInit() {\r\n    //checkInputsValue(): if there is an error it will prevent to execute\r\n    //any code related with the tooltip setup\r\n    if(this.checkInputsValue()) {\r\n      //Create the object with the tooltip options provided as @Inputs\r\n      this.createTooltipOptions();\r\n\r\n      //MouseOver flow: start the process of showing the tooltip\r\n      //until the mouse leaves the anchor element with this.interrupt\r\n      this.mouseOver\r\n      .pipe(\r\n        switchMap(v =>\r\n          of(v).pipe(\r\n            delay(300), //delays the time previous of showing the tooltip\r\n            takeUntil(this.interrupt)\r\n          )\r\n        )\r\n      )\r\n      .subscribe(() => this.show()); //Calls the function responsable of using the tooltipService\r\n  \r\n      //Mouse leave flow: start the process of removing the tooltip when the mouse is away of the anchor element\r\n      this.interrupt.pipe(\r\n        switchMap(v => \r\n          of(v).pipe(\r\n            delay(50),\r\n            takeUntil(this.hideCompleted)\r\n          ))\r\n      ).subscribe(() => this.hide()); //hide the tooltip and triggers the completed cycle flag this.hideCompleted\r\n    } else {\r\n      console.error('There are too many parameters or none parameter to config the tooltip options');\r\n    }\r\n  }\r\n\r\n  /**Detects where the mouse is to trigger the leave/hide process\r\n   * This is a backstop protection against us missing the mouseleave event and leaving a hanging chad.\r\n   * On some browsers, and on some actions (especially scroll) the mouseLeave seems to never fire */\r\n  public onMouseMove(event:MouseEvent) {\r\n    let callCallback = false;\r\n    if(this.contentRect) {\r\n      callCallback = this.tooltipService.onMove(event, this.contentRect!);\r\n      if(callCallback) {\r\n        //trigger on hide process\r\n        this.interrupt.next(); \r\n        //reset the contentRec for a new tooltip\r\n        this.contentRect = undefined;\r\n      }\r\n    }\r\n  }\r\n\r\n  //Trigger the process to show the tooltip\r\n  @HostListener('mouseover')\r\n  public onMouseOver() {\r\n    this.mouseOver.next();\r\n  }\r\n  \r\n  //Trigger the process to hide and later the process\r\n  //to mark as complete the cycle of show and hide the tooltip\r\n  @HostListener('mouseleave')\r\n  public onLeave() {\r\n    this.interrupt.next();\r\n  }\r\n\r\n  private checkInputsValue():boolean {\r\n    let parametersWithValue = 0;\r\n    if(this.tooltipText) {\r\n      parametersWithValue = parametersWithValue + 1\r\n    } \r\n    if(this.tooltipCustomContent) {\r\n      parametersWithValue = parametersWithValue + 1\r\n    }\r\n    if(this.tooltipConfig) {\r\n      parametersWithValue = parametersWithValue + 1\r\n    }\r\n    if(parametersWithValue === 1) {\r\n      return true;\r\n    } else {\r\n      return false;\r\n    }\r\n  }\r\n  /**\r\n   * createTooltipOptions\r\n   * will only be executed after manageError() verifies \r\n   * if the parameters are not overlapping each other\r\n   * and it will build the tooltipOptions object\r\n   */\r\n  private createTooltipOptions(): void {\r\n    this.tooltipOptions = {\r\n      id: `tooltip_${this.tooltipConfig?.id? this.tooltipConfig?.id: ''}`,\r\n      text: this.tooltipConfig?.text || this.tooltipText,\r\n      title: this.tooltipConfig?.title,\r\n      subtitle: this.tooltipConfig?.subtitle,\r\n      customContent: this.tooltipConfig?.customContent || this.tooltipCustomContent,\r\n      dismissible: this.tooltipConfig?.dismissible || false,\r\n      maxWidth: this.tooltipConfig?.maxWidth,\r\n      width: this.tooltipConfig?.width,\r\n      backgroundColor: this.tooltipConfig?.backgroundColor,\r\n    };\r\n  }\r\n\r\n\r\n  private show():void {\r\n    //Reference to the element where to tooltip is attached\r\n    const element = this.element.nativeElement;\r\n    //contentRect will be assing only after showing a tooltip/popover and it will be\r\n    //reset after hide the same tooltip/popover\r\n    this.contentRect = this.element.nativeElement.getBoundingClientRect();\r\n    //tooltipPosition is never undefined, default value = \"top-center\"\r\n    if(!this.tooltip) {\r\n      this.tooltip = this.tooltipService.show(element as HTMLElement, this.tooltipPosition, this.tooltipOptions);\r\n      this.mouseMoveUnsubscribe = this.renderer2.listen(document, 'mousemove', this.onMouseMove.bind(this));\r\n    }\r\n  }\r\n\r\n  private hide():void {\r\n    //There is a timing issue between the show - hide with \r\n    //liner tooltip elements, so the below line\r\n    //makes sure the app doesn't break\r\n    if(this.tooltip) {\r\n      //Call the hide() from the tooltip component\r\n      this.tooltip.hide();\r\n      this.tooltip = undefined;\r\n      \r\n      if(this.mouseMoveUnsubscribe){\r\n        this.mouseMoveUnsubscribe();\r\n      }\r\n    }\r\n\r\n    //Interrupt the flow of mouseover with a delay and triggers the \r\n    //flow to hide the tooltip with a delay \r\n    this.interrupt.next();\r\n    //Work as a flag to indicate the flow of show and hide has been completed\r\n    this.hideCompleted.next();\r\n  }\r\n\r\n  //When the element where the tooltip is attached disappears\r\n  //the tooltip should be destroy as well  \r\n  ngOnDestroy(): void {\r\n   this.interrupt.next();\r\n  }\r\n\r\n}\r\n"]}
@@ -9625,9 +9625,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
9625
9625
  }] } });
9626
9626
 
9627
9627
  class TooltipDirective {
9628
- constructor(tooltipService, element) {
9628
+ constructor(tooltipService, element, renderer2) {
9629
9629
  this.tooltipService = tooltipService;
9630
9630
  this.element = element;
9631
+ this.renderer2 = renderer2;
9631
9632
  //TooltipConfig: receives all the tooltip options to overwrite the
9632
9633
  //default configuration of the tooltip
9633
9634
  this.tooltipConfig = undefined;
@@ -9647,6 +9648,10 @@ class TooltipDirective {
9647
9648
  //Object with the tooltip options builded with the Input parameters
9648
9649
  //and use it in tooltipService - show()
9649
9650
  this.tooltipOptions = {};
9651
+ /**Set when we show a tooltip, to allow us to unsubscribe to mouse move when hide fires.
9652
+ * if we never showed the tooltip this will remain null and we won't have an event to unsubscribe to
9653
+ */
9654
+ this.mouseMoveUnsubscribe = null;
9650
9655
  }
9651
9656
  ngOnInit() {
9652
9657
  //checkInputsValue(): if there is an error it will prevent to execute
@@ -9667,7 +9672,9 @@ class TooltipDirective {
9667
9672
  console.error('There are too many parameters or none parameter to config the tooltip options');
9668
9673
  }
9669
9674
  }
9670
- //Detects where the mouse is to trigger the leave/hide process
9675
+ /**Detects where the mouse is to trigger the leave/hide process
9676
+ * This is a backstop protection against us missing the mouseleave event and leaving a hanging chad.
9677
+ * On some browsers, and on some actions (especially scroll) the mouseLeave seems to never fire */
9671
9678
  onMouseMove(event) {
9672
9679
  let callCallback = false;
9673
9680
  if (this.contentRect) {
@@ -9736,6 +9743,7 @@ class TooltipDirective {
9736
9743
  //tooltipPosition is never undefined, default value = "top-center"
9737
9744
  if (!this.tooltip) {
9738
9745
  this.tooltip = this.tooltipService.show(element, this.tooltipPosition, this.tooltipOptions);
9746
+ this.mouseMoveUnsubscribe = this.renderer2.listen(document, 'mousemove', this.onMouseMove.bind(this));
9739
9747
  }
9740
9748
  }
9741
9749
  hide() {
@@ -9746,6 +9754,9 @@ class TooltipDirective {
9746
9754
  //Call the hide() from the tooltip component
9747
9755
  this.tooltip.hide();
9748
9756
  this.tooltip = undefined;
9757
+ if (this.mouseMoveUnsubscribe) {
9758
+ this.mouseMoveUnsubscribe();
9759
+ }
9749
9760
  }
9750
9761
  //Interrupt the flow of mouseover with a delay and triggers the
9751
9762
  //flow to hide the tooltip with a delay
@@ -9759,14 +9770,14 @@ class TooltipDirective {
9759
9770
  this.interrupt.next();
9760
9771
  }
9761
9772
  }
9762
- TooltipDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: TooltipDirective, deps: [{ token: TooltipService }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
9763
- TooltipDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.0", type: TooltipDirective, selector: "[ecTooltip]", inputs: { tooltipConfig: "tooltipConfig", tooltipText: "tooltipText", tooltipCustomContent: "tooltipCustomContent", tooltipPosition: "tooltipPosition" }, host: { listeners: { "document:mousemove": "onMouseMove($event)", "mouseover": "onMouseOver()", "mouseleave": "onLeave()" } }, ngImport: i0 });
9773
+ TooltipDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: TooltipDirective, deps: [{ token: TooltipService }, { token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
9774
+ TooltipDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.0", type: TooltipDirective, selector: "[ecTooltip]", inputs: { tooltipConfig: "tooltipConfig", tooltipText: "tooltipText", tooltipCustomContent: "tooltipCustomContent", tooltipPosition: "tooltipPosition" }, host: { listeners: { "mouseover": "onMouseOver()", "mouseleave": "onLeave()" } }, ngImport: i0 });
9764
9775
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: TooltipDirective, decorators: [{
9765
9776
  type: Directive,
9766
9777
  args: [{
9767
9778
  selector: '[ecTooltip]'
9768
9779
  }]
9769
- }], ctorParameters: function () { return [{ type: TooltipService }, { type: i0.ElementRef }]; }, propDecorators: { tooltipConfig: [{
9780
+ }], ctorParameters: function () { return [{ type: TooltipService }, { type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { tooltipConfig: [{
9770
9781
  type: Input
9771
9782
  }], tooltipText: [{
9772
9783
  type: Input
@@ -9774,9 +9785,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
9774
9785
  type: Input
9775
9786
  }], tooltipPosition: [{
9776
9787
  type: Input
9777
- }], onMouseMove: [{
9778
- type: HostListener,
9779
- args: ['document:mousemove', ['$event']]
9780
9788
  }], onMouseOver: [{
9781
9789
  type: HostListener,
9782
9790
  args: ['mouseover']