matcha-components 18.3.3 → 18.3.5

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.
@@ -0,0 +1,16 @@
1
+ import { QueryList, AfterContentInit } from '@angular/core';
2
+ import { MatchaStepComponent } from '../stepper-step/stepper-step.component';
3
+ import { MatchaStepperService } from '../stepper.service';
4
+ import * as i0 from "@angular/core";
5
+ export declare class MatchaStepperComponent implements AfterContentInit {
6
+ private stepperService;
7
+ steps: QueryList<MatchaStepComponent>;
8
+ currentStepIndex: number;
9
+ constructor(stepperService: MatchaStepperService);
10
+ ngAfterContentInit(): void;
11
+ next(): void;
12
+ previous(): void;
13
+ private activateStep;
14
+ static ɵfac: i0.ɵɵFactoryDeclaration<MatchaStepperComponent, never>;
15
+ static ɵcmp: i0.ɵɵComponentDeclaration<MatchaStepperComponent, "matcha-stepper", never, {}, {}, ["steps"], ["[matcha-stepper-header]", "*", "[matcha-stepper-footer]"], false, never>;
16
+ }
@@ -0,0 +1,16 @@
1
+ import { Subscription } from 'rxjs';
2
+ import { OnInit, OnDestroy } from '@angular/core';
3
+ import { MatchaStepperService, StepData } from '../stepper.service';
4
+ import * as i0 from "@angular/core";
5
+ export declare class MatchaStepperPaginationComponent implements OnInit, OnDestroy {
6
+ private stepperService;
7
+ steps: StepData[];
8
+ currentStep: number;
9
+ subscription: Subscription;
10
+ constructor(stepperService: MatchaStepperService);
11
+ ngOnInit(): void;
12
+ goToStep(index: number): void;
13
+ ngOnDestroy(): void;
14
+ static ɵfac: i0.ɵɵFactoryDeclaration<MatchaStepperPaginationComponent, never>;
15
+ static ɵcmp: i0.ɵɵComponentDeclaration<MatchaStepperPaginationComponent, "matcha-stepper-pagination", never, {}, {}, never, never, false, never>;
16
+ }
@@ -0,0 +1,7 @@
1
+ import * as i0 from "@angular/core";
2
+ export declare class MatchaStepComponent {
3
+ title: string;
4
+ active: boolean;
5
+ static ɵfac: i0.ɵɵFactoryDeclaration<MatchaStepComponent, never>;
6
+ static ɵcmp: i0.ɵɵComponentDeclaration<MatchaStepComponent, "matcha-step", never, { "title": { "alias": "title"; "required": false; }; }, {}, never, ["*"], false, never>;
7
+ }
@@ -1,8 +1,10 @@
1
1
  import * as i0 from "@angular/core";
2
- import * as i1 from "./stepper.directive";
3
- import * as i2 from "@angular/common";
2
+ import * as i1 from "./stepper-step/stepper-step.component";
3
+ import * as i2 from "./stepper/stepper.component";
4
+ import * as i3 from "./stepper-pagination/stepper-pagination.component";
5
+ import * as i4 from "@angular/common";
4
6
  export declare class MatchaStepperModule {
5
7
  static ɵfac: i0.ɵɵFactoryDeclaration<MatchaStepperModule, never>;
6
- static ɵmod: i0.ɵɵNgModuleDeclaration<MatchaStepperModule, [typeof i1.MatchaStepperDirective], [typeof i2.CommonModule], [typeof i1.MatchaStepperDirective]>;
8
+ static ɵmod: i0.ɵɵNgModuleDeclaration<MatchaStepperModule, [typeof i1.MatchaStepComponent, typeof i2.MatchaStepperComponent, typeof i3.MatchaStepperPaginationComponent], [typeof i4.CommonModule], [typeof i1.MatchaStepComponent, typeof i2.MatchaStepperComponent, typeof i3.MatchaStepperPaginationComponent]>;
7
9
  static ɵinj: i0.ɵɵInjectorDeclaration<MatchaStepperModule>;
8
10
  }
@@ -0,0 +1,15 @@
1
+ import { EventEmitter } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export interface StepData {
4
+ title: string;
5
+ visited: boolean;
6
+ }
7
+ export declare class MatchaStepperService {
8
+ currentStep: number;
9
+ steps: StepData[];
10
+ stepChanged: EventEmitter<number>;
11
+ setSteps(steps: StepData[]): void;
12
+ setCurrentStep(index: number): void;
13
+ static ɵfac: i0.ɵɵFactoryDeclaration<MatchaStepperService, never>;
14
+ static ɵprov: i0.ɵɵInjectableDeclaration<MatchaStepperService>;
15
+ }
@@ -19,5 +19,5 @@ export declare class MatchaTooltipDirective {
19
19
  private createTooltip;
20
20
  private destroyTooltip;
21
21
  static ɵfac: i0.ɵɵFactoryDeclaration<MatchaTooltipDirective, never>;
22
- static ɵdir: i0.ɵɵDirectiveDeclaration<MatchaTooltipDirective, "[matcha-tooltip]", never, { "tooltipText": { "alias": "matcha-tooltip"; "required": false; }; "tooltipDisabled": { "alias": "tooltip-disabled"; "required": false; }; "preferAbove": { "alias": "display-above"; "required": false; }; "preferBelow": { "alias": "display-below"; "required": false; }; "preferLeft": { "alias": "display-left"; "required": false; }; "preferRight": { "alias": "display-right"; "required": false; }; "tooltipEnableClose": { "alias": "tooltip-enable-close"; "required": false; }; }, {}, never, never, false, never>;
22
+ static ɵdir: i0.ɵɵDirectiveDeclaration<MatchaTooltipDirective, "[matcha-tooltip]", never, { "tooltipText": { "alias": "matcha-tooltip"; "required": false; }; "tooltipDisabled": { "alias": "matcha-tooltip-disabled"; "required": false; }; "preferAbove": { "alias": "matcha-tooltip-above"; "required": false; }; "preferBelow": { "alias": "matcha-tooltip-below"; "required": false; }; "preferLeft": { "alias": "matcha-tooltip-left"; "required": false; }; "preferRight": { "alias": "matcha-tooltip-right"; "required": false; }; "tooltipEnableClose": { "alias": "tooltip-enable-close"; "required": false; }; }, {}, never, never, false, never>;
23
23
  }
@@ -1,9 +1,8 @@
1
1
  import * as i0 from "@angular/core";
2
- import * as i1 from "./tooltip/tooltip.component";
3
- import * as i2 from "./tooltip.directive";
4
- import * as i3 from "@angular/common";
2
+ import * as i1 from "./tooltip.directive";
3
+ import * as i2 from "@angular/common";
5
4
  export declare class MatchaTooltipModule {
6
5
  static ɵfac: i0.ɵɵFactoryDeclaration<MatchaTooltipModule, never>;
7
- static ɵmod: i0.ɵɵNgModuleDeclaration<MatchaTooltipModule, [typeof i1.MatchaTooltipComponent, typeof i2.MatchaTooltipDirective], [typeof i3.CommonModule], [typeof i1.MatchaTooltipComponent, typeof i2.MatchaTooltipDirective]>;
6
+ static ɵmod: i0.ɵɵNgModuleDeclaration<MatchaTooltipModule, [typeof i1.MatchaTooltipDirective], [typeof i2.CommonModule], [typeof i1.MatchaTooltipDirective]>;
8
7
  static ɵinj: i0.ɵɵInjectorDeclaration<MatchaTooltipModule>;
9
8
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "matcha-components",
3
- "version": "18.3.3",
3
+ "version": "18.3.5",
4
4
  "peerDependencies": {},
5
5
  "dependencies": {
6
6
  "tslib": "^2.3.0"
package/public-api.d.ts CHANGED
@@ -11,7 +11,9 @@ export * from './lib/matcha-modal/modal-footer/modal-footer.component';
11
11
  export * from './lib/matcha-modal/modal-options/modal-options.component';
12
12
  export * from './lib/matcha-modal/modal/modal.component';
13
13
  export * from './lib/matcha-menu/menu.component';
14
- export * from './lib/matcha-tooltip/tooltip/tooltip.component';
14
+ export * from './lib/matcha-stepper/stepper/stepper.component';
15
+ export * from './lib/matcha-stepper/stepper-pagination/stepper-pagination.component';
16
+ export * from './lib/matcha-stepper/stepper-step/stepper-step.component';
15
17
  export * from './lib/matcha-toolbar/toolbar/toolbar.component';
16
18
  export * from './lib/matcha-toolbar/toolbar-button/toolbar-button.component';
17
19
  export * from './lib/matcha-toolbar/toolbar-content/toolbar-content.component';
@@ -1,198 +0,0 @@
1
- import { Component, HostListener, Input } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- export class MatchaTooltipComponent {
4
- constructor(el, renderer) {
5
- this.el = el;
6
- this.renderer = renderer;
7
- this.tooltipText = '';
8
- this.tooltipDisabled = false;
9
- // Inputs para displayência de posição (true = displayência ativa)
10
- this.displayAbove = false;
11
- this.displayBelow = false;
12
- this.displayLeft = false;
13
- this.displayRight = false;
14
- // Input para exibir botão de fechar (útil para mobile)
15
- this.tooltipEnableClose = false;
16
- this.tooltipElement = null;
17
- this.documentClickListener = null;
18
- }
19
- // Para desktop: usamos mouseenter se não estivermos no modo "close-enabled"
20
- onMouseEnter() {
21
- if (this.tooltipEnableClose) {
22
- // Se estiver em modo de clique/tap para mobile, não abre via hover.
23
- return;
24
- }
25
- if (this.tooltipDisabled || this.tooltipElement || !this.tooltipText) {
26
- return;
27
- }
28
- this.createTooltip();
29
- }
30
- // Em modo desktop, fecha ao sair do hover, exceto se tooltipEnableClose for true
31
- onMouseLeave() {
32
- if (!this.tooltipEnableClose && this.tooltipElement) {
33
- this.destroyTooltip();
34
- }
35
- }
36
- // Para mobile ou quando tooltipEnableClose está ativo, abrimos o tooltip com clique/tap
37
- onClick(event) {
38
- if (!this.tooltipEnableClose) {
39
- // Se não estiver no modo de fechar com clique, ignora o click
40
- return;
41
- }
42
- event.stopPropagation();
43
- // Se o tooltip já estiver aberto, não faz nada (ou pode implementar toggle)
44
- if (!this.tooltipElement && !this.tooltipDisabled && this.tooltipText) {
45
- this.createTooltip();
46
- }
47
- }
48
- createTooltip() {
49
- // Cria o tooltip e adiciona a classe base
50
- this.tooltipElement = this.renderer.createElement('div');
51
- this.renderer.addClass(this.tooltipElement, 'matcha-tooltip-content');
52
- // Define o texto do tooltip (aqui não usamos innerHTML, permitindo que o botão seja inserido depois)
53
- this.tooltipElement.textContent = this.tooltipText;
54
- // Define estilos iniciais para posicionamento e medição
55
- this.renderer.setStyle(this.tooltipElement, 'position', 'absolute');
56
- this.renderer.setStyle(this.tooltipElement, 'top', '0');
57
- this.renderer.setStyle(this.tooltipElement, 'left', '0');
58
- this.renderer.setStyle(this.tooltipElement, 'visibility', 'hidden');
59
- this.renderer.appendChild(document.body, this.tooltipElement);
60
- // Se tooltipEnableClose estiver true, adiciona o botão de fechar
61
- if (this.tooltipEnableClose) {
62
- const closeButton = this.renderer.createElement('div');
63
- this.renderer.addClass(closeButton, 'matcha-tooltip-close');
64
- // O botão de fechar fica dentro do tooltip
65
- this.renderer.appendChild(this.tooltipElement, closeButton);
66
- // Ao clicar no botão X, fecha o tooltip
67
- this.renderer.listen(closeButton, 'click', (e) => {
68
- e.stopPropagation();
69
- this.destroyTooltip();
70
- });
71
- // Adiciona listener global para fechar o tooltip quando clicar fora dele
72
- this.documentClickListener = this.renderer.listen('document', 'click', (e) => {
73
- if (this.tooltipElement && !this.tooltipElement.contains(e.target)) {
74
- this.destroyTooltip();
75
- }
76
- });
77
- }
78
- // Medidas para posicionamento
79
- const margin = 8;
80
- const hostRect = this.el.nativeElement.getBoundingClientRect();
81
- const tooltipRect = this.tooltipElement.getBoundingClientRect();
82
- // Verifica se há espaço suficiente para cada posição
83
- const hasSpaceAbove = hostRect.top >= tooltipRect.height + margin;
84
- const hasSpaceBelow = (window.innerHeight - hostRect.bottom) >= tooltipRect.height + margin;
85
- const hasSpaceLeft = hostRect.left >= tooltipRect.width + margin;
86
- const hasSpaceRight = (window.innerWidth - hostRect.right) >= tooltipRect.width + margin;
87
- // Determina a posição desejada com base na displayência do usuário e disponibilidade
88
- let chosenPosition = 'above';
89
- if (this.displayAbove && hasSpaceAbove) {
90
- chosenPosition = 'above';
91
- }
92
- else if (this.displayBelow && hasSpaceBelow) {
93
- chosenPosition = 'below';
94
- }
95
- else if (this.displayLeft && hasSpaceLeft) {
96
- chosenPosition = 'left';
97
- }
98
- else if (this.displayRight && hasSpaceRight) {
99
- chosenPosition = 'right';
100
- }
101
- else {
102
- chosenPosition = hasSpaceAbove ? 'above' : (hasSpaceBelow ? 'below' : 'above');
103
- }
104
- // Calcula a posição (top e left) de acordo com a posição escolhida
105
- let top = 0;
106
- let left = 0;
107
- switch (chosenPosition) {
108
- case 'above':
109
- top = hostRect.top + window.scrollY - tooltipRect.height - margin;
110
- left = hostRect.left + window.scrollX + (hostRect.width - tooltipRect.width) / 2;
111
- break;
112
- case 'below':
113
- top = hostRect.bottom + window.scrollY + margin;
114
- left = hostRect.left + window.scrollX + (hostRect.width - tooltipRect.width) / 2;
115
- break;
116
- case 'left':
117
- top = hostRect.top + window.scrollY + (hostRect.height - tooltipRect.height) / 2;
118
- left = hostRect.left + window.scrollX - tooltipRect.width - margin;
119
- break;
120
- case 'right':
121
- top = hostRect.top + window.scrollY + (hostRect.height - tooltipRect.height) / 2;
122
- left = hostRect.right + window.scrollX + margin;
123
- break;
124
- }
125
- // Ajusta horizontalmente para não ultrapassar os limites da tela
126
- if (left < margin) {
127
- left = margin;
128
- }
129
- else if (left + tooltipRect.width > window.innerWidth - margin) {
130
- left = window.innerWidth - tooltipRect.width - margin;
131
- }
132
- // Aplica os estilos calculados e torna o tooltip visível
133
- this.renderer.setStyle(this.tooltipElement, 'top', `${top}px`);
134
- this.renderer.setStyle(this.tooltipElement, 'left', `${left}px`);
135
- this.renderer.setStyle(this.tooltipElement, 'visibility', 'visible');
136
- // Adiciona classes específicas para customizar a seta de acordo com a posição
137
- this.renderer.removeClass(this.tooltipElement, 'matcha-tooltip-content_below');
138
- this.renderer.removeClass(this.tooltipElement, 'matcha-tooltip-content_left');
139
- this.renderer.removeClass(this.tooltipElement, 'matcha-tooltip-content_right');
140
- if (chosenPosition === 'below') {
141
- this.renderer.addClass(this.tooltipElement, 'matcha-tooltip-content_below');
142
- }
143
- else if (chosenPosition === 'left') {
144
- this.renderer.addClass(this.tooltipElement, 'matcha-tooltip-content_left');
145
- }
146
- else if (chosenPosition === 'right') {
147
- this.renderer.addClass(this.tooltipElement, 'matcha-tooltip-content_right');
148
- }
149
- // Para a posição 'above', mantém o estilo padrão
150
- }
151
- destroyTooltip() {
152
- if (this.tooltipElement) {
153
- this.renderer.removeChild(document.body, this.tooltipElement);
154
- this.tooltipElement = null;
155
- }
156
- if (this.documentClickListener) {
157
- this.documentClickListener(); // Remove o listener global
158
- this.documentClickListener = null;
159
- }
160
- }
161
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MatchaTooltipComponent, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); }
162
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: MatchaTooltipComponent, selector: "matcha-tooltip", inputs: { tooltipText: ["matcha-tooltip", "tooltipText"], tooltipDisabled: ["tooltip-disabled", "tooltipDisabled"], displayAbove: ["display-above", "displayAbove"], displayBelow: ["display-below", "displayBelow"], displayLeft: ["display-left", "displayLeft"], displayRight: ["display-right", "displayRight"], tooltipEnableClose: ["tooltip-enable-close", "tooltipEnableClose"] }, host: { listeners: { "mouseenter": "onMouseEnter()", "mouseleave": "onMouseLeave()", "click": "onClick($event)" } }, ngImport: i0, template: "<ng-content></ng-content>\n", styles: [""] }); }
163
- }
164
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MatchaTooltipComponent, decorators: [{
165
- type: Component,
166
- args: [{ selector: 'matcha-tooltip', template: "<ng-content></ng-content>\n" }]
167
- }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }], propDecorators: { tooltipText: [{
168
- type: Input,
169
- args: ['matcha-tooltip']
170
- }], tooltipDisabled: [{
171
- type: Input,
172
- args: ['tooltip-disabled']
173
- }], displayAbove: [{
174
- type: Input,
175
- args: ['display-above']
176
- }], displayBelow: [{
177
- type: Input,
178
- args: ['display-below']
179
- }], displayLeft: [{
180
- type: Input,
181
- args: ['display-left']
182
- }], displayRight: [{
183
- type: Input,
184
- args: ['display-right']
185
- }], tooltipEnableClose: [{
186
- type: Input,
187
- args: ['tooltip-enable-close']
188
- }], onMouseEnter: [{
189
- type: HostListener,
190
- args: ['mouseenter']
191
- }], onMouseLeave: [{
192
- type: HostListener,
193
- args: ['mouseleave']
194
- }], onClick: [{
195
- type: HostListener,
196
- args: ['click', ['$event']]
197
- }] } });
198
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.component.js","sourceRoot":"","sources":["../../../../../../projects/matcha-components/src/lib/matcha-tooltip/tooltip/tooltip.component.ts","../../../../../../projects/matcha-components/src/lib/matcha-tooltip/tooltip/tooltip.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, HostListener, Input, Renderer2 } from '@angular/core';\n\n@Component({\n  selector: 'matcha-tooltip', // Usado como atributo\n  templateUrl: './tooltip.component.html',\n  styleUrls: ['./tooltip.component.scss']\n})\nexport class MatchaTooltipComponent {\n  @Input('matcha-tooltip') tooltipText: string = '';\n  @Input('tooltip-disabled') tooltipDisabled: boolean = false;\n\n  // Inputs para displayência de posição (true = displayência ativa)\n  @Input('display-above') displayAbove: boolean = false;\n  @Input('display-below') displayBelow: boolean = false;\n  @Input('display-left') displayLeft: boolean = false;\n  @Input('display-right') displayRight: boolean = false;\n\n  // Input para exibir botão de fechar (útil para mobile)\n  @Input('tooltip-enable-close') tooltipEnableClose: boolean = false;\n\n  private tooltipElement: HTMLElement | null = null;\n  private documentClickListener: (() => void) | null = null;\n\n  constructor(private el: ElementRef, private renderer: Renderer2) {}\n\n  // Para desktop: usamos mouseenter se não estivermos no modo \"close-enabled\"\n  @HostListener('mouseenter') onMouseEnter() {\n    if (this.tooltipEnableClose) {\n      // Se estiver em modo de clique/tap para mobile, não abre via hover.\n      return;\n    }\n    if (this.tooltipDisabled || this.tooltipElement || !this.tooltipText) {\n      return;\n    }\n    this.createTooltip();\n  }\n\n  // Em modo desktop, fecha ao sair do hover, exceto se tooltipEnableClose for true\n  @HostListener('mouseleave') onMouseLeave() {\n    if (!this.tooltipEnableClose && this.tooltipElement) {\n      this.destroyTooltip();\n    }\n  }\n\n  // Para mobile ou quando tooltipEnableClose está ativo, abrimos o tooltip com clique/tap\n  @HostListener('click', ['$event'])\n  onClick(event: Event) {\n    if (!this.tooltipEnableClose) {\n      // Se não estiver no modo de fechar com clique, ignora o click\n      return;\n    }\n    event.stopPropagation();\n    // Se o tooltip já estiver aberto, não faz nada (ou pode implementar toggle)\n    if (!this.tooltipElement && !this.tooltipDisabled && this.tooltipText) {\n      this.createTooltip();\n    }\n  }\n\n  private createTooltip() {\n    // Cria o tooltip e adiciona a classe base\n    this.tooltipElement = this.renderer.createElement('div');\n    this.renderer.addClass(this.tooltipElement, 'matcha-tooltip-content');\n    // Define o texto do tooltip (aqui não usamos innerHTML, permitindo que o botão seja inserido depois)\n    this.tooltipElement!.textContent = this.tooltipText;\n\n    // Define estilos iniciais para posicionamento e medição\n    this.renderer.setStyle(this.tooltipElement, 'position', 'absolute');\n    this.renderer.setStyle(this.tooltipElement, 'top', '0');\n    this.renderer.setStyle(this.tooltipElement, 'left', '0');\n    this.renderer.setStyle(this.tooltipElement, 'visibility', 'hidden');\n    this.renderer.appendChild(document.body, this.tooltipElement);\n\n    // Se tooltipEnableClose estiver true, adiciona o botão de fechar\n    if (this.tooltipEnableClose) {\n      const closeButton = this.renderer.createElement('div');\n      this.renderer.addClass(closeButton, 'matcha-tooltip-close');\n      // O botão de fechar fica dentro do tooltip\n      this.renderer.appendChild(this.tooltipElement, closeButton);\n      // Ao clicar no botão X, fecha o tooltip\n      this.renderer.listen(closeButton, 'click', (e: Event) => {\n        e.stopPropagation();\n        this.destroyTooltip();\n      });\n      // Adiciona listener global para fechar o tooltip quando clicar fora dele\n      this.documentClickListener = this.renderer.listen('document', 'click', (e: Event) => {\n        if (this.tooltipElement && !this.tooltipElement.contains(e.target as Node)) {\n          this.destroyTooltip();\n        }\n      });\n    }\n\n    // Medidas para posicionamento\n    const margin = 8;\n    const hostRect = this.el.nativeElement.getBoundingClientRect();\n    const tooltipRect = this.tooltipElement!.getBoundingClientRect();\n\n    // Verifica se há espaço suficiente para cada posição\n    const hasSpaceAbove = hostRect.top >= tooltipRect.height + margin;\n    const hasSpaceBelow = (window.innerHeight - hostRect.bottom) >= tooltipRect.height + margin;\n    const hasSpaceLeft  = hostRect.left >= tooltipRect.width + margin;\n    const hasSpaceRight = (window.innerWidth - hostRect.right) >= tooltipRect.width + margin;\n\n    // Determina a posição desejada com base na displayência do usuário e disponibilidade\n    let chosenPosition: 'above' | 'below' | 'left' | 'right' = 'above';\n    if (this.displayAbove && hasSpaceAbove) {\n      chosenPosition = 'above';\n    } else if (this.displayBelow && hasSpaceBelow) {\n      chosenPosition = 'below';\n    } else if (this.displayLeft && hasSpaceLeft) {\n      chosenPosition = 'left';\n    } else if (this.displayRight && hasSpaceRight) {\n      chosenPosition = 'right';\n    } else {\n      chosenPosition = hasSpaceAbove ? 'above' : (hasSpaceBelow ? 'below' : 'above');\n    }\n\n    // Calcula a posição (top e left) de acordo com a posição escolhida\n    let top: number = 0;\n    let left: number = 0;\n    switch (chosenPosition) {\n      case 'above':\n        top = hostRect.top + window.scrollY - tooltipRect.height - margin;\n        left = hostRect.left + window.scrollX + (hostRect.width - tooltipRect.width) / 2;\n        break;\n      case 'below':\n        top = hostRect.bottom + window.scrollY + margin;\n        left = hostRect.left + window.scrollX + (hostRect.width - tooltipRect.width) / 2;\n        break;\n      case 'left':\n        top = hostRect.top + window.scrollY + (hostRect.height - tooltipRect.height) / 2;\n        left = hostRect.left + window.scrollX - tooltipRect.width - margin;\n        break;\n      case 'right':\n        top = hostRect.top + window.scrollY + (hostRect.height - tooltipRect.height) / 2;\n        left = hostRect.right + window.scrollX + margin;\n        break;\n    }\n\n    // Ajusta horizontalmente para não ultrapassar os limites da tela\n    if (left < margin) {\n      left = margin;\n    } else if (left + tooltipRect.width > window.innerWidth - margin) {\n      left = window.innerWidth - tooltipRect.width - margin;\n    }\n\n    // Aplica os estilos calculados e torna o tooltip visível\n    this.renderer.setStyle(this.tooltipElement, 'top', `${top}px`);\n    this.renderer.setStyle(this.tooltipElement, 'left', `${left}px`);\n    this.renderer.setStyle(this.tooltipElement, 'visibility', 'visible');\n\n    // Adiciona classes específicas para customizar a seta de acordo com a posição\n    this.renderer.removeClass(this.tooltipElement, 'matcha-tooltip-content_below');\n    this.renderer.removeClass(this.tooltipElement, 'matcha-tooltip-content_left');\n    this.renderer.removeClass(this.tooltipElement, 'matcha-tooltip-content_right');\n    if (chosenPosition === 'below') {\n      this.renderer.addClass(this.tooltipElement, 'matcha-tooltip-content_below');\n    } else if (chosenPosition === 'left') {\n      this.renderer.addClass(this.tooltipElement, 'matcha-tooltip-content_left');\n    } else if (chosenPosition === 'right') {\n      this.renderer.addClass(this.tooltipElement, 'matcha-tooltip-content_right');\n    }\n    // Para a posição 'above', mantém o estilo padrão\n  }\n\n  private destroyTooltip() {\n    if (this.tooltipElement) {\n      this.renderer.removeChild(document.body, this.tooltipElement);\n      this.tooltipElement = null;\n    }\n    if (this.documentClickListener) {\n      this.documentClickListener(); // Remove o listener global\n      this.documentClickListener = null;\n    }\n  }\n}\n","<ng-content></ng-content>\n"]}
@@ -1,23 +0,0 @@
1
- import { ElementRef, Renderer2 } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- export declare class MatchaTooltipComponent {
4
- private el;
5
- private renderer;
6
- tooltipText: string;
7
- tooltipDisabled: boolean;
8
- displayAbove: boolean;
9
- displayBelow: boolean;
10
- displayLeft: boolean;
11
- displayRight: boolean;
12
- tooltipEnableClose: boolean;
13
- private tooltipElement;
14
- private documentClickListener;
15
- constructor(el: ElementRef, renderer: Renderer2);
16
- onMouseEnter(): void;
17
- onMouseLeave(): void;
18
- onClick(event: Event): void;
19
- private createTooltip;
20
- private destroyTooltip;
21
- static ɵfac: i0.ɵɵFactoryDeclaration<MatchaTooltipComponent, never>;
22
- static ɵcmp: i0.ɵɵComponentDeclaration<MatchaTooltipComponent, "matcha-tooltip", never, { "tooltipText": { "alias": "matcha-tooltip"; "required": false; }; "tooltipDisabled": { "alias": "tooltip-disabled"; "required": false; }; "displayAbove": { "alias": "display-above"; "required": false; }; "displayBelow": { "alias": "display-below"; "required": false; }; "displayLeft": { "alias": "display-left"; "required": false; }; "displayRight": { "alias": "display-right"; "required": false; }; "tooltipEnableClose": { "alias": "tooltip-enable-close"; "required": false; }; }, {}, never, ["*"], false, never>;
23
- }