matcha-components 18.0.47 → 18.2.1
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.
- package/esm2022/lib/matcha-modal/modal-content/modal-content.component.mjs +3 -3
- package/esm2022/lib/matcha-tooltip/tooltip/tooltip.component.mjs +198 -0
- package/esm2022/lib/matcha-tooltip/tooltip.directive.mjs +174 -10
- package/esm2022/lib/matcha-tooltip/tooltip.module.mjs +5 -4
- package/esm2022/public-api.mjs +7 -6
- package/fesm2022/matcha-components.mjs +454 -94
- package/fesm2022/matcha-components.mjs.map +1 -1
- package/lib/matcha-tooltip/tooltip/tooltip.component.d.ts +23 -0
- package/lib/matcha-tooltip/tooltip.directive.d.ts +18 -4
- package/lib/matcha-tooltip/tooltip.module.d.ts +4 -3
- package/package.json +1 -1
- package/public-api.d.ts +6 -5
|
@@ -2,10 +2,10 @@ import { Component } from '@angular/core';
|
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
export class MatchaModalContentComponent {
|
|
4
4
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MatchaModalContentComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
5
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: MatchaModalContentComponent, selector: "matcha-modal-content", ngImport: i0, template: "\n<div class=\"py-24 pt-0 overflow-auto\" style=\"max-height: calc(100vh - 300px);\n\">\n <div class=\"matcha-card-flat matcha-background-transparent p-0
|
|
5
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: MatchaModalContentComponent, selector: "matcha-modal-content", ngImport: i0, template: "\n<div class=\"py-24 pt-0 overflow-auto\" style=\"max-height: calc(100vh - 300px);\n\">\n <div class=\"matcha-card-flat matcha-background-transparent p-0 flex-column--force\">\n <div class=\"flex-col matcha-card-flat matcha-background-transparent px-24 py-0\">\n <ng-content></ng-content>\n </div>\n </div>\n</div>\n", styles: [""] }); }
|
|
6
6
|
}
|
|
7
7
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MatchaModalContentComponent, decorators: [{
|
|
8
8
|
type: Component,
|
|
9
|
-
args: [{ selector: 'matcha-modal-content', template: "\n<div class=\"py-24 pt-0 overflow-auto\" style=\"max-height: calc(100vh - 300px);\n\">\n <div class=\"matcha-card-flat matcha-background-transparent p-0
|
|
9
|
+
args: [{ selector: 'matcha-modal-content', template: "\n<div class=\"py-24 pt-0 overflow-auto\" style=\"max-height: calc(100vh - 300px);\n\">\n <div class=\"matcha-card-flat matcha-background-transparent p-0 flex-column--force\">\n <div class=\"flex-col matcha-card-flat matcha-background-transparent px-24 py-0\">\n <ng-content></ng-content>\n </div>\n </div>\n</div>\n" }]
|
|
10
10
|
}] });
|
|
11
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwtY29udGVudC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tYXRjaGEtY29tcG9uZW50cy9zcmMvbGliL21hdGNoYS1tb2RhbC9tb2RhbC1jb250ZW50L21vZGFsLWNvbnRlbnQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbWF0Y2hhLWNvbXBvbmVudHMvc3JjL2xpYi9tYXRjaGEtbW9kYWwvbW9kYWwtY29udGVudC9tb2RhbC1jb250ZW50LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBTzFDLE1BQU0sT0FBTywyQkFBMkI7K0dBQTNCLDJCQUEyQjttR0FBM0IsMkJBQTJCLDREQ1B4Qyw2VkFTQTs7NEZERmEsMkJBQTJCO2tCQUx2QyxTQUFTOytCQUNFLHNCQUFzQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdtYXRjaGEtbW9kYWwtY29udGVudCcsXG4gIHRlbXBsYXRlVXJsOiAnLi9tb2RhbC1jb250ZW50LmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vbW9kYWwtY29udGVudC5jb21wb25lbnQuc2NzcyddXG59KVxuZXhwb3J0IGNsYXNzIE1hdGNoYU1vZGFsQ29udGVudENvbXBvbmVudCB7XG5cbn1cbiIsIlxuPGRpdiBjbGFzcz1cInB5LTI0IHB0LTAgb3ZlcmZsb3ctYXV0b1wiIHN0eWxlPVwibWF4LWhlaWdodDogY2FsYygxMDB2aCAtIDMwMHB4KTtcblwiPlxuICAgIDxkaXYgY2xhc3M9XCJtYXRjaGEtY2FyZC1mbGF0IG1hdGNoYS1iYWNrZ3JvdW5kLXRyYW5zcGFyZW50IHAtMCBmbGV4LWNvbHVtbi0tZm9yY2VcIj5cbiAgICAgICAgPGRpdiBjbGFzcz1cImZsZXgtY29sIG1hdGNoYS1jYXJkLWZsYXQgbWF0Y2hhLWJhY2tncm91bmQtdHJhbnNwYXJlbnQgcHgtMjQgcHktMFwiPlxuICAgICAgICAgICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuICAgICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbjwvZGl2PlxuIl19
|
|
@@ -0,0 +1,198 @@
|
|
|
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,19 +1,183 @@
|
|
|
1
|
-
import { Directive } from '@angular/core';
|
|
1
|
+
import { Directive, HostListener, Input } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
export class MatchaTooltipDirective {
|
|
4
|
-
constructor(
|
|
5
|
-
this.
|
|
6
|
-
this.
|
|
7
|
-
|
|
8
|
-
this.
|
|
4
|
+
constructor(el, renderer) {
|
|
5
|
+
this.el = el;
|
|
6
|
+
this.renderer = renderer;
|
|
7
|
+
this.tooltipText = '';
|
|
8
|
+
this.tooltipDisabled = false;
|
|
9
|
+
this.preferAbove = false;
|
|
10
|
+
this.preferBelow = false;
|
|
11
|
+
this.preferLeft = false;
|
|
12
|
+
this.preferRight = false;
|
|
13
|
+
this.tooltipEnableClose = false;
|
|
14
|
+
this.tooltipElement = null;
|
|
15
|
+
this.documentClickListener = null;
|
|
16
|
+
}
|
|
17
|
+
onMouseEnter() {
|
|
18
|
+
if (this.tooltipEnableClose) {
|
|
19
|
+
// Em modo de clique/tap, não abre via hover
|
|
20
|
+
return;
|
|
21
|
+
}
|
|
22
|
+
if (this.tooltipDisabled || this.tooltipElement || !this.tooltipText) {
|
|
23
|
+
return;
|
|
24
|
+
}
|
|
25
|
+
this.createTooltip();
|
|
26
|
+
}
|
|
27
|
+
onMouseLeave() {
|
|
28
|
+
if (!this.tooltipEnableClose && this.tooltipElement) {
|
|
29
|
+
this.destroyTooltip();
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
onClick(event) {
|
|
33
|
+
if (!this.tooltipEnableClose) {
|
|
34
|
+
return;
|
|
35
|
+
}
|
|
36
|
+
event.stopPropagation();
|
|
37
|
+
if (!this.tooltipElement && !this.tooltipDisabled && this.tooltipText) {
|
|
38
|
+
this.createTooltip();
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
createTooltip() {
|
|
42
|
+
// Cria o tooltip e adiciona a classe base
|
|
43
|
+
this.tooltipElement = this.renderer.createElement('div');
|
|
44
|
+
this.renderer.addClass(this.tooltipElement, 'matcha-tooltip-content');
|
|
45
|
+
// Define o conteúdo do tooltip
|
|
46
|
+
this.tooltipElement.textContent = this.tooltipText;
|
|
47
|
+
// Define estilos iniciais para medição
|
|
48
|
+
this.renderer.setStyle(this.tooltipElement, 'position', 'absolute');
|
|
49
|
+
this.renderer.setStyle(this.tooltipElement, 'top', '0');
|
|
50
|
+
this.renderer.setStyle(this.tooltipElement, 'left', '0');
|
|
51
|
+
this.renderer.setStyle(this.tooltipElement, 'visibility', 'hidden');
|
|
52
|
+
this.renderer.appendChild(document.body, this.tooltipElement);
|
|
53
|
+
// Se tooltipEnableClose estiver ativo, adiciona o botão de fechar
|
|
54
|
+
if (this.tooltipEnableClose) {
|
|
55
|
+
const closeButton = this.renderer.createElement('div');
|
|
56
|
+
this.renderer.addClass(closeButton, 'matcha-tooltip-close');
|
|
57
|
+
this.renderer.appendChild(this.tooltipElement, closeButton);
|
|
58
|
+
this.renderer.listen(closeButton, 'click', (e) => {
|
|
59
|
+
e.stopPropagation();
|
|
60
|
+
this.destroyTooltip();
|
|
61
|
+
});
|
|
62
|
+
this.documentClickListener = this.renderer.listen('document', 'click', (e) => {
|
|
63
|
+
if (this.tooltipElement && !this.tooltipElement.contains(e.target)) {
|
|
64
|
+
this.destroyTooltip();
|
|
65
|
+
}
|
|
66
|
+
});
|
|
67
|
+
}
|
|
68
|
+
// Medidas e cálculo de posição
|
|
69
|
+
const margin = 8;
|
|
70
|
+
const hostRect = this.el.nativeElement.getBoundingClientRect();
|
|
71
|
+
const tooltipRect = this.tooltipElement.getBoundingClientRect();
|
|
72
|
+
const hasSpaceAbove = hostRect.top >= tooltipRect.height + margin;
|
|
73
|
+
const hasSpaceBelow = (window.innerHeight - hostRect.bottom) >= tooltipRect.height + margin;
|
|
74
|
+
const hasSpaceLeft = hostRect.left >= tooltipRect.width + margin;
|
|
75
|
+
const hasSpaceRight = (window.innerWidth - hostRect.right) >= tooltipRect.width + margin;
|
|
76
|
+
let chosenPosition = 'above';
|
|
77
|
+
if (this.preferAbove && hasSpaceAbove) {
|
|
78
|
+
chosenPosition = 'above';
|
|
79
|
+
}
|
|
80
|
+
else if (this.preferBelow && hasSpaceBelow) {
|
|
81
|
+
chosenPosition = 'below';
|
|
82
|
+
}
|
|
83
|
+
else if (this.preferLeft && hasSpaceLeft) {
|
|
84
|
+
chosenPosition = 'left';
|
|
85
|
+
}
|
|
86
|
+
else if (this.preferRight && hasSpaceRight) {
|
|
87
|
+
chosenPosition = 'right';
|
|
88
|
+
}
|
|
89
|
+
else {
|
|
90
|
+
chosenPosition = hasSpaceAbove ? 'above' : (hasSpaceBelow ? 'below' : 'above');
|
|
91
|
+
}
|
|
92
|
+
let top = 0;
|
|
93
|
+
let left = 0;
|
|
94
|
+
switch (chosenPosition) {
|
|
95
|
+
case 'above':
|
|
96
|
+
top = hostRect.top + window.scrollY - tooltipRect.height - margin;
|
|
97
|
+
left = hostRect.left + window.scrollX + (hostRect.width - tooltipRect.width) / 2;
|
|
98
|
+
break;
|
|
99
|
+
case 'below':
|
|
100
|
+
top = hostRect.bottom + window.scrollY + margin;
|
|
101
|
+
left = hostRect.left + window.scrollX + (hostRect.width - tooltipRect.width) / 2;
|
|
102
|
+
break;
|
|
103
|
+
case 'left':
|
|
104
|
+
top = hostRect.top + window.scrollY + (hostRect.height - tooltipRect.height) / 2;
|
|
105
|
+
left = hostRect.left + window.scrollX - tooltipRect.width - margin;
|
|
106
|
+
break;
|
|
107
|
+
case 'right':
|
|
108
|
+
top = hostRect.top + window.scrollY + (hostRect.height - tooltipRect.height) / 2;
|
|
109
|
+
left = hostRect.right + window.scrollX + margin;
|
|
110
|
+
break;
|
|
111
|
+
}
|
|
112
|
+
if (left < margin) {
|
|
113
|
+
left = margin;
|
|
114
|
+
}
|
|
115
|
+
else if (left + tooltipRect.width > window.innerWidth - margin) {
|
|
116
|
+
left = window.innerWidth - tooltipRect.width - margin;
|
|
117
|
+
}
|
|
118
|
+
this.renderer.setStyle(this.tooltipElement, 'top', `${top}px`);
|
|
119
|
+
this.renderer.setStyle(this.tooltipElement, 'left', `${left}px`);
|
|
120
|
+
this.renderer.setStyle(this.tooltipElement, 'visibility', 'visible');
|
|
121
|
+
this.renderer.removeClass(this.tooltipElement, 'matcha-tooltip-content_below');
|
|
122
|
+
this.renderer.removeClass(this.tooltipElement, 'matcha-tooltip-content_left');
|
|
123
|
+
this.renderer.removeClass(this.tooltipElement, 'matcha-tooltip-content_right');
|
|
124
|
+
if (chosenPosition === 'below') {
|
|
125
|
+
this.renderer.addClass(this.tooltipElement, 'matcha-tooltip-content_below');
|
|
126
|
+
}
|
|
127
|
+
else if (chosenPosition === 'left') {
|
|
128
|
+
this.renderer.addClass(this.tooltipElement, 'matcha-tooltip-content_left');
|
|
129
|
+
}
|
|
130
|
+
else if (chosenPosition === 'right') {
|
|
131
|
+
this.renderer.addClass(this.tooltipElement, 'matcha-tooltip-content_right');
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
destroyTooltip() {
|
|
135
|
+
if (this.tooltipElement) {
|
|
136
|
+
this.renderer.removeChild(document.body, this.tooltipElement);
|
|
137
|
+
this.tooltipElement = null;
|
|
138
|
+
}
|
|
139
|
+
if (this.documentClickListener) {
|
|
140
|
+
this.documentClickListener();
|
|
141
|
+
this.documentClickListener = null;
|
|
142
|
+
}
|
|
9
143
|
}
|
|
10
144
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MatchaTooltipDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
11
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: MatchaTooltipDirective, selector: "[
|
|
145
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: MatchaTooltipDirective, selector: "[matcha-tooltip]", inputs: { tooltipText: ["matcha-tooltip", "tooltipText"], tooltipDisabled: ["tooltip-disabled", "tooltipDisabled"], preferAbove: ["display-above", "preferAbove"], preferBelow: ["display-below", "preferBelow"], preferLeft: ["display-left", "preferLeft"], preferRight: ["display-right", "preferRight"], tooltipEnableClose: ["tooltip-enable-close", "tooltipEnableClose"] }, host: { listeners: { "mouseenter": "onMouseEnter()", "mouseleave": "onMouseLeave()", "click": "onClick($event)" } }, ngImport: i0 }); }
|
|
12
146
|
}
|
|
13
147
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MatchaTooltipDirective, decorators: [{
|
|
14
148
|
type: Directive,
|
|
15
149
|
args: [{
|
|
16
|
-
selector: '[
|
|
150
|
+
selector: '[matcha-tooltip]' // Usado como atributo
|
|
17
151
|
}]
|
|
18
|
-
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }]
|
|
19
|
-
|
|
152
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }], propDecorators: { tooltipText: [{
|
|
153
|
+
type: Input,
|
|
154
|
+
args: ['matcha-tooltip']
|
|
155
|
+
}], tooltipDisabled: [{
|
|
156
|
+
type: Input,
|
|
157
|
+
args: ['tooltip-disabled']
|
|
158
|
+
}], preferAbove: [{
|
|
159
|
+
type: Input,
|
|
160
|
+
args: ['display-above']
|
|
161
|
+
}], preferBelow: [{
|
|
162
|
+
type: Input,
|
|
163
|
+
args: ['display-below']
|
|
164
|
+
}], preferLeft: [{
|
|
165
|
+
type: Input,
|
|
166
|
+
args: ['display-left']
|
|
167
|
+
}], preferRight: [{
|
|
168
|
+
type: Input,
|
|
169
|
+
args: ['display-right']
|
|
170
|
+
}], tooltipEnableClose: [{
|
|
171
|
+
type: Input,
|
|
172
|
+
args: ['tooltip-enable-close']
|
|
173
|
+
}], onMouseEnter: [{
|
|
174
|
+
type: HostListener,
|
|
175
|
+
args: ['mouseenter']
|
|
176
|
+
}], onMouseLeave: [{
|
|
177
|
+
type: HostListener,
|
|
178
|
+
args: ['mouseleave']
|
|
179
|
+
}], onClick: [{
|
|
180
|
+
type: HostListener,
|
|
181
|
+
args: ['click', ['$event']]
|
|
182
|
+
}] } });
|
|
183
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"","sources":["../../../../../projects/matcha-components/src/lib/matcha-tooltip/tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, HostListener, Input, Renderer2 } from '@angular/core';\n\n@Directive({\n  selector: '[matcha-tooltip]' // Usado como atributo\n})\nexport class MatchaTooltipDirective {\n  @Input('matcha-tooltip') tooltipText: string = '';\n  @Input('tooltip-disabled') tooltipDisabled: boolean = false;\n\n  @Input('display-above') preferAbove: boolean = false;\n  @Input('display-below') preferBelow: boolean = false;\n  @Input('display-left') preferLeft: boolean = false;\n  @Input('display-right') preferRight: boolean = false;\n\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  @HostListener('mouseenter')\n  onMouseEnter() {\n    if (this.tooltipEnableClose) {\n      // Em modo de clique/tap, 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  @HostListener('mouseleave')\n  onMouseLeave() {\n    if (!this.tooltipEnableClose && this.tooltipElement) {\n      this.destroyTooltip();\n    }\n  }\n\n  @HostListener('click', ['$event'])\n  onClick(event: Event) {\n    if (!this.tooltipEnableClose) {\n      return;\n    }\n    event.stopPropagation();\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\n    // Define o conteúdo do tooltip\n    this.tooltipElement!.textContent = this.tooltipText;\n\n    // Define estilos iniciais para 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 ativo, 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      this.renderer.appendChild(this.tooltipElement, closeButton);\n      this.renderer.listen(closeButton, 'click', (e: Event) => {\n        e.stopPropagation();\n        this.destroyTooltip();\n      });\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 e cálculo de posição\n    const margin = 8;\n    const hostRect = this.el.nativeElement.getBoundingClientRect();\n    const tooltipRect = this.tooltipElement!.getBoundingClientRect();\n\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    let chosenPosition: 'above' | 'below' | 'left' | 'right' = 'above';\n    if (this.preferAbove && hasSpaceAbove) {\n      chosenPosition = 'above';\n    } else if (this.preferBelow && hasSpaceBelow) {\n      chosenPosition = 'below';\n    } else if (this.preferLeft && hasSpaceLeft) {\n      chosenPosition = 'left';\n    } else if (this.preferRight && hasSpaceRight) {\n      chosenPosition = 'right';\n    } else {\n      chosenPosition = hasSpaceAbove ? 'above' : (hasSpaceBelow ? 'below' : 'above');\n    }\n\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    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    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    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  }\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();\n      this.documentClickListener = null;\n    }\n  }\n}\n"]}
|
|
@@ -1,18 +1,19 @@
|
|
|
1
1
|
import { NgModule } from '@angular/core';
|
|
2
2
|
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { MatchaTooltipComponent } from './tooltip/tooltip.component';
|
|
3
4
|
import { MatchaTooltipDirective } from './tooltip.directive';
|
|
4
5
|
import * as i0 from "@angular/core";
|
|
5
6
|
export class MatchaTooltipModule {
|
|
6
7
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MatchaTooltipModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
7
|
-
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: MatchaTooltipModule, declarations: [MatchaTooltipDirective], imports: [CommonModule], exports: [MatchaTooltipDirective] }); }
|
|
8
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: MatchaTooltipModule, declarations: [MatchaTooltipComponent, MatchaTooltipDirective], imports: [CommonModule], exports: [MatchaTooltipComponent, MatchaTooltipDirective] }); }
|
|
8
9
|
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MatchaTooltipModule, imports: [CommonModule] }); }
|
|
9
10
|
}
|
|
10
11
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MatchaTooltipModule, decorators: [{
|
|
11
12
|
type: NgModule,
|
|
12
13
|
args: [{
|
|
13
|
-
declarations: [MatchaTooltipDirective],
|
|
14
|
+
declarations: [MatchaTooltipComponent, MatchaTooltipDirective],
|
|
14
15
|
imports: [CommonModule],
|
|
15
|
-
exports: [MatchaTooltipDirective],
|
|
16
|
+
exports: [MatchaTooltipComponent, MatchaTooltipDirective],
|
|
16
17
|
}]
|
|
17
18
|
}] });
|
|
18
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tYXRjaGEtY29tcG9uZW50cy9zcmMvbGliL21hdGNoYS10b29sdGlwL3Rvb2x0aXAubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQ3JFLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLHFCQUFxQixDQUFDOztBQU83RCxNQUFNLE9BQU8sbUJBQW1COytHQUFuQixtQkFBbUI7Z0hBQW5CLG1CQUFtQixpQkFKYixzQkFBc0IsRUFBRSxzQkFBc0IsYUFDbkQsWUFBWSxhQUNaLHNCQUFzQixFQUFFLHNCQUFzQjtnSEFFL0MsbUJBQW1CLFlBSGxCLFlBQVk7OzRGQUdiLG1CQUFtQjtrQkFML0IsUUFBUTttQkFBQztvQkFDTixZQUFZLEVBQUUsQ0FBQyxzQkFBc0IsRUFBRSxzQkFBc0IsQ0FBQztvQkFDOUQsT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDO29CQUN2QixPQUFPLEVBQUUsQ0FBQyxzQkFBc0IsRUFBRSxzQkFBc0IsQ0FBQztpQkFDNUQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE1hdGNoYVRvb2x0aXBDb21wb25lbnQgfSBmcm9tICcuL3Rvb2x0aXAvdG9vbHRpcC5jb21wb25lbnQnO1xuaW1wb3J0IHsgTWF0Y2hhVG9vbHRpcERpcmVjdGl2ZSB9IGZyb20gJy4vdG9vbHRpcC5kaXJlY3RpdmUnO1xuXG5ATmdNb2R1bGUoe1xuICAgIGRlY2xhcmF0aW9uczogW01hdGNoYVRvb2x0aXBDb21wb25lbnQsIE1hdGNoYVRvb2x0aXBEaXJlY3RpdmVdLFxuICAgIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxuICAgIGV4cG9ydHM6IFtNYXRjaGFUb29sdGlwQ29tcG9uZW50LCBNYXRjaGFUb29sdGlwRGlyZWN0aXZlXSxcbn0pXG5leHBvcnQgY2xhc3MgTWF0Y2hhVG9vbHRpcE1vZHVsZSB7fVxuIl19
|
package/esm2022/public-api.mjs
CHANGED
|
@@ -25,6 +25,7 @@ export * from './lib/matcha-modal/modal-footer/modal-footer.component';
|
|
|
25
25
|
export * from './lib/matcha-modal/modal-options/modal-options.component';
|
|
26
26
|
export * from './lib/matcha-modal/modal/modal.component';
|
|
27
27
|
export * from './lib/matcha-menu/menu.component';
|
|
28
|
+
export * from './lib/matcha-tooltip/tooltip/tooltip.component';
|
|
28
29
|
// -----------------------------------------------------------
|
|
29
30
|
// MODULES
|
|
30
31
|
// -----------------------------------------------------------
|
|
@@ -33,6 +34,10 @@ export * from './lib/matcha-card/card.module';
|
|
|
33
34
|
export * from './lib/matcha-masonry/masonry.module';
|
|
34
35
|
export * from './lib/matcha-title/title.module';
|
|
35
36
|
export * from './lib/matcha-button/button.module';
|
|
37
|
+
export * from './lib/matcha-tooltip/tooltip.module';
|
|
38
|
+
export * from './lib/matcha-divider/divider.module';
|
|
39
|
+
export * from './lib/matcha-elevation/elevation.module';
|
|
40
|
+
export * from './lib/matcha-grid/grid.module';
|
|
36
41
|
export * from './lib/matcha-components.module';
|
|
37
42
|
export * from './lib/matcha-autocomplete/autocomplete.module';
|
|
38
43
|
export * from './lib/matcha-badge/badge.module';
|
|
@@ -42,11 +47,8 @@ export * from './lib/matcha-button-toggle/button-toggle.module';
|
|
|
42
47
|
export * from './lib/matcha-checkbox/checkbox.module';
|
|
43
48
|
export * from './lib/matcha-chips/chips.module';
|
|
44
49
|
export * from './lib/matcha-datepicker/datepicker.module';
|
|
45
|
-
export * from './lib/matcha-divider/divider.module';
|
|
46
|
-
export * from './lib/matcha-elevation/elevation.module';
|
|
47
50
|
export * from './lib/matcha-expansion/expansion.module';
|
|
48
51
|
export * from './lib/matcha-forms/forms.module';
|
|
49
|
-
export * from './lib/matcha-grid/grid.module';
|
|
50
52
|
export * from './lib/matcha-icon/icon.module';
|
|
51
53
|
export * from './lib/matcha-input/input.module';
|
|
52
54
|
export * from './lib/matcha-list/list.module';
|
|
@@ -63,14 +65,13 @@ export * from './lib/matcha-snackbar/snack-bar.module';
|
|
|
63
65
|
export * from './lib/matcha-sort-header/sort-header.module';
|
|
64
66
|
export * from './lib/matcha-stepper/stepper.module';
|
|
65
67
|
export * from './lib/matcha-table/table.module';
|
|
66
|
-
export * from './lib/matcha-tooltip/tooltip.module';
|
|
67
68
|
export * from './lib/matcha-tree/tree.module';
|
|
68
69
|
// -----------------------------------------------------------
|
|
69
70
|
// DIRECTIVES
|
|
70
71
|
// -----------------------------------------------------------
|
|
72
|
+
export * from './lib/matcha-tooltip/tooltip.directive';
|
|
71
73
|
export * from './lib/matcha-input/input.directive';
|
|
72
74
|
export * from './lib/matcha-tree/tree.directive';
|
|
73
|
-
export * from './lib/matcha-tooltip/tooltip.directive';
|
|
74
75
|
export * from './lib/matcha-table/table.directive';
|
|
75
76
|
export * from './lib/matcha-stepper/stepper.directive';
|
|
76
77
|
export * from './lib/matcha-sort-header/sort-header.directive';
|
|
@@ -97,4 +98,4 @@ export * from './lib/matcha-tabs/tabs.directive';
|
|
|
97
98
|
export * from './lib/matcha-badge/badge.directive';
|
|
98
99
|
export * from './lib/matcha-autocomplete/autocomplete-overview.directive';
|
|
99
100
|
export * from './lib/matcha-autocomplete/autocomplete.directive';
|
|
100
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"public-api.js","sourceRoot":"","sources":["../../../projects/matcha-components/src/public-api.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Public API Surface of matcha-components\n */\n\n// -----------------------------------------------------------\n// COMPONENTS\n// -----------------------------------------------------------\n\n// // ATOMIC COMPONENTS\n// export * from './lib/matcha-button/matcha-button.component';\n\n// // BASE COMPONENT\n// export * from './lib/matcha-title/matcha-title.component';\n\n//\n// -----------------------------------------------------------\n// COMPONENTS\n// -----------------------------------------------------------\nexport * from './lib/matcha-button/button/button.component';\nexport * from './lib/matcha-card/card/card.component';\nexport * from './lib/matcha-divider/divider/divider.component';\nexport * from './lib/matcha-title/title/title.component';\nexport * from './lib/matcha-icon/icon.component';\nexport * from './lib/matcha-grid/grid.component';\nexport * from './lib/matcha-masonry/masonry/masonry.component';\nexport * from './lib/matcha-modal/modal-content/modal-content.component';\nexport * from './lib/matcha-modal/modal-header/modal-header.component';\nexport * from './lib/matcha-modal/modal-footer/modal-footer.component';\nexport * from './lib/matcha-modal/modal-options/modal-options.component';\nexport * from './lib/matcha-modal/modal/modal.component';\nexport * from './lib/matcha-menu/menu.component';\n\n\n// -----------------------------------------------------------\n// MODULES\n// -----------------------------------------------------------\nexport * from './lib/matcha-modal/matcha-modal.module';\nexport * from './lib/matcha-card/card.module';\nexport * from './lib/matcha-masonry/masonry.module';\nexport * from './lib/matcha-title/title.module';\nexport * from './lib/matcha-button/button.module';\n\nexport * from './lib/matcha-components.module';\nexport * from './lib/matcha-autocomplete/autocomplete.module';\nexport * from './lib/matcha-badge/badge.module';\nexport * from './lib/matcha-tabs/tabs.module';\nexport * from './lib/matcha-bottom-sheet/bottom-sheet.module';\nexport * from './lib/matcha-button-toggle/button-toggle.module';\nexport * from './lib/matcha-checkbox/checkbox.module';\nexport * from './lib/matcha-chips/chips.module';\nexport * from './lib/matcha-datepicker/datepicker.module';\nexport * from './lib/matcha-divider/divider.module';\nexport * from './lib/matcha-elevation/elevation.module';\nexport * from './lib/matcha-expansion/expansion.module';\nexport * from './lib/matcha-forms/forms.module';\nexport * from './lib/matcha-grid/grid.module';\nexport * from './lib/matcha-icon/icon.module';\nexport * from './lib/matcha-input/input.module';\nexport * from './lib/matcha-list/list.module';\nexport * from './lib/matcha-menu/menu.module';\nexport * from './lib/matcha-sidenav/sidenav.module';\nexport * from './lib/matcha-paginator/paginator.module';\nexport * from './lib/matcha-progress-bar/progress-bar.module';\nexport * from './lib/matcha-progress-spinner/progress-spinner.module';\nexport * from './lib/matcha-radio-button/radio-button.module';\nexport * from './lib/matcha-select/select.module';\nexport * from './lib/matcha-slide-toggle/slide-toggle.module';\nexport * from './lib/matcha-slider/slider.module';\nexport * from './lib/matcha-snackbar/snack-bar.module';\nexport * from './lib/matcha-sort-header/sort-header.module';\nexport * from './lib/matcha-stepper/stepper.module';\nexport * from './lib/matcha-table/table.module';\nexport * from './lib/matcha-tooltip/tooltip.module';\nexport * from './lib/matcha-tree/tree.module';\n\n// -----------------------------------------------------------\n// DIRECTIVES\n// -----------------------------------------------------------\n\nexport * from './lib/matcha-input/input.directive';\nexport * from './lib/matcha-tree/tree.directive';\nexport * from './lib/matcha-tooltip/tooltip.directive';\nexport * from './lib/matcha-table/table.directive';\nexport * from './lib/matcha-stepper/stepper.directive';\nexport * from './lib/matcha-sort-header/sort-header.directive';\nexport * from './lib/matcha-snackbar/snack-bar.directive';\nexport * from './lib/matcha-slider/matcha-slider.directive';\nexport * from './lib/matcha-slide-toggle/slide-toggle.directive';\nexport * from './lib/matcha-select/select.directive';\nexport * from './lib/matcha-radio-button/matcha-radio-button.directive';\nexport * from './lib/matcha-progress-spinner/progress-spinner.directive';\nexport * from './lib/matcha-progress-bar/progress-bar.directive';\nexport * from './lib/matcha-paginator/paginator.directive';\nexport * from './lib/matcha-sidenav/sidenav.directive';\nexport * from './lib/matcha-menu/menu.directive';\nexport * from './lib/matcha-list/list.directive';\nexport * from './lib/matcha-forms/form-field.directive';\nexport * from './lib/matcha-expansion/expansion.directive';\nexport * from './lib/matcha-elevation/elevation.directive';\nexport * from './lib/matcha-datepicker/datepicker.directive';\nexport * from './lib/matcha-chips/matcha-chips.directive';\nexport * from './lib/matcha-checkbox/checkbox.directive';\nexport * from './lib/matcha-button-toggle/matcha-button-toggle.directive';\nexport * from './lib/matcha-bottom-sheet/bottom-sheet.directive';\nexport * from './lib/matcha-tabs/tabs.directive';\nexport * from './lib/matcha-badge/badge.directive';\nexport * from './lib/matcha-autocomplete/autocomplete-overview.directive';\nexport * from './lib/matcha-autocomplete/autocomplete.directive';\n"]}
|
|
101
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"public-api.js","sourceRoot":"","sources":["../../../projects/matcha-components/src/public-api.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Public API Surface of matcha-components\n */\n\n// -----------------------------------------------------------\n// COMPONENTS\n// -----------------------------------------------------------\n\n// // ATOMIC COMPONENTS\n// export * from './lib/matcha-button/matcha-button.component';\n\n// // BASE COMPONENT\n// export * from './lib/matcha-title/matcha-title.component';\n\n//\n// -----------------------------------------------------------\n// COMPONENTS\n// -----------------------------------------------------------\nexport * from './lib/matcha-button/button/button.component';\nexport * from './lib/matcha-card/card/card.component';\nexport * from './lib/matcha-divider/divider/divider.component';\nexport * from './lib/matcha-title/title/title.component';\nexport * from './lib/matcha-icon/icon.component';\nexport * from './lib/matcha-grid/grid.component';\nexport * from './lib/matcha-masonry/masonry/masonry.component';\nexport * from './lib/matcha-modal/modal-content/modal-content.component';\nexport * from './lib/matcha-modal/modal-header/modal-header.component';\nexport * from './lib/matcha-modal/modal-footer/modal-footer.component';\nexport * from './lib/matcha-modal/modal-options/modal-options.component';\nexport * from './lib/matcha-modal/modal/modal.component';\nexport * from './lib/matcha-menu/menu.component';\nexport * from './lib/matcha-tooltip/tooltip/tooltip.component';\n\n\n// -----------------------------------------------------------\n// MODULES\n// -----------------------------------------------------------\nexport * from './lib/matcha-modal/matcha-modal.module';\nexport * from './lib/matcha-card/card.module';\nexport * from './lib/matcha-masonry/masonry.module';\nexport * from './lib/matcha-title/title.module';\nexport * from './lib/matcha-button/button.module';\nexport * from './lib/matcha-tooltip/tooltip.module';\nexport * from './lib/matcha-divider/divider.module';\nexport * from './lib/matcha-elevation/elevation.module';\nexport * from './lib/matcha-grid/grid.module';\n\nexport * from './lib/matcha-components.module';\nexport * from './lib/matcha-autocomplete/autocomplete.module';\nexport * from './lib/matcha-badge/badge.module';\nexport * from './lib/matcha-tabs/tabs.module';\nexport * from './lib/matcha-bottom-sheet/bottom-sheet.module';\nexport * from './lib/matcha-button-toggle/button-toggle.module';\nexport * from './lib/matcha-checkbox/checkbox.module';\nexport * from './lib/matcha-chips/chips.module';\nexport * from './lib/matcha-datepicker/datepicker.module';\nexport * from './lib/matcha-expansion/expansion.module';\nexport * from './lib/matcha-forms/forms.module';\nexport * from './lib/matcha-icon/icon.module';\nexport * from './lib/matcha-input/input.module';\nexport * from './lib/matcha-list/list.module';\nexport * from './lib/matcha-menu/menu.module';\nexport * from './lib/matcha-sidenav/sidenav.module';\nexport * from './lib/matcha-paginator/paginator.module';\nexport * from './lib/matcha-progress-bar/progress-bar.module';\nexport * from './lib/matcha-progress-spinner/progress-spinner.module';\nexport * from './lib/matcha-radio-button/radio-button.module';\nexport * from './lib/matcha-select/select.module';\nexport * from './lib/matcha-slide-toggle/slide-toggle.module';\nexport * from './lib/matcha-slider/slider.module';\nexport * from './lib/matcha-snackbar/snack-bar.module';\nexport * from './lib/matcha-sort-header/sort-header.module';\nexport * from './lib/matcha-stepper/stepper.module';\nexport * from './lib/matcha-table/table.module';\nexport * from './lib/matcha-tree/tree.module';\n\n// -----------------------------------------------------------\n// DIRECTIVES\n// -----------------------------------------------------------\n\nexport * from './lib/matcha-tooltip/tooltip.directive';\n\nexport * from './lib/matcha-input/input.directive';\nexport * from './lib/matcha-tree/tree.directive';\nexport * from './lib/matcha-table/table.directive';\nexport * from './lib/matcha-stepper/stepper.directive';\nexport * from './lib/matcha-sort-header/sort-header.directive';\nexport * from './lib/matcha-snackbar/snack-bar.directive';\nexport * from './lib/matcha-slider/matcha-slider.directive';\nexport * from './lib/matcha-slide-toggle/slide-toggle.directive';\nexport * from './lib/matcha-select/select.directive';\nexport * from './lib/matcha-radio-button/matcha-radio-button.directive';\nexport * from './lib/matcha-progress-spinner/progress-spinner.directive';\nexport * from './lib/matcha-progress-bar/progress-bar.directive';\nexport * from './lib/matcha-paginator/paginator.directive';\nexport * from './lib/matcha-sidenav/sidenav.directive';\nexport * from './lib/matcha-menu/menu.directive';\nexport * from './lib/matcha-list/list.directive';\nexport * from './lib/matcha-forms/form-field.directive';\nexport * from './lib/matcha-expansion/expansion.directive';\nexport * from './lib/matcha-elevation/elevation.directive';\nexport * from './lib/matcha-datepicker/datepicker.directive';\nexport * from './lib/matcha-chips/matcha-chips.directive';\nexport * from './lib/matcha-checkbox/checkbox.directive';\nexport * from './lib/matcha-button-toggle/matcha-button-toggle.directive';\nexport * from './lib/matcha-bottom-sheet/bottom-sheet.directive';\nexport * from './lib/matcha-tabs/tabs.directive';\nexport * from './lib/matcha-badge/badge.directive';\nexport * from './lib/matcha-autocomplete/autocomplete-overview.directive';\nexport * from './lib/matcha-autocomplete/autocomplete.directive';\n"]}
|