master-control 0.3.28 → 0.3.30

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"]}