matcha-components 18.0.47 → 18.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.
@@ -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(_elementRef, _renderer) {
5
- this._elementRef = _elementRef;
6
- this._renderer = _renderer;
7
- //this._elementRef.nativeElement.style.backgroundColor = 'grey';
8
- this._renderer.addClass(this._elementRef.nativeElement, 'matcha-tooltip');
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: "[matchaTooltip]", ngImport: i0 }); }
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: '[matchaTooltip]'
150
+ selector: '[matcha-tooltip]' // Usado como atributo
17
151
  }]
18
- }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }] });
19
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tYXRjaGEtY29tcG9uZW50cy9zcmMvbGliL21hdGNoYS10b29sdGlwL3Rvb2x0aXAuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQXlCLE1BQU0sZUFBZSxDQUFDOztBQUtqRSxNQUFNLE9BQU8sc0JBQXNCO0lBRS9CLFlBQ1ksV0FBdUIsRUFDdkIsU0FBb0I7UUFEcEIsZ0JBQVcsR0FBWCxXQUFXLENBQVk7UUFDdkIsY0FBUyxHQUFULFNBQVMsQ0FBVztRQUU1QixnRUFBZ0U7UUFDaEUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxhQUFhLEVBQUUsZ0JBQWdCLENBQUMsQ0FBQTtJQUM3RSxDQUFDOytHQVJRLHNCQUFzQjttR0FBdEIsc0JBQXNCOzs0RkFBdEIsc0JBQXNCO2tCQUhsQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxpQkFBaUI7aUJBQzVCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBSZW5kZXJlcjIgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW21hdGNoYVRvb2x0aXBdJ1xufSlcbmV4cG9ydCBjbGFzcyBNYXRjaGFUb29sdGlwRGlyZWN0aXZlIHtcblxuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBwcml2YXRlIF9lbGVtZW50UmVmOiBFbGVtZW50UmVmLFxuICAgICAgICBwcml2YXRlIF9yZW5kZXJlcjogUmVuZGVyZXIyXG4gICAgKSB7XG4gICAgICAgIC8vdGhpcy5fZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LnN0eWxlLmJhY2tncm91bmRDb2xvciA9ICdncmV5JztcbiAgICAgICAgdGhpcy5fcmVuZGVyZXIuYWRkQ2xhc3ModGhpcy5fZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LCAnbWF0Y2hhLXRvb2x0aXAnKVxuICAgIH1cblxufVxuIl19
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tYXRjaGEtY29tcG9uZW50cy9zcmMvbGliL21hdGNoYS10b29sdGlwL3Rvb2x0aXAubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLHFCQUFxQixDQUFDOztBQU83RCxNQUFNLE9BQU8sbUJBQW1COytHQUFuQixtQkFBbUI7Z0hBQW5CLG1CQUFtQixpQkFKYixzQkFBc0IsYUFDM0IsWUFBWSxhQUNaLHNCQUFzQjtnSEFFdkIsbUJBQW1CLFlBSGxCLFlBQVk7OzRGQUdiLG1CQUFtQjtrQkFML0IsUUFBUTttQkFBQztvQkFDTixZQUFZLEVBQUUsQ0FBQyxzQkFBc0IsQ0FBQztvQkFDdEMsT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDO29CQUN2QixPQUFPLEVBQUUsQ0FBQyxzQkFBc0IsQ0FBQztpQkFDcEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE1hdGNoYVRvb2x0aXBEaXJlY3RpdmUgfSBmcm9tICcuL3Rvb2x0aXAuZGlyZWN0aXZlJztcblxuQE5nTW9kdWxlKHtcbiAgICBkZWNsYXJhdGlvbnM6IFtNYXRjaGFUb29sdGlwRGlyZWN0aXZlXSxcbiAgICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcbiAgICBleHBvcnRzOiBbTWF0Y2hhVG9vbHRpcERpcmVjdGl2ZV0sXG59KVxuZXhwb3J0IGNsYXNzIE1hdGNoYVRvb2x0aXBNb2R1bGUge31cbiJdfQ==
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tYXRjaGEtY29tcG9uZW50cy9zcmMvbGliL21hdGNoYS10b29sdGlwL3Rvb2x0aXAubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQ3JFLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLHFCQUFxQixDQUFDOztBQU83RCxNQUFNLE9BQU8sbUJBQW1COytHQUFuQixtQkFBbUI7Z0hBQW5CLG1CQUFtQixpQkFKYixzQkFBc0IsRUFBRSxzQkFBc0IsYUFDbkQsWUFBWSxhQUNaLHNCQUFzQixFQUFFLHNCQUFzQjtnSEFFL0MsbUJBQW1CLFlBSGxCLFlBQVk7OzRGQUdiLG1CQUFtQjtrQkFML0IsUUFBUTttQkFBQztvQkFDTixZQUFZLEVBQUUsQ0FBQyxzQkFBc0IsRUFBRSxzQkFBc0IsQ0FBQztvQkFDOUQsT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDO29CQUN2QixPQUFPLEVBQUUsQ0FBQyxzQkFBc0IsRUFBRSxzQkFBc0IsQ0FBQztpQkFDNUQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE1hdGNoYVRvb2x0aXBDb21wb25lbnQgfSBmcm9tICcuL3Rvb2x0aXAvdG9vbHRpcC5jb21wb25lbnQnO1xuaW1wb3J0IHsgTWF0Y2hhVG9vbHRpcERpcmVjdGl2ZSB9IGZyb20gJy4vdG9vbHRpcC5kaXJlY3RpdmUnO1xuXG5ATmdNb2R1bGUoe1xuICAgIGRlY2xhcmF0aW9uczogW01hdGNoYVRvb2x0aXBDb21wb25lbnQsIE1hdGNoYVRvb2x0aXBEaXJlY3RpdmVdLFxuICAgIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxuICAgIGV4cG9ydHM6IFtNYXRjaGFUb29sdGlwQ29tcG9uZW50LCBNYXRjaGFUb29sdGlwRGlyZWN0aXZlXSxcbn0pXG5leHBvcnQgY2xhc3MgTWF0Y2hhVG9vbHRpcE1vZHVsZSB7fVxuIl19
@@ -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"]}