@dev-tcloud/tcloud-ui 4.1.1 → 4.2.0

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,79 +1,14 @@
1
1
  import { Directive, Input, HostListener } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
3
  export class TCloudUiTooltipDirective {
4
- onMouseOver(event) {
5
- let hoverInCallback = () => {
6
- this.remove = false;
7
- };
8
- let hoverOutCallback = () => {
9
- this.remove = true;
10
- const customDivAll = document.querySelectorAll('.tc-directive-tooltip');
11
- if (customDivAll && customDivAll.length > 0) {
12
- customDivAll.forEach((_customDiv) => {
13
- if (_customDiv) {
14
- _customDiv.remove();
15
- }
16
- });
17
- }
18
- };
19
- hoverOutCallback;
20
- setTimeout(() => {
21
- const scrollTop = window?.scrollY || window?.pageYOffset;
22
- const tooltip = this.renderer.createElement('div');
23
- const rect = this.el.nativeElement?.getBoundingClientRect();
24
- // const direction = this.el.nativeElement?.attributes['ng-reflect--t-cdirection']?.value || 'top';
25
- const direction = this._direction || 'top';
26
- const el_position_x = (rect?.left) ? parseInt(rect?.left) : 0;
27
- const el_position_y = (rect?.top) ? parseInt(rect?.top + scrollTop) : 0;
28
- let width = 0;
29
- let height = 0;
30
- if (event && event.target) {
31
- const _event = event.target;
32
- height = _event.offsetHeight;
33
- width = _event.offsetWidth;
34
- }
35
- const top = `${(el_position_y - ((height / 2) + 10))}px`;
36
- const left = `${el_position_x + (width / 2)}px`;
37
- this.renderer.setStyle(tooltip, 'top', '0px');
38
- this.renderer.setStyle(tooltip, 'left', '0px');
39
- this.renderer.setStyle(tooltip, 'opacity', '0');
40
- this.renderer.addClass(tooltip, 'tc-directive-tooltip');
41
- this.renderer.addClass(tooltip, `tc-directive-tooltip-${direction}`);
42
- const id = this.generateID();
43
- this.renderer.setAttribute(tooltip, 'id', id);
44
- const textNode = this.info_text;
45
- if (textNode !== undefined && textNode !== null && textNode !== '') {
46
- tooltip.innerHTML = textNode;
47
- this.renderer.appendChild(document.body, tooltip);
48
- this.start_tooltip(id, height, width, el_position_x, el_position_y, direction);
49
- if (tooltip) {
50
- tooltip.addEventListener('mouseenter', hoverInCallback);
51
- tooltip.addEventListener('mouseleave', hoverOutCallback);
52
- }
53
- }
54
- });
55
- }
56
- onMouseOut(event) {
57
- this.remove = true;
58
- const customDivAll = document.querySelectorAll('.tc-directive-tooltip');
59
- if (customDivAll && customDivAll.length > 0) {
60
- setTimeout(() => {
61
- if (this.remove) {
62
- customDivAll.forEach((_customDiv) => {
63
- if (_customDiv) {
64
- _customDiv.remove();
65
- }
66
- });
67
- }
68
- }, 25);
69
- }
70
- }
71
4
  set TCtooltip(tooltip) {
72
5
  if (tooltip) {
73
- if (typeof tooltip === 'object') {
74
- }
75
- else {
76
- this.info_text = tooltip;
6
+ this.info_text = typeof tooltip === 'object' ? '' : tooltip;
7
+ if (this.tooltipVisible && this.tooltipElement) {
8
+ // Atualiza o conteúdo do tooltip diretamente
9
+ this.tooltipElement.innerHTML = this.info_text;
10
+ // Reaplica a posição calculada anteriormente para manter a centralização
11
+ this.repositionTooltip();
77
12
  }
78
13
  }
79
14
  }
@@ -85,12 +20,121 @@ export class TCloudUiTooltipDirective {
85
20
  constructor(el, renderer) {
86
21
  this.el = el;
87
22
  this.renderer = renderer;
23
+ this.tooltipMode = 'hover';
88
24
  this.remove = false;
89
25
  this.info_text = '';
26
+ this.tooltipVisible = false;
27
+ this.tooltipElement = null;
90
28
  this._direction = 'top';
91
29
  }
30
+ onDocumentClick(event) {
31
+ if (this.tooltipMode === 'click' && this.tooltipVisible && this.info_text) {
32
+ const clickedInside = this.el.nativeElement.contains(event.target) || (this.tooltipElement?.contains(event.target));
33
+ if (!clickedInside) {
34
+ this.removeTooltip();
35
+ }
36
+ }
37
+ }
38
+ onMouseOver(event) {
39
+ if (this.tooltipMode === 'hover' && !this.tooltipVisible && this.info_text) {
40
+ this.createTooltip(event);
41
+ this.tooltipVisible = true;
42
+ }
43
+ }
44
+ onMouseOut(event) {
45
+ if (this.tooltipVisible) {
46
+ const relatedTarget = event.relatedTarget;
47
+ if (!this.el.nativeElement.contains(relatedTarget) && !this.tooltipElement?.contains(relatedTarget)) {
48
+ this.removeTooltip();
49
+ }
50
+ }
51
+ }
52
+ onClick(event) {
53
+ if (this.tooltipMode === 'click') {
54
+ if (this.tooltipVisible) {
55
+ this.removeTooltip();
56
+ }
57
+ else {
58
+ this.createTooltip(event);
59
+ }
60
+ this.tooltipVisible = !this.tooltipVisible;
61
+ }
62
+ }
63
+ createTooltip(event) {
64
+ const scrollTop = window?.scrollY || window?.pageYOffset;
65
+ const tooltip = this.renderer.createElement('div');
66
+ const rect = this.el.nativeElement?.getBoundingClientRect();
67
+ const direction = this._direction || 'top';
68
+ const el_position_x = rect?.left || 0;
69
+ const el_position_y = rect?.top + scrollTop || 0;
70
+ let width = 0;
71
+ let height = 0;
72
+ if (event && event.target) {
73
+ const _event = event.target;
74
+ height = _event.offsetHeight;
75
+ width = _event.offsetWidth;
76
+ }
77
+ this.renderer.setStyle(tooltip, 'top', '0px');
78
+ this.renderer.setStyle(tooltip, 'left', '0px');
79
+ this.renderer.setStyle(tooltip, 'opacity', '0');
80
+ this.renderer.addClass(tooltip, 'tc-directive-tooltip');
81
+ this.renderer.addClass(tooltip, `tc-directive-tooltip-${direction}`);
82
+ const id = this.generateID();
83
+ this.renderer.setAttribute(tooltip, 'id', id);
84
+ tooltip.innerHTML = this.info_text;
85
+ this.renderer.appendChild(document.body, tooltip);
86
+ this.start_tooltip(id, height, width, el_position_x, el_position_y, direction);
87
+ this.tooltipElement = tooltip;
88
+ tooltip.addEventListener('mouseenter', () => this.tooltipVisible = true);
89
+ tooltip.addEventListener('mouseleave', () => this.removeTooltip());
90
+ }
91
+ removeTooltip() {
92
+ const customDivAll = document.querySelectorAll('.tc-directive-tooltip');
93
+ if (customDivAll && customDivAll.length > 0) {
94
+ setTimeout(() => {
95
+ customDivAll.forEach((_customDiv) => {
96
+ if (_customDiv) {
97
+ _customDiv.remove();
98
+ }
99
+ });
100
+ }, 25);
101
+ }
102
+ this.tooltipVisible = false;
103
+ this.tooltipElement = null;
104
+ }
105
+ repositionTooltip() {
106
+ if (!this.tooltipElement)
107
+ return;
108
+ const rect = this.el.nativeElement?.getBoundingClientRect();
109
+ const height = this.el.nativeElement.offsetHeight;
110
+ const width = this.el.nativeElement.offsetWidth;
111
+ const tooltipHeight = this.tooltipElement.clientHeight;
112
+ const tooltipWidth = this.tooltipElement.clientWidth;
113
+ let p_y = 0;
114
+ let p_x = 0;
115
+ const scrollTop = window?.scrollY || window?.pageYOffset;
116
+ const center_position = (rect.left + (width / 2)) - (tooltipWidth / 2);
117
+ if (this._direction === 'top') {
118
+ p_y = (rect.top + scrollTop - tooltipHeight) - 15;
119
+ p_x = center_position;
120
+ }
121
+ else if (this._direction === 'bottom') {
122
+ p_y = (rect.top + scrollTop + height) + 15;
123
+ p_x = center_position;
124
+ }
125
+ else if (this._direction === 'left') {
126
+ p_y = (rect.top + scrollTop - (tooltipHeight / 2) + (height / 2));
127
+ p_x = rect.left - tooltipWidth - 15;
128
+ }
129
+ else if (this._direction === 'right') {
130
+ p_y = (rect.top + scrollTop - (tooltipHeight / 2) + (height / 2));
131
+ p_x = rect.left + width + 15;
132
+ }
133
+ this.renderer.setStyle(this.tooltipElement, 'top', `${p_y}px`);
134
+ this.renderer.setStyle(this.tooltipElement, 'left', `${p_x}px`);
135
+ }
92
136
  generateID(target) {
93
- const ref = (target) ? `-${target}` : '';
137
+ const ref = target ? `-${target}` : '';
94
138
  return `tc-tooltip-${Math.floor(Math.random() * Math.floor(Math.random() * Date.now()))}${ref}`;
95
139
  }
96
140
  start_tooltip(id, height, width, el_position_x, el_position_y, direction) {
@@ -98,13 +142,6 @@ export class TCloudUiTooltipDirective {
98
142
  const tooltip = document.getElementById(id);
99
143
  const tooltip_height = tooltip.clientHeight;
100
144
  const tooltip_width = tooltip.clientWidth;
101
- /*
102
- console.log('altura do target: ', height);
103
- console.log('largura do target: ', width);
104
- console.log('el_position_x do target: ', el_position_x);
105
- console.log('el_position_y do target: ', el_position_y);
106
- console.log('direction do tooltip: ', direction);
107
- */
108
145
  let p_y = 0;
109
146
  let p_x = 0;
110
147
  const center_position = (el_position_x + (width / 2)) - (tooltip_width / 2);
@@ -130,22 +167,30 @@ export class TCloudUiTooltipDirective {
130
167
  });
131
168
  }
132
169
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: TCloudUiTooltipDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive }); }
133
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.6", type: TCloudUiTooltipDirective, selector: "[TCtooltip]", inputs: { TCtooltip: "TCtooltip", TCdirection: "TCdirection" }, host: { listeners: { "mouseover": "onMouseOver($event)", "mouseout": "onMouseOut($event)" } }, ngImport: i0 }); }
170
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.6", type: TCloudUiTooltipDirective, selector: "[TCtooltip]", inputs: { tooltipMode: "tooltipMode", TCtooltip: "TCtooltip", TCdirection: "TCdirection" }, host: { listeners: { "document:click": "onDocumentClick($event)", "mouseover": "onMouseOver($event)", "mouseout": "onMouseOut($event)", "click": "onClick($event)" } }, ngImport: i0 }); }
134
171
  }
135
172
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: TCloudUiTooltipDirective, decorators: [{
136
173
  type: Directive,
137
174
  args: [{
138
175
  selector: '[TCtooltip]'
139
176
  }]
140
- }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }], propDecorators: { onMouseOver: [{
177
+ }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }], propDecorators: { tooltipMode: [{
178
+ type: Input
179
+ }], TCtooltip: [{
180
+ type: Input
181
+ }], TCdirection: [{
182
+ type: Input
183
+ }], onDocumentClick: [{
184
+ type: HostListener,
185
+ args: ['document:click', ['$event']]
186
+ }], onMouseOver: [{
141
187
  type: HostListener,
142
188
  args: ['mouseover', ['$event']]
143
189
  }], onMouseOut: [{
144
190
  type: HostListener,
145
191
  args: ['mouseout', ['$event']]
146
- }], TCtooltip: [{
147
- type: Input
148
- }], TCdirection: [{
149
- type: Input
192
+ }], onClick: [{
193
+ type: HostListener,
194
+ args: ['click', ['$event']]
150
195
  }] } });
151
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"","sources":["../../../../../../projects/tcloud-ui/src/lib/_directives/tooltip/tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, Renderer2, Input, HostListener} from '@angular/core';\r\n\r\n\r\n@Directive({\r\n  selector: '[TCtooltip]'\r\n})\r\nexport class TCloudUiTooltipDirective {\r\n\r\n  remove: boolean = false;\r\n\r\n  info_text: string = '';\r\n\r\n  @HostListener('mouseover', ['$event']) onMouseOver(event: MouseEvent) {\r\n\r\n    let hoverInCallback = () => {\r\n      this.remove = false;\r\n    }\r\n\r\n    let hoverOutCallback = () => {\r\n      this.remove = true; \r\n      const customDivAll = <any> document.querySelectorAll('.tc-directive-tooltip');\r\n      if(customDivAll && customDivAll.length > 0){\r\n        customDivAll.forEach(( _customDiv: any) => {\r\n          if( _customDiv ){ _customDiv.remove(); }\r\n        });\r\n      }\r\n    }\r\n\r\n    hoverOutCallback;\r\n\r\n    setTimeout(() => {\r\n      const scrollTop = window?.scrollY || window?.pageYOffset;\r\n      const tooltip = this.renderer.createElement('div');\r\n      const rect  = this.el.nativeElement?.getBoundingClientRect();\r\n      // const direction = this.el.nativeElement?.attributes['ng-reflect--t-cdirection']?.value || 'top';\r\n      const direction = this._direction || 'top';\r\n      const el_position_x = (rect?.left) ? parseInt(rect?.left) : 0;\r\n      const el_position_y = (rect?.top ) ? parseInt(rect?.top  + scrollTop) : 0;\r\n\r\n      let width = 0;\r\n      let height = 0;\r\n      if( event && event.target ){\r\n        const _event = event.target as any;\r\n        height  = _event.offsetHeight;\r\n        width   = _event.offsetWidth;\r\n      }\r\n\r\n      const top = `${(el_position_y - ((height/2) + 10) )}px`;\r\n      const left = `${el_position_x + (width/2) }px`;\r\n      this.renderer.setStyle(tooltip, 'top', '0px');\r\n      this.renderer.setStyle(tooltip, 'left', '0px');\r\n      this.renderer.setStyle(tooltip, 'opacity', '0');\r\n      this.renderer.addClass(tooltip, 'tc-directive-tooltip');\r\n      this.renderer.addClass(tooltip, `tc-directive-tooltip-${direction}`);\r\n      const id = this.generateID();\r\n      this.renderer.setAttribute(tooltip, 'id', id);\r\n      const textNode = this.info_text;\r\n\r\n      if( textNode !== undefined && textNode !== null && textNode !== '' ){\r\n\r\n        tooltip.innerHTML = textNode;\r\n        this.renderer.appendChild(document.body, tooltip);    \r\n        this.start_tooltip(id, height, width, el_position_x, el_position_y, direction);\r\n\r\n        if (tooltip) {\r\n          tooltip.addEventListener('mouseenter', hoverInCallback);\r\n          tooltip.addEventListener('mouseleave', hoverOutCallback);\r\n        }\r\n      }\r\n\r\n    });\r\n\r\n  }  \r\n\r\n  @HostListener('mouseout', ['$event']) onMouseOut(event: MouseEvent) {   \r\n    this.remove = true;\r\n    const customDivAll = <any> document.querySelectorAll('.tc-directive-tooltip');\r\n    if(customDivAll && customDivAll.length > 0){\r\n      setTimeout(() => {\r\n        if( this.remove ){\r\n          customDivAll.forEach(( _customDiv: any) => {\r\n            if( _customDiv ){ _customDiv.remove(); }\r\n          });\r\n        }\r\n      }, 25);\r\n    }\r\n  }\r\n\r\n\r\n  @Input() set TCtooltip (tooltip: any){\r\n    if (tooltip){\r\n      if( typeof tooltip === 'object' ){\r\n      }else{\r\n        this.info_text = tooltip;\r\n      }      \r\n    }\r\n  }\r\n\r\n  private _direction: 'top' | 'bottom' | 'left' | 'right' = 'top';\r\n  @Input() set TCdirection (direction: any){\r\n    if (direction){\r\n      this._direction = direction;\r\n    }\r\n  }\r\n  \r\n  constructor(\r\n    private el: ElementRef,\r\n    private renderer: Renderer2\r\n  ) {}\r\n\r\n\r\n  generateID(target?: string): string{\r\n    const ref = (target) ? `-${target}` : '';\r\n    return `tc-tooltip-${Math.floor(Math.random() * Math.floor(Math.random() * Date.now()))}${ref}`;\r\n  }\r\n\r\n  start_tooltip(id: string, height: number, width: number, el_position_x: number, el_position_y: number, direction: string){\r\n    setTimeout(() => {      \r\n      const tooltip: any = document.getElementById(id);\r\n      const tooltip_height = tooltip.clientHeight;\r\n      const tooltip_width = tooltip.clientWidth;\r\n\r\n      /*\r\n      console.log('altura do target: ', height);\r\n      console.log('largura do target: ', width);\r\n      console.log('el_position_x do target: ', el_position_x);\r\n      console.log('el_position_y do target: ', el_position_y);\r\n      console.log('direction do tooltip: ', direction);\r\n      */\r\n\r\n      let p_y = 0;\r\n      let p_x = 0;\r\n      const center_position = (el_position_x + (width/2)) - (tooltip_width/2);\r\n\r\n      if( direction === 'top' ){\r\n        p_y = (el_position_y - tooltip_height) - 15;\r\n        p_x = center_position;\r\n      }\r\n\r\n      if( direction === 'bottom' ){\r\n        p_y = (el_position_y + height) + 15;\r\n        p_x = center_position;\r\n      }\r\n\r\n      if( direction === 'left' ){\r\n        p_y = el_position_y - (tooltip_height/2) + (height/2);\r\n        p_x = center_position - tooltip_width/2 - width/2 - 15;\r\n      }\r\n\r\n      if( direction === 'right' ){\r\n        p_y = el_position_y - (tooltip_height/2) + (height/2);\r\n        p_x = center_position + tooltip_width/2 + width/2 + 15;\r\n      }\r\n\r\n      this.renderer.setStyle(tooltip, 'top', `${p_y}px`);\r\n      this.renderer.setStyle(tooltip, 'left', `${p_x}px`);\r\n      this.renderer.addClass(tooltip, 'tc-tooltip-fade-in');\r\n\r\n    });\r\n  }\r\n\r\n}"]}
196
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"","sources":["../../../../../../projects/tcloud-ui/src/lib/_directives/tooltip/tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, Renderer2, Input, HostListener } from '@angular/core';\r\n\r\n@Directive({\r\n  selector: '[TCtooltip]'\r\n})\r\nexport class TCloudUiTooltipDirective {\r\n\r\n  @Input() tooltipMode: 'click' | 'hover' = 'hover';\r\n  remove: boolean = false;\r\n  info_text: string = '';\r\n  tooltipVisible: boolean = false;\r\n  private tooltipElement: HTMLElement | null = null;\r\n\r\n  private _direction: 'top' | 'bottom' | 'left' | 'right' = 'top';\r\n\r\n  @Input() set TCtooltip(tooltip: any) {\r\n\r\n    if (tooltip) {\r\n      this.info_text = typeof tooltip === 'object' ? '' : tooltip;\r\n      if (this.tooltipVisible && this.tooltipElement) {\r\n        // Atualiza o conteúdo do tooltip diretamente\r\n        this.tooltipElement.innerHTML = this.info_text;\r\n\r\n        // Reaplica a posição calculada anteriormente para manter a centralização\r\n        this.repositionTooltip();\r\n      }\r\n    }\r\n  }\r\n\r\n  @Input() set TCdirection(direction: any) {\r\n    if (direction) {\r\n      this._direction = direction;\r\n    }\r\n  }\r\n\r\n  constructor(\r\n    private el: ElementRef,\r\n    private renderer: Renderer2\r\n  ) {}\r\n\r\n  @HostListener('document:click', ['$event']) onDocumentClick(event: MouseEvent) {\r\n    if (this.tooltipMode === 'click' && this.tooltipVisible && this.info_text) {\r\n      const clickedInside = this.el.nativeElement.contains(event.target) || (this.tooltipElement?.contains(event.target as Node));\r\n      if (!clickedInside) {\r\n        this.removeTooltip();\r\n      }\r\n    }\r\n  }\r\n\r\n  @HostListener('mouseover', ['$event']) onMouseOver(event: MouseEvent) {\r\n    if (this.tooltipMode === 'hover' && !this.tooltipVisible && this.info_text) {\r\n      this.createTooltip(event);\r\n      this.tooltipVisible = true;\r\n    }\r\n  }\r\n\r\n  @HostListener('mouseout', ['$event']) onMouseOut(event: MouseEvent) {\r\n    if (this.tooltipVisible) {\r\n      const relatedTarget = event.relatedTarget as Node;\r\n      if (!this.el.nativeElement.contains(relatedTarget) && !this.tooltipElement?.contains(relatedTarget)) {\r\n        this.removeTooltip();\r\n      }\r\n    }\r\n  }\r\n\r\n  @HostListener('click', ['$event']) onClick(event: MouseEvent) {\r\n    if (this.tooltipMode === 'click') {\r\n      if (this.tooltipVisible) {\r\n        this.removeTooltip();\r\n      } else {\r\n        this.createTooltip(event);\r\n      }\r\n      this.tooltipVisible = !this.tooltipVisible;\r\n    }\r\n  }\r\n\r\n  private createTooltip(event: MouseEvent) {\r\n    const scrollTop = window?.scrollY || window?.pageYOffset;\r\n    const tooltip = this.renderer.createElement('div');\r\n    const rect = this.el.nativeElement?.getBoundingClientRect();\r\n    const direction = this._direction || 'top';\r\n    const el_position_x = rect?.left || 0;\r\n    const el_position_y = rect?.top + scrollTop || 0;\r\n\r\n    let width = 0;\r\n    let height = 0;\r\n    if (event && event.target) {\r\n      const _event = event.target as any;\r\n      height = _event.offsetHeight;\r\n      width = _event.offsetWidth;\r\n    }\r\n\r\n    this.renderer.setStyle(tooltip, 'top', '0px');\r\n    this.renderer.setStyle(tooltip, 'left', '0px');\r\n    this.renderer.setStyle(tooltip, 'opacity', '0');\r\n    this.renderer.addClass(tooltip, 'tc-directive-tooltip');\r\n    this.renderer.addClass(tooltip, `tc-directive-tooltip-${direction}`);\r\n    const id = this.generateID();\r\n    this.renderer.setAttribute(tooltip, 'id', id);\r\n    tooltip.innerHTML = this.info_text;\r\n    this.renderer.appendChild(document.body, tooltip);\r\n    this.start_tooltip(id, height, width, el_position_x, el_position_y, direction);\r\n    this.tooltipElement = tooltip;\r\n\r\n    tooltip.addEventListener('mouseenter', () => this.tooltipVisible = true);\r\n    tooltip.addEventListener('mouseleave', () => this.removeTooltip());\r\n  }\r\n\r\n  private removeTooltip() {\r\n    const customDivAll = <any>document.querySelectorAll('.tc-directive-tooltip');\r\n    if (customDivAll && customDivAll.length > 0) {\r\n      setTimeout(() => {\r\n        customDivAll.forEach((_customDiv: any) => {\r\n          if (_customDiv) { _customDiv.remove(); }\r\n        });\r\n      }, 25);\r\n    }\r\n    this.tooltipVisible = false;\r\n    this.tooltipElement = null;\r\n  }\r\n\r\n  private repositionTooltip() {\r\n    if (!this.tooltipElement) return;\r\n\r\n    const rect = this.el.nativeElement?.getBoundingClientRect();\r\n    const height = this.el.nativeElement.offsetHeight;\r\n    const width = this.el.nativeElement.offsetWidth;\r\n    const tooltipHeight = this.tooltipElement.clientHeight;\r\n    const tooltipWidth = this.tooltipElement.clientWidth;\r\n\r\n    let p_y = 0;\r\n    let p_x = 0;\r\n    const scrollTop = window?.scrollY || window?.pageYOffset;\r\n    const center_position = (rect.left + (width / 2)) - (tooltipWidth / 2);\r\n\r\n    if (this._direction === 'top') {\r\n      p_y = (rect.top + scrollTop - tooltipHeight) - 15;\r\n      p_x = center_position;\r\n    } else if (this._direction === 'bottom') {\r\n      p_y = (rect.top + scrollTop + height) + 15;\r\n      p_x = center_position;\r\n    } else if (this._direction === 'left') {\r\n      p_y = (rect.top + scrollTop - (tooltipHeight / 2) + (height / 2));\r\n      p_x = rect.left - tooltipWidth - 15;\r\n    } else if (this._direction === 'right') {\r\n      p_y = (rect.top + scrollTop - (tooltipHeight / 2) + (height / 2));\r\n      p_x = rect.left + width + 15;\r\n    }\r\n\r\n    this.renderer.setStyle(this.tooltipElement, 'top', `${p_y}px`);\r\n    this.renderer.setStyle(this.tooltipElement, 'left', `${p_x}px`);\r\n  }\r\n\r\n  private generateID(target?: string): string {\r\n    const ref = target ? `-${target}` : '';\r\n    return `tc-tooltip-${Math.floor(Math.random() * Math.floor(Math.random() * Date.now()))}${ref}`;\r\n  }\r\n\r\n  private start_tooltip(id: string, height: number, width: number, el_position_x: number, el_position_y: number, direction: string) {\r\n    setTimeout(() => {\r\n      const tooltip: any = document.getElementById(id);\r\n      const tooltip_height = tooltip.clientHeight;\r\n      const tooltip_width = tooltip.clientWidth;\r\n\r\n      let p_y = 0;\r\n      let p_x = 0;\r\n      const center_position = (el_position_x + (width / 2)) - (tooltip_width / 2);\r\n\r\n      if (direction === 'top') {\r\n        p_y = (el_position_y - tooltip_height) - 15;\r\n        p_x = center_position;\r\n      }\r\n\r\n      if (direction === 'bottom') {\r\n        p_y = (el_position_y + height) + 15;\r\n        p_x = center_position;\r\n      }\r\n\r\n      if (direction === 'left') {\r\n        p_y = el_position_y - (tooltip_height / 2) + (height / 2);\r\n        p_x = center_position - tooltip_width / 2 - width / 2 - 15;\r\n      }\r\n\r\n      if (direction === 'right') {\r\n        p_y = el_position_y - (tooltip_height / 2) + (height / 2);\r\n        p_x = center_position + tooltip_width / 2 + width / 2 + 15;\r\n      }\r\n\r\n      this.renderer.setStyle(tooltip, 'top', `${p_y}px`);\r\n      this.renderer.setStyle(tooltip, 'left', `${p_x}px`);\r\n      this.renderer.addClass(tooltip, 'tc-tooltip-fade-in');\r\n    });\r\n  }\r\n}\r\n"]}
@@ -4688,79 +4688,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImpor
4688
4688
  }] } });
4689
4689
 
4690
4690
  class TCloudUiTooltipDirective {
4691
- onMouseOver(event) {
4692
- let hoverInCallback = () => {
4693
- this.remove = false;
4694
- };
4695
- let hoverOutCallback = () => {
4696
- this.remove = true;
4697
- const customDivAll = document.querySelectorAll('.tc-directive-tooltip');
4698
- if (customDivAll && customDivAll.length > 0) {
4699
- customDivAll.forEach((_customDiv) => {
4700
- if (_customDiv) {
4701
- _customDiv.remove();
4702
- }
4703
- });
4704
- }
4705
- };
4706
- hoverOutCallback;
4707
- setTimeout(() => {
4708
- const scrollTop = window?.scrollY || window?.pageYOffset;
4709
- const tooltip = this.renderer.createElement('div');
4710
- const rect = this.el.nativeElement?.getBoundingClientRect();
4711
- // const direction = this.el.nativeElement?.attributes['ng-reflect--t-cdirection']?.value || 'top';
4712
- const direction = this._direction || 'top';
4713
- const el_position_x = (rect?.left) ? parseInt(rect?.left) : 0;
4714
- const el_position_y = (rect?.top) ? parseInt(rect?.top + scrollTop) : 0;
4715
- let width = 0;
4716
- let height = 0;
4717
- if (event && event.target) {
4718
- const _event = event.target;
4719
- height = _event.offsetHeight;
4720
- width = _event.offsetWidth;
4721
- }
4722
- const top = `${(el_position_y - ((height / 2) + 10))}px`;
4723
- const left = `${el_position_x + (width / 2)}px`;
4724
- this.renderer.setStyle(tooltip, 'top', '0px');
4725
- this.renderer.setStyle(tooltip, 'left', '0px');
4726
- this.renderer.setStyle(tooltip, 'opacity', '0');
4727
- this.renderer.addClass(tooltip, 'tc-directive-tooltip');
4728
- this.renderer.addClass(tooltip, `tc-directive-tooltip-${direction}`);
4729
- const id = this.generateID();
4730
- this.renderer.setAttribute(tooltip, 'id', id);
4731
- const textNode = this.info_text;
4732
- if (textNode !== undefined && textNode !== null && textNode !== '') {
4733
- tooltip.innerHTML = textNode;
4734
- this.renderer.appendChild(document.body, tooltip);
4735
- this.start_tooltip(id, height, width, el_position_x, el_position_y, direction);
4736
- if (tooltip) {
4737
- tooltip.addEventListener('mouseenter', hoverInCallback);
4738
- tooltip.addEventListener('mouseleave', hoverOutCallback);
4739
- }
4740
- }
4741
- });
4742
- }
4743
- onMouseOut(event) {
4744
- this.remove = true;
4745
- const customDivAll = document.querySelectorAll('.tc-directive-tooltip');
4746
- if (customDivAll && customDivAll.length > 0) {
4747
- setTimeout(() => {
4748
- if (this.remove) {
4749
- customDivAll.forEach((_customDiv) => {
4750
- if (_customDiv) {
4751
- _customDiv.remove();
4752
- }
4753
- });
4754
- }
4755
- }, 25);
4756
- }
4757
- }
4758
4691
  set TCtooltip(tooltip) {
4759
4692
  if (tooltip) {
4760
- if (typeof tooltip === 'object') {
4761
- }
4762
- else {
4763
- this.info_text = tooltip;
4693
+ this.info_text = typeof tooltip === 'object' ? '' : tooltip;
4694
+ if (this.tooltipVisible && this.tooltipElement) {
4695
+ // Atualiza o conteúdo do tooltip diretamente
4696
+ this.tooltipElement.innerHTML = this.info_text;
4697
+ // Reaplica a posição calculada anteriormente para manter a centralização
4698
+ this.repositionTooltip();
4764
4699
  }
4765
4700
  }
4766
4701
  }
@@ -4772,12 +4707,121 @@ class TCloudUiTooltipDirective {
4772
4707
  constructor(el, renderer) {
4773
4708
  this.el = el;
4774
4709
  this.renderer = renderer;
4710
+ this.tooltipMode = 'hover';
4775
4711
  this.remove = false;
4776
4712
  this.info_text = '';
4713
+ this.tooltipVisible = false;
4714
+ this.tooltipElement = null;
4777
4715
  this._direction = 'top';
4778
4716
  }
4717
+ onDocumentClick(event) {
4718
+ if (this.tooltipMode === 'click' && this.tooltipVisible && this.info_text) {
4719
+ const clickedInside = this.el.nativeElement.contains(event.target) || (this.tooltipElement?.contains(event.target));
4720
+ if (!clickedInside) {
4721
+ this.removeTooltip();
4722
+ }
4723
+ }
4724
+ }
4725
+ onMouseOver(event) {
4726
+ if (this.tooltipMode === 'hover' && !this.tooltipVisible && this.info_text) {
4727
+ this.createTooltip(event);
4728
+ this.tooltipVisible = true;
4729
+ }
4730
+ }
4731
+ onMouseOut(event) {
4732
+ if (this.tooltipVisible) {
4733
+ const relatedTarget = event.relatedTarget;
4734
+ if (!this.el.nativeElement.contains(relatedTarget) && !this.tooltipElement?.contains(relatedTarget)) {
4735
+ this.removeTooltip();
4736
+ }
4737
+ }
4738
+ }
4739
+ onClick(event) {
4740
+ if (this.tooltipMode === 'click') {
4741
+ if (this.tooltipVisible) {
4742
+ this.removeTooltip();
4743
+ }
4744
+ else {
4745
+ this.createTooltip(event);
4746
+ }
4747
+ this.tooltipVisible = !this.tooltipVisible;
4748
+ }
4749
+ }
4750
+ createTooltip(event) {
4751
+ const scrollTop = window?.scrollY || window?.pageYOffset;
4752
+ const tooltip = this.renderer.createElement('div');
4753
+ const rect = this.el.nativeElement?.getBoundingClientRect();
4754
+ const direction = this._direction || 'top';
4755
+ const el_position_x = rect?.left || 0;
4756
+ const el_position_y = rect?.top + scrollTop || 0;
4757
+ let width = 0;
4758
+ let height = 0;
4759
+ if (event && event.target) {
4760
+ const _event = event.target;
4761
+ height = _event.offsetHeight;
4762
+ width = _event.offsetWidth;
4763
+ }
4764
+ this.renderer.setStyle(tooltip, 'top', '0px');
4765
+ this.renderer.setStyle(tooltip, 'left', '0px');
4766
+ this.renderer.setStyle(tooltip, 'opacity', '0');
4767
+ this.renderer.addClass(tooltip, 'tc-directive-tooltip');
4768
+ this.renderer.addClass(tooltip, `tc-directive-tooltip-${direction}`);
4769
+ const id = this.generateID();
4770
+ this.renderer.setAttribute(tooltip, 'id', id);
4771
+ tooltip.innerHTML = this.info_text;
4772
+ this.renderer.appendChild(document.body, tooltip);
4773
+ this.start_tooltip(id, height, width, el_position_x, el_position_y, direction);
4774
+ this.tooltipElement = tooltip;
4775
+ tooltip.addEventListener('mouseenter', () => this.tooltipVisible = true);
4776
+ tooltip.addEventListener('mouseleave', () => this.removeTooltip());
4777
+ }
4778
+ removeTooltip() {
4779
+ const customDivAll = document.querySelectorAll('.tc-directive-tooltip');
4780
+ if (customDivAll && customDivAll.length > 0) {
4781
+ setTimeout(() => {
4782
+ customDivAll.forEach((_customDiv) => {
4783
+ if (_customDiv) {
4784
+ _customDiv.remove();
4785
+ }
4786
+ });
4787
+ }, 25);
4788
+ }
4789
+ this.tooltipVisible = false;
4790
+ this.tooltipElement = null;
4791
+ }
4792
+ repositionTooltip() {
4793
+ if (!this.tooltipElement)
4794
+ return;
4795
+ const rect = this.el.nativeElement?.getBoundingClientRect();
4796
+ const height = this.el.nativeElement.offsetHeight;
4797
+ const width = this.el.nativeElement.offsetWidth;
4798
+ const tooltipHeight = this.tooltipElement.clientHeight;
4799
+ const tooltipWidth = this.tooltipElement.clientWidth;
4800
+ let p_y = 0;
4801
+ let p_x = 0;
4802
+ const scrollTop = window?.scrollY || window?.pageYOffset;
4803
+ const center_position = (rect.left + (width / 2)) - (tooltipWidth / 2);
4804
+ if (this._direction === 'top') {
4805
+ p_y = (rect.top + scrollTop - tooltipHeight) - 15;
4806
+ p_x = center_position;
4807
+ }
4808
+ else if (this._direction === 'bottom') {
4809
+ p_y = (rect.top + scrollTop + height) + 15;
4810
+ p_x = center_position;
4811
+ }
4812
+ else if (this._direction === 'left') {
4813
+ p_y = (rect.top + scrollTop - (tooltipHeight / 2) + (height / 2));
4814
+ p_x = rect.left - tooltipWidth - 15;
4815
+ }
4816
+ else if (this._direction === 'right') {
4817
+ p_y = (rect.top + scrollTop - (tooltipHeight / 2) + (height / 2));
4818
+ p_x = rect.left + width + 15;
4819
+ }
4820
+ this.renderer.setStyle(this.tooltipElement, 'top', `${p_y}px`);
4821
+ this.renderer.setStyle(this.tooltipElement, 'left', `${p_x}px`);
4822
+ }
4779
4823
  generateID(target) {
4780
- const ref = (target) ? `-${target}` : '';
4824
+ const ref = target ? `-${target}` : '';
4781
4825
  return `tc-tooltip-${Math.floor(Math.random() * Math.floor(Math.random() * Date.now()))}${ref}`;
4782
4826
  }
4783
4827
  start_tooltip(id, height, width, el_position_x, el_position_y, direction) {
@@ -4785,13 +4829,6 @@ class TCloudUiTooltipDirective {
4785
4829
  const tooltip = document.getElementById(id);
4786
4830
  const tooltip_height = tooltip.clientHeight;
4787
4831
  const tooltip_width = tooltip.clientWidth;
4788
- /*
4789
- console.log('altura do target: ', height);
4790
- console.log('largura do target: ', width);
4791
- console.log('el_position_x do target: ', el_position_x);
4792
- console.log('el_position_y do target: ', el_position_y);
4793
- console.log('direction do tooltip: ', direction);
4794
- */
4795
4832
  let p_y = 0;
4796
4833
  let p_x = 0;
4797
4834
  const center_position = (el_position_x + (width / 2)) - (tooltip_width / 2);
@@ -4817,23 +4854,31 @@ class TCloudUiTooltipDirective {
4817
4854
  });
4818
4855
  }
4819
4856
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: TCloudUiTooltipDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive }); }
4820
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.6", type: TCloudUiTooltipDirective, selector: "[TCtooltip]", inputs: { TCtooltip: "TCtooltip", TCdirection: "TCdirection" }, host: { listeners: { "mouseover": "onMouseOver($event)", "mouseout": "onMouseOut($event)" } }, ngImport: i0 }); }
4857
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.6", type: TCloudUiTooltipDirective, selector: "[TCtooltip]", inputs: { tooltipMode: "tooltipMode", TCtooltip: "TCtooltip", TCdirection: "TCdirection" }, host: { listeners: { "document:click": "onDocumentClick($event)", "mouseover": "onMouseOver($event)", "mouseout": "onMouseOut($event)", "click": "onClick($event)" } }, ngImport: i0 }); }
4821
4858
  }
4822
4859
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: TCloudUiTooltipDirective, decorators: [{
4823
4860
  type: Directive,
4824
4861
  args: [{
4825
4862
  selector: '[TCtooltip]'
4826
4863
  }]
4827
- }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }], propDecorators: { onMouseOver: [{
4864
+ }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }], propDecorators: { tooltipMode: [{
4865
+ type: Input
4866
+ }], TCtooltip: [{
4867
+ type: Input
4868
+ }], TCdirection: [{
4869
+ type: Input
4870
+ }], onDocumentClick: [{
4871
+ type: HostListener,
4872
+ args: ['document:click', ['$event']]
4873
+ }], onMouseOver: [{
4828
4874
  type: HostListener,
4829
4875
  args: ['mouseover', ['$event']]
4830
4876
  }], onMouseOut: [{
4831
4877
  type: HostListener,
4832
4878
  args: ['mouseout', ['$event']]
4833
- }], TCtooltip: [{
4834
- type: Input
4835
- }], TCdirection: [{
4836
- type: Input
4879
+ }], onClick: [{
4880
+ type: HostListener,
4881
+ args: ['click', ['$event']]
4837
4882
  }] } });
4838
4883
 
4839
4884
  class TCloudUiElCopyDirective {