master-control 0.3.27 → 0.3.29

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.
@@ -1,15 +1,89 @@
1
- import { Directive, HostListener, Input, } from '@angular/core';
1
+ import { Directive, HostListener, Input, Inject, } from '@angular/core';
2
+ import { DOCUMENT } from '@angular/common';
2
3
  import * as i0 from "@angular/core";
3
4
  export class CustomizedTooltipDirective {
4
5
  el;
5
6
  vcr;
7
+ document;
6
8
  template;
7
9
  tooltipElement = null;
8
10
  showTimeout = null;
9
11
  hideTimeout = null;
10
- constructor(el, vcr) {
12
+ static styleInjected = false;
13
+ constructor(el, vcr, document) {
11
14
  this.el = el;
12
15
  this.vcr = vcr;
16
+ this.document = document;
17
+ this.injectStyles();
18
+ }
19
+ injectStyles() {
20
+ // Only inject styles once per application
21
+ if (CustomizedTooltipDirective.styleInjected) {
22
+ return;
23
+ }
24
+ const style = this.document.createElement('style');
25
+ style.id = 'tooltip-styles';
26
+ style.textContent = `
27
+ .tooltip-container {
28
+ position: relative;
29
+ display: inline-block;
30
+ }
31
+
32
+ .tooltip-text {
33
+ max-width: 328px !important;
34
+ min-height: 100px;
35
+ background-color: white;
36
+ border: 1px solid #ffaa013d !important;
37
+ color: #444444 !important;
38
+ text-align: left;
39
+ border-radius: 12px;
40
+ padding: 12px;
41
+ font-size: 12px;
42
+ position: absolute;
43
+ z-index: 1;
44
+ top: 100%;
45
+ left: 50%;
46
+ transform: translateX(-10%);
47
+ transition: opacity 0.3s;
48
+ box-shadow: 0px 2px 15px 2px #e3e6ec99;
49
+ letter-spacing: 0px;
50
+ line-height: 150%;
51
+ }
52
+ .tooltip-text, p {
53
+ font-weight: 400 !important;
54
+ }
55
+
56
+ .tooltip-container:hover .tooltip-text {
57
+ visibility: visible;
58
+ opacity: 1;
59
+ }
60
+
61
+ .tooltip-text::after {
62
+ content: "";
63
+ position: absolute;
64
+ bottom: 100%;
65
+ left: var(--arrow-left-position, 10%);
66
+ transform: translateX(-50%);
67
+ border-width: 10px;
68
+ border-style: solid;
69
+ border-color: transparent transparent #ffaa013d transparent;
70
+ z-index: 2;
71
+ }
72
+
73
+ .tooltip-text::before {
74
+ content: "";
75
+ position: absolute;
76
+ bottom: calc(100% - 0px);
77
+ left: var(--arrow-left-position, 10%);
78
+ transform: translateX(-50%);
79
+ border-width: 9px;
80
+ border-style: solid;
81
+ border-color: transparent transparent #fff transparent;
82
+ z-index: 3;
83
+ }
84
+ `;
85
+ this.document.head.appendChild(style);
86
+ CustomizedTooltipDirective.styleInjected = true;
13
87
  }
14
88
  showTooltip() {
15
89
  // Clear any existing hide timeout
@@ -25,7 +99,7 @@ export class CustomizedTooltipDirective {
25
99
  this.showTimeout = setTimeout(() => {
26
100
  if (!this.tooltipElement && this.template) {
27
101
  // Create tooltip container
28
- this.tooltipElement = document.createElement('div');
102
+ this.tooltipElement = this.document.createElement('div');
29
103
  this.tooltipElement.className = 'tooltip-text';
30
104
  // Add pointer-events none to prevent mouse interference
31
105
  this.tooltipElement.style.pointerEvents = 'none';
@@ -36,7 +110,7 @@ export class CustomizedTooltipDirective {
36
110
  this.tooltipElement?.appendChild(node);
37
111
  });
38
112
  // Position the tooltip
39
- document.body.appendChild(this.tooltipElement);
113
+ this.document.body.appendChild(this.tooltipElement);
40
114
  const rect = this.el.nativeElement.getBoundingClientRect();
41
115
  this.tooltipElement.style.position = 'absolute';
42
116
  this.tooltipElement.style.top = (rect.bottom + 10) + 'px';
@@ -75,7 +149,7 @@ export class CustomizedTooltipDirective {
75
149
  // Small delay before hiding to prevent flickering
76
150
  this.hideTimeout = setTimeout(() => {
77
151
  if (this.tooltipElement) {
78
- document.body.removeChild(this.tooltipElement);
152
+ this.document.body.removeChild(this.tooltipElement);
79
153
  this.tooltipElement = null;
80
154
  this.vcr.clear();
81
155
  }
@@ -91,11 +165,11 @@ export class CustomizedTooltipDirective {
91
165
  }
92
166
  // Clean up tooltip
93
167
  if (this.tooltipElement) {
94
- document.body.removeChild(this.tooltipElement);
168
+ this.document.body.removeChild(this.tooltipElement);
95
169
  this.tooltipElement = null;
96
170
  }
97
171
  }
98
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CustomizedTooltipDirective, deps: [{ token: i0.ElementRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive });
172
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CustomizedTooltipDirective, deps: [{ token: i0.ElementRef }, { token: i0.ViewContainerRef }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Directive });
99
173
  static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: CustomizedTooltipDirective, isStandalone: true, selector: "[appTooltipTemplate]", inputs: { template: ["appTooltipTemplate", "template"] }, host: { listeners: { "mouseenter": "showTooltip()", "mouseleave": "hideTooltip()" } }, ngImport: i0 });
100
174
  }
101
175
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CustomizedTooltipDirective, decorators: [{
@@ -104,7 +178,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
104
178
  selector: '[appTooltipTemplate]',
105
179
  standalone: true,
106
180
  }]
107
- }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.ViewContainerRef }], propDecorators: { template: [{
181
+ }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.ViewContainerRef }, { type: Document, decorators: [{
182
+ type: Inject,
183
+ args: [DOCUMENT]
184
+ }] }], propDecorators: { template: [{
108
185
  type: Input,
109
186
  args: ['appTooltipTemplate']
110
187
  }], showTooltip: [{
@@ -114,4 +191,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
114
191
  type: HostListener,
115
192
  args: ['mouseleave']
116
193
  }] } });
117
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"customized.tooltip.directive.js","sourceRoot":"","sources":["../../../../../projects/master-control/src/lib/directives/customized.tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Directive,\r\n  ElementRef,\r\n  HostListener,\r\n  Input,\r\n  TemplateRef,\r\n  ViewContainerRef,\r\n} from '@angular/core';\r\n\r\n@Directive({\r\n  selector: '[appTooltipTemplate]',\r\n  standalone: true,\r\n})\r\nexport class CustomizedTooltipDirective {\r\n  @Input('appTooltipTemplate') template!: TemplateRef<any>;\r\n\r\n  private tooltipElement: HTMLElement | null = null;\r\n  private showTimeout: any = null;\r\n  private hideTimeout: any = null;\r\n\r\n  constructor(private el: ElementRef, private vcr: ViewContainerRef) {}\r\n\r\n @HostListener('mouseenter')\r\n  showTooltip() {\r\n    // Clear any existing hide timeout\r\n    if (this.hideTimeout) {\r\n      clearTimeout(this.hideTimeout);\r\n      this.hideTimeout = null;\r\n    }\r\n\r\n    // If tooltip already exists, don't create another\r\n    if (this.tooltipElement) {\r\n      return;\r\n    }\r\n\r\n    // Small delay to prevent flickering\r\n    this.showTimeout = setTimeout(() => {\r\n      if (!this.tooltipElement && this.template) {\r\n        // Create tooltip container\r\n        this.tooltipElement = document.createElement('div');\r\n        this.tooltipElement.className = 'tooltip-text';\r\n\r\n        // Add pointer-events none to prevent mouse interference\r\n        this.tooltipElement.style.pointerEvents = 'none';\r\n\r\n        // Render the template content\r\n        const embeddedView = this.vcr.createEmbeddedView(this.template);\r\n        embeddedView.detectChanges();\r\n        embeddedView.rootNodes.forEach((node:any) => {\r\n          this.tooltipElement?.appendChild(node);\r\n        });\r\n\r\n        // Position the tooltip\r\n        document.body.appendChild(this.tooltipElement);\r\n        const rect = this.el.nativeElement.getBoundingClientRect();\r\n        this.tooltipElement.style.position = 'absolute';\r\n        this.tooltipElement.style.top = (rect.bottom + 10) + 'px';\r\n        this.tooltipElement.style.left = (rect.left - 10) + 'px';\r\n        this.tooltipElement.style.visibility = 'visible';\r\n        this.tooltipElement.style.opacity = '1';\r\n\r\n        // Wait a frame for the tooltip to be fully rendered with its content\r\n        requestAnimationFrame(() => {\r\n          if (this.tooltipElement) {\r\n            // Find the image element inside the span to get its actual dimensions\r\n            const imgElement = this.el.nativeElement.querySelector('img');\r\n            let iconCenterX: number;\r\n\r\n            if (imgElement) {\r\n              const imgRect = imgElement.getBoundingClientRect();\r\n              iconCenterX = imgRect.left + (imgRect.width / 2);\r\n            } else {\r\n              // Fallback to span center if no image found\r\n              iconCenterX = rect.left + (rect.width / 2);\r\n            }\r\n\r\n            // Get the actual tooltip position after it's rendered\r\n            const tooltipRect = this.tooltipElement.getBoundingClientRect();\r\n            const arrowPosition = iconCenterX - tooltipRect.left;\r\n            this.tooltipElement.style.setProperty('--arrow-left-position', `${arrowPosition}px`);\r\n          }\r\n        });\r\n      }\r\n    }, 100);\r\n  }\r\n\r\n  @HostListener('mouseleave')\r\n  hideTooltip() {\r\n    // Clear any existing show timeout\r\n    if (this.showTimeout) {\r\n      clearTimeout(this.showTimeout);\r\n      this.showTimeout = null;\r\n    }\r\n\r\n    // Small delay before hiding to prevent flickering\r\n    this.hideTimeout = setTimeout(() => {\r\n      if (this.tooltipElement) {\r\n        document.body.removeChild(this.tooltipElement);\r\n        this.tooltipElement = null;\r\n        this.vcr.clear();\r\n      }\r\n    }, 50);\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    // Clean up timeouts\r\n    if (this.showTimeout) {\r\n      clearTimeout(this.showTimeout);\r\n    }\r\n    if (this.hideTimeout) {\r\n      clearTimeout(this.hideTimeout);\r\n    }\r\n    // Clean up tooltip\r\n    if (this.tooltipElement) {\r\n      document.body.removeChild(this.tooltipElement);\r\n      this.tooltipElement = null;\r\n    }\r\n  }\r\n}\r\n"]}
194
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"customized.tooltip.directive.js","sourceRoot":"","sources":["../../../../../projects/master-control/src/lib/directives/customized.tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Directive,\r\n  ElementRef,\r\n  HostListener,\r\n  Input,\r\n  TemplateRef,\r\n  ViewContainerRef,\r\n  OnDestroy,\r\n  Inject,\r\n} from '@angular/core';\r\nimport { DOCUMENT } from '@angular/common';\r\n\r\n@Directive({\r\n  selector: '[appTooltipTemplate]',\r\n  standalone: true,\r\n})\r\nexport class CustomizedTooltipDirective implements OnDestroy {\r\n  @Input('appTooltipTemplate') template!: TemplateRef<any>;\r\n\r\n  private tooltipElement: HTMLElement | null = null;\r\n  private showTimeout: any = null;\r\n  private hideTimeout: any = null;\r\n  private static styleInjected = false;\r\n\r\n  constructor(\r\n    private el: ElementRef,\r\n    private vcr: ViewContainerRef,\r\n    @Inject(DOCUMENT) private document: Document\r\n  ) {\r\n    this.injectStyles();\r\n  }\r\n\r\n  private injectStyles() {\r\n    // Only inject styles once per application\r\n    if (CustomizedTooltipDirective.styleInjected) {\r\n      return;\r\n    }\r\n\r\n    const style = this.document.createElement('style');\r\n    style.id = 'tooltip-styles';\r\n    style.textContent = `\r\n     .tooltip-container {\r\n  position: relative;\r\n  display: inline-block;\r\n}\r\n\r\n.tooltip-text {\r\n  max-width: 328px !important;\r\n  min-height: 100px;\r\n  background-color: white;\r\n  border: 1px solid #ffaa013d !important;\r\n  color: #444444 !important;\r\n  text-align: left;\r\n  border-radius: 12px;\r\n  padding: 12px;\r\n  font-size: 12px;\r\n  position: absolute;\r\n  z-index: 1;\r\n  top: 100%;\r\n  left: 50%;\r\n  transform: translateX(-10%);\r\n  transition: opacity 0.3s;\r\n  box-shadow: 0px 2px 15px 2px #e3e6ec99;\r\n  letter-spacing: 0px;\r\n  line-height: 150%;\r\n}\r\n.tooltip-text, p {\r\n  font-weight: 400 !important;\r\n}\r\n\r\n.tooltip-container:hover .tooltip-text {\r\n  visibility: visible;\r\n  opacity: 1;\r\n}\r\n\r\n.tooltip-text::after {\r\n  content: \"\";\r\n  position: absolute;\r\n  bottom: 100%;\r\n  left: var(--arrow-left-position, 10%);\r\n  transform: translateX(-50%);\r\n  border-width: 10px;\r\n  border-style: solid;\r\n  border-color: transparent transparent #ffaa013d transparent;\r\n  z-index: 2;\r\n}\r\n\r\n.tooltip-text::before {\r\n  content: \"\";\r\n  position: absolute;\r\n  bottom: calc(100% - 0px);\r\n  left: var(--arrow-left-position, 10%);\r\n  transform: translateX(-50%);\r\n  border-width: 9px;\r\n  border-style: solid;\r\n  border-color: transparent transparent #fff transparent;\r\n  z-index: 3;\r\n}\r\n    `;\r\n\r\n    this.document.head.appendChild(style);\r\n    CustomizedTooltipDirective.styleInjected = true;\r\n  }\r\n\r\n  @HostListener('mouseenter')\r\n  showTooltip() {\r\n    // Clear any existing hide timeout\r\n    if (this.hideTimeout) {\r\n      clearTimeout(this.hideTimeout);\r\n      this.hideTimeout = null;\r\n    }\r\n\r\n    // If tooltip already exists, don't create another\r\n    if (this.tooltipElement) {\r\n      return;\r\n    }\r\n\r\n    // Small delay to prevent flickering\r\n    this.showTimeout = setTimeout(() => {\r\n      if (!this.tooltipElement && this.template) {\r\n        // Create tooltip container\r\n        this.tooltipElement = this.document.createElement('div');\r\n        this.tooltipElement.className = 'tooltip-text';\r\n\r\n        // Add pointer-events none to prevent mouse interference\r\n        this.tooltipElement.style.pointerEvents = 'none';\r\n\r\n        // Render the template content\r\n        const embeddedView = this.vcr.createEmbeddedView(this.template);\r\n        embeddedView.detectChanges();\r\n        embeddedView.rootNodes.forEach((node: any) => {\r\n          this.tooltipElement?.appendChild(node);\r\n        });\r\n\r\n        // Position the tooltip\r\n        this.document.body.appendChild(this.tooltipElement);\r\n        const rect = this.el.nativeElement.getBoundingClientRect();\r\n        this.tooltipElement.style.position = 'absolute';\r\n        this.tooltipElement.style.top = (rect.bottom + 10) + 'px';\r\n        this.tooltipElement.style.left = (rect.left - 10) + 'px';\r\n        this.tooltipElement.style.visibility = 'visible';\r\n        this.tooltipElement.style.opacity = '1';\r\n\r\n        // Wait a frame for the tooltip to be fully rendered with its content\r\n        requestAnimationFrame(() => {\r\n          if (this.tooltipElement) {\r\n            // Find the image element inside the span to get its actual dimensions\r\n            const imgElement = this.el.nativeElement.querySelector('img');\r\n            let iconCenterX: number;\r\n\r\n            if (imgElement) {\r\n              const imgRect = imgElement.getBoundingClientRect();\r\n              iconCenterX = imgRect.left + (imgRect.width / 2);\r\n            } else {\r\n              // Fallback to span center if no image found\r\n              iconCenterX = rect.left + (rect.width / 2);\r\n            }\r\n\r\n            // Get the actual tooltip position after it's rendered\r\n            const tooltipRect = this.tooltipElement.getBoundingClientRect();\r\n            const arrowPosition = iconCenterX - tooltipRect.left;\r\n            this.tooltipElement.style.setProperty('--arrow-left-position', `${arrowPosition}px`);\r\n          }\r\n        });\r\n      }\r\n    }, 100);\r\n  }\r\n\r\n  @HostListener('mouseleave')\r\n  hideTooltip() {\r\n    // Clear any existing show timeout\r\n    if (this.showTimeout) {\r\n      clearTimeout(this.showTimeout);\r\n      this.showTimeout = null;\r\n    }\r\n\r\n    // Small delay before hiding to prevent flickering\r\n    this.hideTimeout = setTimeout(() => {\r\n      if (this.tooltipElement) {\r\n        this.document.body.removeChild(this.tooltipElement);\r\n        this.tooltipElement = null;\r\n        this.vcr.clear();\r\n      }\r\n    }, 50);\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    // Clean up timeouts\r\n    if (this.showTimeout) {\r\n      clearTimeout(this.showTimeout);\r\n    }\r\n    if (this.hideTimeout) {\r\n      clearTimeout(this.hideTimeout);\r\n    }\r\n    // Clean up tooltip\r\n    if (this.tooltipElement) {\r\n      this.document.body.removeChild(this.tooltipElement);\r\n      this.tooltipElement = null;\r\n    }\r\n  }\r\n}\r\n"]}
@@ -67,4 +67,5 @@ export * from './lib/info-textbox/info-textbox.component';
67
67
  export * from './lib/textbox-with-underscore/textbox-with-underscore.component';
68
68
  export * from './lib/label-with-image/label-with-image.component';
69
69
  export * from './lib/underscore-mob-number/underscore-mob-number.component';
70
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL21hc3Rlci1jb250cm9sL3NyYy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyw4QkFBOEIsQ0FBQztBQUM3QyxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsZ0NBQWdDLENBQUM7QUFDL0MsY0FBYyxtQ0FBbUMsQ0FBQztBQUNsRCxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyxtQ0FBbUMsQ0FBQztBQUNsRCxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsMkNBQTJDLENBQUM7QUFDMUQsY0FBYyxpREFBaUQsQ0FBQztBQUNoRSxjQUFjLCtDQUErQyxDQUFDO0FBQzlELGNBQWMseUNBQXlDLENBQUM7QUFDeEQsY0FBYywrQ0FBK0MsQ0FBQztBQUM5RCxjQUFjLCtDQUErQyxDQUFDO0FBQzlELGNBQWMsK0NBQStDLENBQUM7QUFDOUQsY0FBYyxtQ0FBbUMsQ0FBQztBQUNsRCxjQUFjLGlEQUFpRCxDQUFDO0FBQ2hFLGNBQWMsdURBQXVELENBQUM7QUFDdEUsY0FBYyxxREFBcUQsQ0FBQztBQUNwRSxjQUFjLDJDQUEyQyxDQUFDO0FBQzFELGNBQWMscURBQXFELENBQUM7QUFDcEUsY0FBYywyQ0FBMkMsQ0FBQztBQUMxRCxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMsaUVBQWlFLENBQUM7QUFDaEYsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMseURBQXlELENBQUM7QUFDeEUsY0FBYyxxREFBcUQsQ0FBQztBQUNwRSxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYyxxREFBcUQsQ0FBQztBQUNwRSxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYywyQ0FBMkMsQ0FBQztBQUMxRCxjQUFjLCtDQUErQyxDQUFDO0FBQzlELGNBQWMsbURBQW1ELENBQUM7QUFDbEUsY0FBYyxtREFBbUQsQ0FBQztBQUNsRSxjQUFjLG1EQUFtRCxDQUFDO0FBQ2xFLGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLDZDQUE2QyxDQUFDO0FBQzVELGNBQWMsMkNBQTJDLENBQUM7QUFDMUQsY0FBYyxtREFBbUQsQ0FBQztBQUNsRSxjQUFjLCtDQUErQyxDQUFDO0FBQzlELGNBQWMscURBQXFELENBQUM7QUFDcEUsY0FBYyxtREFBbUQsQ0FBQztBQUNsRSxjQUFjLG1EQUFtRCxDQUFDO0FBQ2xFLGNBQWMseUNBQXlDLENBQUM7QUFDeEQsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLHVEQUF1RCxDQUFDO0FBQ3RFLGNBQWMsMkNBQTJDLENBQUM7QUFDMUQsY0FBYyxpRUFBaUUsQ0FBQztBQUNoRixjQUFjLG1EQUFtRCxDQUFDO0FBQ2xFLGNBQWMsNkRBQTZELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxyXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2YgbWFzdGVyLWNvbnRyb2xcclxuICovXHJcblxyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9tYXN0ZXItY29udHJvbC5zZXJ2aWNlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvdGV4dGJveC90ZXh0Ym94LmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL21hc3Rlci1jb250cm9sLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NoZWNrYm94L2NoZWNrYm94LmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RvYi9kb2IuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvaW5mby9pbmZvLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vYi1udW1iZXIvbW9iLW51bWJlci5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9yYWRpby9yYWRpby5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9zZWxlY3Qvc2VsZWN0LmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3RleHRhcmVhL3RleHRhcmVhLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3VwbG9hZC91cGxvYWQuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvdG9nZ2xlL3RvZ2dsZS5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9idXR0b24vYnV0dG9uLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3RhYi90YWIuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvYXV0b2NvbXBsZXRlL2F1dG9jb21wbGV0ZS5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9tdWx0aXBsZS1zZWxlY3QvbXVsdGlwbGUtc2VsZWN0LmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NlbGVjdC10ZXh0Ym94L3NlbGVjdC10ZXh0Ym94LmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL290cC10ZXh0Ym94L290cC10ZXh0Ym94LmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Ftb3VudC10ZXh0Ym94L2Ftb3VudC10ZXh0Ym94LmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3N1ZmZpeC10ZXh0Ym94L3N1ZmZpeC10ZXh0Ym94LmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL290cC1tb2ItbnVtYmVyL290cC1tb2ItbnVtYmVyLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2FnZS1kYXRlL2FnZS1kYXRlLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2FkZGl0aW9uLWJ1dHRvbi9hZGRpdGlvbi1idXR0b24uY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvdGV4dGJveC13aXRoLWltYWdlL3RleHRib3gtd2l0aC1pbWFnZS5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9lbWFpbC13aXRoLWRvbWFpbi9lbWFpbC13aXRoLWRvbWFpbi5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9pbWFnZS11cGxvYWQvaW1hZ2UtdXBsb2FkLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Rvd25sb2FkLWRvY3VtZW50L2Rvd25sb2FkLWRvY3VtZW50LmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2FkZC1kb2N1bWVudC9hZGQtZG9jdW1lbnQuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvaHlwZXJsaW5rL2h5cGVybGluay5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi90ZXh0Ym94LXdpdGgtdW5kZXJzY29yZS90ZXh0Ym94LXdpdGgtdW5kZXJzY29yZS5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9pY29uLWJ1dHRvbi9pY29uLWJ1dHRvbi5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9pbWFnZS9pbWFnZS5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9zdGVwcGVyL3N0ZXBwZXIuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY2FyZC9jYXJkLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2hyLWxpbmUvaHItbGluZS5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9zZWFyY2gtbXVsdGktc2VsZWN0L3NlYXJjaC1tdWx0aS1zZWxlY3QuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvc3Vic2NyaXB0LXRleHRib3gvc3Vic2NyaXB0LXRleHRib3guY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbGFiZWwvbGFiZWwuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvdGFibGUvdGFibGUuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvdGV4dGJveC13aXRoLXRleHQvdGV4dGJveC13aXRoLXRleHQuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbG9hZGVyL2xvYWRlci5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kaXNjb3VudC9kaXNjb3VudC5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9iZW5lZml0LWNhcmQvYmVuZWZpdC1jYXJkLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Vycm9yLXNuYWNrYmFyL2Vycm9yLXNuYWNrYmFyLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3dhcm5pbmctc25hY2tiYXIvd2FybmluZy1zbmFja2Jhci5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9zdWNjZXNzLXNuYWNrYmFyL3N1Y2Nlc3Mtc25hY2tiYXIuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbmV1dHJhbC1zbmFja2Jhci9uZXV0cmFsLXNuYWNrYmFyLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2dyZXktbGFiZWwvZ3JleS1sYWJlbC5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9pZnJhbWUvaWZyYW1lLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3RvZ2dsZS1idXR0b24vdG9nZ2xlLWJ1dHRvbi5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9wYXktZ2V0LWNhcmQvcGF5LWdldC1jYXJkLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2luLWJ1aWx0LWJlbmVmaXQvaW4tYnVpbHQtYmVuZWZpdC5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9vdGhlci1iZW5lZml0cy9vdGhlci1iZW5lZml0cy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9hbm51aXR5LXJhdGUtbG9nby9hbm51aXR5LXJhdGUtbG9nby5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9sYWJlbC12YWx1ZS1jYXJkL2xhYmVsLXZhbHVlLWNhcmQuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbWVkaWFsLXF1ZXN0aW9ucy9tZWRpYWwtcXVlc3Rpb25zLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Rpc2NvdW50LXYyL2Rpc2NvdW50LXYyLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3BhZ2UtbnVkZ2UvcGFnZS1udWRnZS5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9oZWFkZXIvaGVhZGVyLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3N1Yi1oZWFkZXIvc3ViLWhlYWRlci5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9tZW51L21lbnUuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvc3RlcHBlci13aXRoLWFycm93L3N0ZXBwZXItd2l0aC1hcnJvdy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9pbmZvLXRleHRib3gvaW5mby10ZXh0Ym94LmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3RleHRib3gtd2l0aC11bmRlcnNjb3JlL3RleHRib3gtd2l0aC11bmRlcnNjb3JlLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xhYmVsLXdpdGgtaW1hZ2UvbGFiZWwtd2l0aC1pbWFnZS5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi91bmRlcnNjb3JlLW1vYi1udW1iZXIvdW5kZXJzY29yZS1tb2ItbnVtYmVyLmNvbXBvbmVudCc7XHJcbiJdfQ==
70
+ export * from './lib/directives/customized.tooltip.directive';
71
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL21hc3Rlci1jb250cm9sL3NyYy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyw4QkFBOEIsQ0FBQztBQUM3QyxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsZ0NBQWdDLENBQUM7QUFDL0MsY0FBYyxtQ0FBbUMsQ0FBQztBQUNsRCxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyxtQ0FBbUMsQ0FBQztBQUNsRCxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsMkNBQTJDLENBQUM7QUFDMUQsY0FBYyxpREFBaUQsQ0FBQztBQUNoRSxjQUFjLCtDQUErQyxDQUFDO0FBQzlELGNBQWMseUNBQXlDLENBQUM7QUFDeEQsY0FBYywrQ0FBK0MsQ0FBQztBQUM5RCxjQUFjLCtDQUErQyxDQUFDO0FBQzlELGNBQWMsK0NBQStDLENBQUM7QUFDOUQsY0FBYyxtQ0FBbUMsQ0FBQztBQUNsRCxjQUFjLGlEQUFpRCxDQUFDO0FBQ2hFLGNBQWMsdURBQXVELENBQUM7QUFDdEUsY0FBYyxxREFBcUQsQ0FBQztBQUNwRSxjQUFjLDJDQUEyQyxDQUFDO0FBQzFELGNBQWMscURBQXFELENBQUM7QUFDcEUsY0FBYywyQ0FBMkMsQ0FBQztBQUMxRCxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMsaUVBQWlFLENBQUM7QUFDaEYsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMseURBQXlELENBQUM7QUFDeEUsY0FBYyxxREFBcUQsQ0FBQztBQUNwRSxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYyxxREFBcUQsQ0FBQztBQUNwRSxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYywyQ0FBMkMsQ0FBQztBQUMxRCxjQUFjLCtDQUErQyxDQUFDO0FBQzlELGNBQWMsbURBQW1ELENBQUM7QUFDbEUsY0FBYyxtREFBbUQsQ0FBQztBQUNsRSxjQUFjLG1EQUFtRCxDQUFDO0FBQ2xFLGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLDZDQUE2QyxDQUFDO0FBQzVELGNBQWMsMkNBQTJDLENBQUM7QUFDMUQsY0FBYyxtREFBbUQsQ0FBQztBQUNsRSxjQUFjLCtDQUErQyxDQUFDO0FBQzlELGNBQWMscURBQXFELENBQUM7QUFDcEUsY0FBYyxtREFBbUQsQ0FBQztBQUNsRSxjQUFjLG1EQUFtRCxDQUFDO0FBQ2xFLGNBQWMseUNBQXlDLENBQUM7QUFDeEQsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLHVEQUF1RCxDQUFDO0FBQ3RFLGNBQWMsMkNBQTJDLENBQUM7QUFDMUQsY0FBYyxpRUFBaUUsQ0FBQztBQUNoRixjQUFjLG1EQUFtRCxDQUFDO0FBQ2xFLGNBQWMsNkRBQTZELENBQUM7QUFDNUUsY0FBYywrQ0FBK0MsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXHJcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBtYXN0ZXItY29udHJvbFxyXG4gKi9cclxuXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL21hc3Rlci1jb250cm9sLnNlcnZpY2UnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi90ZXh0Ym94L3RleHRib3guY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbWFzdGVyLWNvbnRyb2wuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY2hlY2tib3gvY2hlY2tib3guY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvZG9iL2RvYi5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9pbmZvL2luZm8uY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9iLW51bWJlci9tb2ItbnVtYmVyLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3JhZGlvL3JhZGlvLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NlbGVjdC9zZWxlY3QuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvdGV4dGFyZWEvdGV4dGFyZWEuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvdXBsb2FkL3VwbG9hZC5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi90b2dnbGUvdG9nZ2xlLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2J1dHRvbi9idXR0b24uY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvdGFiL3RhYi5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9hdXRvY29tcGxldGUvYXV0b2NvbXBsZXRlLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL211bHRpcGxlLXNlbGVjdC9tdWx0aXBsZS1zZWxlY3QuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VsZWN0LXRleHRib3gvc2VsZWN0LXRleHRib3guY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvb3RwLXRleHRib3gvb3RwLXRleHRib3guY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvYW1vdW50LXRleHRib3gvYW1vdW50LXRleHRib3guY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvc3VmZml4LXRleHRib3gvc3VmZml4LXRleHRib3guY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvb3RwLW1vYi1udW1iZXIvb3RwLW1vYi1udW1iZXIuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvYWdlLWRhdGUvYWdlLWRhdGUuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvYWRkaXRpb24tYnV0dG9uL2FkZGl0aW9uLWJ1dHRvbi5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi90ZXh0Ym94LXdpdGgtaW1hZ2UvdGV4dGJveC13aXRoLWltYWdlLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2VtYWlsLXdpdGgtZG9tYWluL2VtYWlsLXdpdGgtZG9tYWluLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ltYWdlLXVwbG9hZC9pbWFnZS11cGxvYWQuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvZG93bmxvYWQtZG9jdW1lbnQvZG93bmxvYWQtZG9jdW1lbnQuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvYWRkLWRvY3VtZW50L2FkZC1kb2N1bWVudC5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9oeXBlcmxpbmsvaHlwZXJsaW5rLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3RleHRib3gtd2l0aC11bmRlcnNjb3JlL3RleHRib3gtd2l0aC11bmRlcnNjb3JlLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ljb24tYnV0dG9uL2ljb24tYnV0dG9uLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ltYWdlL2ltYWdlLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3N0ZXBwZXIvc3RlcHBlci5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jYXJkL2NhcmQuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvaHItbGluZS9oci1saW5lLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NlYXJjaC1tdWx0aS1zZWxlY3Qvc2VhcmNoLW11bHRpLXNlbGVjdC5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9zdWJzY3JpcHQtdGV4dGJveC9zdWJzY3JpcHQtdGV4dGJveC5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9sYWJlbC9sYWJlbC5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi90YWJsZS90YWJsZS5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi90ZXh0Ym94LXdpdGgtdGV4dC90ZXh0Ym94LXdpdGgtdGV4dC5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9sb2FkZXIvbG9hZGVyLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Rpc2NvdW50L2Rpc2NvdW50LmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2JlbmVmaXQtY2FyZC9iZW5lZml0LWNhcmQuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvZXJyb3Itc25hY2tiYXIvZXJyb3Itc25hY2tiYXIuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvd2FybmluZy1zbmFja2Jhci93YXJuaW5nLXNuYWNrYmFyLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3N1Y2Nlc3Mtc25hY2tiYXIvc3VjY2Vzcy1zbmFja2Jhci5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9uZXV0cmFsLXNuYWNrYmFyL25ldXRyYWwtc25hY2tiYXIuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvZ3JleS1sYWJlbC9ncmV5LWxhYmVsLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2lmcmFtZS9pZnJhbWUuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvdG9nZ2xlLWJ1dHRvbi90b2dnbGUtYnV0dG9uLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3BheS1nZXQtY2FyZC9wYXktZ2V0LWNhcmQuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvaW4tYnVpbHQtYmVuZWZpdC9pbi1idWlsdC1iZW5lZml0LmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL290aGVyLWJlbmVmaXRzL290aGVyLWJlbmVmaXRzLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2FubnVpdHktcmF0ZS1sb2dvL2FubnVpdHktcmF0ZS1sb2dvLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xhYmVsLXZhbHVlLWNhcmQvbGFiZWwtdmFsdWUtY2FyZC5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9tZWRpYWwtcXVlc3Rpb25zL21lZGlhbC1xdWVzdGlvbnMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvZGlzY291bnQtdjIvZGlzY291bnQtdjIuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvcGFnZS1udWRnZS9wYWdlLW51ZGdlLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2hlYWRlci9oZWFkZXIuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvc3ViLWhlYWRlci9zdWItaGVhZGVyLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL21lbnUvbWVudS5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9zdGVwcGVyLXdpdGgtYXJyb3cvc3RlcHBlci13aXRoLWFycm93LmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2luZm8tdGV4dGJveC9pbmZvLXRleHRib3guY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvdGV4dGJveC13aXRoLXVuZGVyc2NvcmUvdGV4dGJveC13aXRoLXVuZGVyc2NvcmUuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbGFiZWwtd2l0aC1pbWFnZS9sYWJlbC13aXRoLWltYWdlLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3VuZGVyc2NvcmUtbW9iLW51bWJlci91bmRlcnNjb3JlLW1vYi1udW1iZXIuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvZGlyZWN0aXZlcy9jdXN0b21pemVkLnRvb2x0aXAuZGlyZWN0aXZlJztcclxuIl19
@@ -1,11 +1,11 @@
1
1
  import * as i0 from '@angular/core';
2
- import { Injectable, input, EventEmitter, Component, Output, ViewChild, Directive, Input, HostListener, output, effect } from '@angular/core';
2
+ import { Injectable, input, EventEmitter, Component, Output, ViewChild, Directive, Inject, Input, HostListener, output, effect } from '@angular/core';
3
3
  import * as i1 from '@angular/material/input';
4
4
  import { MatInputModule } from '@angular/material/input';
5
5
  import * as i2 from '@angular/material/form-field';
6
6
  import { MatFormFieldModule } from '@angular/material/form-field';
7
7
  import * as i1$1 from '@angular/common';
8
- import { CommonModule, NgIf, NgFor } from '@angular/common';
8
+ import { CommonModule, DOCUMENT, NgIf, NgFor } from '@angular/common';
9
9
  import * as i4 from '@angular/forms';
10
10
  import { NG_VALUE_ACCESSOR, ReactiveFormsModule, FormsModule, FormGroup } from '@angular/forms';
11
11
  import * as i5$1 from '@angular/material/autocomplete';
@@ -1716,13 +1716,86 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
1716
1716
  class CustomizedTooltipDirective {
1717
1717
  el;
1718
1718
  vcr;
1719
+ document;
1719
1720
  template;
1720
1721
  tooltipElement = null;
1721
1722
  showTimeout = null;
1722
1723
  hideTimeout = null;
1723
- constructor(el, vcr) {
1724
+ static styleInjected = false;
1725
+ constructor(el, vcr, document) {
1724
1726
  this.el = el;
1725
1727
  this.vcr = vcr;
1728
+ this.document = document;
1729
+ this.injectStyles();
1730
+ }
1731
+ injectStyles() {
1732
+ // Only inject styles once per application
1733
+ if (CustomizedTooltipDirective.styleInjected) {
1734
+ return;
1735
+ }
1736
+ const style = this.document.createElement('style');
1737
+ style.id = 'tooltip-styles';
1738
+ style.textContent = `
1739
+ .tooltip-container {
1740
+ position: relative;
1741
+ display: inline-block;
1742
+ }
1743
+
1744
+ .tooltip-text {
1745
+ max-width: 328px !important;
1746
+ min-height: 100px;
1747
+ background-color: white;
1748
+ border: 1px solid #ffaa013d !important;
1749
+ color: #444444 !important;
1750
+ text-align: left;
1751
+ border-radius: 12px;
1752
+ padding: 12px;
1753
+ font-size: 12px;
1754
+ position: absolute;
1755
+ z-index: 1;
1756
+ top: 100%;
1757
+ left: 50%;
1758
+ transform: translateX(-10%);
1759
+ transition: opacity 0.3s;
1760
+ box-shadow: 0px 2px 15px 2px #e3e6ec99;
1761
+ letter-spacing: 0px;
1762
+ line-height: 150%;
1763
+ }
1764
+ .tooltip-text, p {
1765
+ font-weight: 400 !important;
1766
+ }
1767
+
1768
+ .tooltip-container:hover .tooltip-text {
1769
+ visibility: visible;
1770
+ opacity: 1;
1771
+ }
1772
+
1773
+ .tooltip-text::after {
1774
+ content: "";
1775
+ position: absolute;
1776
+ bottom: 100%;
1777
+ left: var(--arrow-left-position, 10%);
1778
+ transform: translateX(-50%);
1779
+ border-width: 10px;
1780
+ border-style: solid;
1781
+ border-color: transparent transparent #ffaa013d transparent;
1782
+ z-index: 2;
1783
+ }
1784
+
1785
+ .tooltip-text::before {
1786
+ content: "";
1787
+ position: absolute;
1788
+ bottom: calc(100% - 0px);
1789
+ left: var(--arrow-left-position, 10%);
1790
+ transform: translateX(-50%);
1791
+ border-width: 9px;
1792
+ border-style: solid;
1793
+ border-color: transparent transparent #fff transparent;
1794
+ z-index: 3;
1795
+ }
1796
+ `;
1797
+ this.document.head.appendChild(style);
1798
+ CustomizedTooltipDirective.styleInjected = true;
1726
1799
  }
1727
1800
  showTooltip() {
1728
1801
  // Clear any existing hide timeout
@@ -1738,7 +1811,7 @@ class CustomizedTooltipDirective {
1738
1811
  this.showTimeout = setTimeout(() => {
1739
1812
  if (!this.tooltipElement && this.template) {
1740
1813
  // Create tooltip container
1741
- this.tooltipElement = document.createElement('div');
1814
+ this.tooltipElement = this.document.createElement('div');
1742
1815
  this.tooltipElement.className = 'tooltip-text';
1743
1816
  // Add pointer-events none to prevent mouse interference
1744
1817
  this.tooltipElement.style.pointerEvents = 'none';
@@ -1749,7 +1822,7 @@ class CustomizedTooltipDirective {
1749
1822
  this.tooltipElement?.appendChild(node);
1750
1823
  });
1751
1824
  // Position the tooltip
1752
- document.body.appendChild(this.tooltipElement);
1825
+ this.document.body.appendChild(this.tooltipElement);
1753
1826
  const rect = this.el.nativeElement.getBoundingClientRect();
1754
1827
  this.tooltipElement.style.position = 'absolute';
1755
1828
  this.tooltipElement.style.top = (rect.bottom + 10) + 'px';
@@ -1788,7 +1861,7 @@ class CustomizedTooltipDirective {
1788
1861
  // Small delay before hiding to prevent flickering
1789
1862
  this.hideTimeout = setTimeout(() => {
1790
1863
  if (this.tooltipElement) {
1791
- document.body.removeChild(this.tooltipElement);
1864
+ this.document.body.removeChild(this.tooltipElement);
1792
1865
  this.tooltipElement = null;
1793
1866
  this.vcr.clear();
1794
1867
  }
@@ -1804,11 +1877,11 @@ class CustomizedTooltipDirective {
1804
1877
  }
1805
1878
  // Clean up tooltip
1806
1879
  if (this.tooltipElement) {
1807
- document.body.removeChild(this.tooltipElement);
1880
+ this.document.body.removeChild(this.tooltipElement);
1808
1881
  this.tooltipElement = null;
1809
1882
  }
1810
1883
  }
1811
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CustomizedTooltipDirective, deps: [{ token: i0.ElementRef }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive });
1884
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CustomizedTooltipDirective, deps: [{ token: i0.ElementRef }, { token: i0.ViewContainerRef }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Directive });
1812
1885
  static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: CustomizedTooltipDirective, isStandalone: true, selector: "[appTooltipTemplate]", inputs: { template: ["appTooltipTemplate", "template"] }, host: { listeners: { "mouseenter": "showTooltip()", "mouseleave": "hideTooltip()" } }, ngImport: i0 });
1813
1886
  }
1814
1887
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CustomizedTooltipDirective, decorators: [{
@@ -1817,7 +1890,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
1817
1890
  selector: '[appTooltipTemplate]',
1818
1891
  standalone: true,
1819
1892
  }]
1820
- }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.ViewContainerRef }], propDecorators: { template: [{
1893
+ }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.ViewContainerRef }, { type: Document, decorators: [{
1894
+ type: Inject,
1895
+ args: [DOCUMENT]
1896
+ }] }], propDecorators: { template: [{
1821
1897
  type: Input,
1822
1898
  args: ['appTooltipTemplate']
1823
1899
  }], showTooltip: [{
@@ -5674,5 +5750,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
5674
5750
  * Generated bundle index. Do not edit.
5675
5751
  */
5676
5752
 
5677
- export { AddDocumentComponent, AdditionButtonComponent, AgeDateComponent, AmountTextboxComponent, AnnuityRateLogoComponent, AutocompleteComponent, BenefitCardComponent, ButtonComponent, CardComponent, CheckboxComponent, DiscountComponent, DiscountV2Component, DobComponent, DownloadDocumentComponent, EmailWithDomainComponent, ErrorSnackbarComponent, GreyLabelComponent, HeaderComponent, HrLineComponent, HyperlinkComponent, IconButtonComponent, IframeComponent, ImageComponent, ImageUploadComponent, InBuiltBenefitComponent, InfoComponent, InfoTextboxComponent, LabelComponent, LabelValueCardComponent, LabelWithImageComponent, LoaderComponent, MY_DATE_FORMAT, MasterControlComponent, MasterControlService, MedialQuestionsComponent, MenuComponent, MobNumberComponent, MultipleSelectComponent, NeutralSnackbarComponent, OtherBenefitsComponent, OtpMobNumberComponent, OtpTextboxComponent, PageNudgeComponent, PayGetCardComponent, RadioComponent, SearchMultiSelectComponent, SelectComponent, SelectTextboxComponent, StepperComponent, StepperWIthArrowComponent, SubHeaderComponent, SubscriptTextboxComponent, SuccessSnackbarComponent, SuffixTextboxComponent, TabComponent, TableComponent, TextareaComponent, TextboxComponent, TextboxWithImageComponent, TextboxWithTextComponent, TextboxWithUnderscoreComponent, ToggleButtonComponent, ToggleComponent, UnderscoreMobNumberComponent, UploadComponent, WarningSnackbarComponent };
5753
+ export { AddDocumentComponent, AdditionButtonComponent, AgeDateComponent, AmountTextboxComponent, AnnuityRateLogoComponent, AutocompleteComponent, BenefitCardComponent, ButtonComponent, CardComponent, CheckboxComponent, CustomizedTooltipDirective, DiscountComponent, DiscountV2Component, DobComponent, DownloadDocumentComponent, EmailWithDomainComponent, ErrorSnackbarComponent, GreyLabelComponent, HeaderComponent, HrLineComponent, HyperlinkComponent, IconButtonComponent, IframeComponent, ImageComponent, ImageUploadComponent, InBuiltBenefitComponent, InfoComponent, InfoTextboxComponent, LabelComponent, LabelValueCardComponent, LabelWithImageComponent, LoaderComponent, MY_DATE_FORMAT, MasterControlComponent, MasterControlService, MedialQuestionsComponent, MenuComponent, MobNumberComponent, MultipleSelectComponent, NeutralSnackbarComponent, OtherBenefitsComponent, OtpMobNumberComponent, OtpTextboxComponent, PageNudgeComponent, PayGetCardComponent, RadioComponent, SearchMultiSelectComponent, SelectComponent, SelectTextboxComponent, StepperComponent, StepperWIthArrowComponent, SubHeaderComponent, SubscriptTextboxComponent, SuccessSnackbarComponent, SuffixTextboxComponent, TabComponent, TableComponent, TextareaComponent, TextboxComponent, TextboxWithImageComponent, TextboxWithTextComponent, TextboxWithUnderscoreComponent, ToggleButtonComponent, ToggleComponent, UnderscoreMobNumberComponent, UploadComponent, WarningSnackbarComponent };
5678
5754
  //# sourceMappingURL=master-control.mjs.map