keevo-components 2.0.179 → 2.0.181
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/components/kv-icon/kv-icon.component.mjs +3 -3
- package/esm2022/lib/components/kv-table-draggable/kv-table-draggable.component.mjs +35 -35
- package/esm2022/lib/components/kv-tree-environment/components/kv-tree-environment/kv-tree-environment.component.mjs +134 -174
- package/esm2022/lib/components/kv-tree-environment/components/no-arvore/no-arvore.component.mjs +30 -46
- package/esm2022/lib/components/kv-tree-environment/models/no-arvore.model.mjs +1 -1
- package/esm2022/lib/components/kv-widget-card/kv-widget-card.component.mjs +3 -3
- package/fesm2022/keevo-components.mjs +231 -294
- package/fesm2022/keevo-components.mjs.map +1 -1
- package/lib/api/base-components/base-component-dropdown.d.ts +1 -1
- package/lib/components/kv-button/kv-button.component.d.ts +1 -1
- package/lib/components/kv-buttons/kv-button-popup/kv-button-popup.component.d.ts +1 -1
- package/lib/components/kv-stepper/kv-stepper.component.d.ts +2 -2
- package/lib/components/kv-table/kv-table.component.d.ts +1 -1
- package/lib/components/kv-table-draggable/kv-table-draggable.component.d.ts +1 -1
- package/lib/components/kv-table-expandable/kv-table-expandable.component.d.ts +1 -1
- package/lib/components/kv-table-viewer/kv-table-viewer.component.d.ts +1 -1
- package/lib/components/kv-tag/kv-tag.component.d.ts +1 -1
- package/lib/components/kv-tree-environment/components/kv-tree-environment/kv-tree-environment.component.d.ts +28 -31
- package/lib/components/kv-tree-environment/components/no-arvore/no-arvore.component.d.ts +14 -15
- package/lib/components/kv-tree-environment/models/no-arvore.model.d.ts +6 -4
- package/package.json +1 -1
|
@@ -1,13 +1,24 @@
|
|
|
1
1
|
import { CommonModule } from '@angular/common';
|
|
2
|
-
import { Component, input, signal, Output, EventEmitter,
|
|
2
|
+
import { ChangeDetectionStrategy, Component, input, signal, Output, EventEmitter, computed, ContentChild, effect } from '@angular/core';
|
|
3
3
|
import { NoArvoreComponent } from '../no-arvore/no-arvore.component';
|
|
4
4
|
import { ScrollingModule } from '@angular/cdk/scrolling';
|
|
5
5
|
import { PrimeNgModule } from '../../../../api/modules/primeng.module';
|
|
6
|
+
import { FormControl, FormGroup, FormsModule, ReactiveFormsModule } from "@angular/forms";
|
|
7
|
+
import { toSignal } from '@angular/core/rxjs-interop';
|
|
8
|
+
import { KeevoComponentsModule } from '../../../keevo-components.module';
|
|
6
9
|
import * as i0 from "@angular/core";
|
|
7
|
-
import * as i1 from "@angular/
|
|
8
|
-
import * as i2 from "
|
|
10
|
+
import * as i1 from "@angular/common";
|
|
11
|
+
import * as i2 from "@angular/cdk/scrolling";
|
|
12
|
+
import * as i3 from "primeng/api";
|
|
13
|
+
import * as i4 from "primeng/sidebar";
|
|
14
|
+
import * as i5 from "../../../kv-button/kv-button.component";
|
|
15
|
+
import * as i6 from "../../../kv-inputs/kv-input-text/kv-input-text.component";
|
|
16
|
+
import * as i7 from "@angular/forms";
|
|
9
17
|
export class KvTreeEnvironmentComponent {
|
|
10
18
|
constructor() {
|
|
19
|
+
this.onAddClick = new EventEmitter();
|
|
20
|
+
this.onSelectedItem = new EventEmitter();
|
|
21
|
+
this.onSidebarNodeClick = new EventEmitter();
|
|
11
22
|
this.arvoreDeDados = input([]);
|
|
12
23
|
this.nosSimples = input([]);
|
|
13
24
|
this.estruturaArvore = input([]);
|
|
@@ -15,128 +26,74 @@ export class KvTreeEnvironmentComponent {
|
|
|
15
26
|
this.configuracao = input({});
|
|
16
27
|
this.showButtonCollapsed = input(true);
|
|
17
28
|
this.showAddButton = input(true);
|
|
18
|
-
this.
|
|
19
|
-
this.
|
|
20
|
-
this.
|
|
21
|
-
this.mapaDeExpansao = new Map();
|
|
22
|
-
this._cachedDados = null;
|
|
23
|
-
this._dadosHash = null;
|
|
24
|
-
this._cachedListaPlana = null;
|
|
25
|
-
this._listaPlanaHash = null;
|
|
26
|
-
this.listaPlana = signal([]);
|
|
27
|
-
this.iconCollapsed = signal('collapse_all');
|
|
28
|
-
this.collapsedAll = signal(true);
|
|
29
|
+
this.showSearchField = input(false);
|
|
30
|
+
this.enableSidebar = input(false);
|
|
31
|
+
this.sidebarVisible = signal(false);
|
|
29
32
|
this.selectedItem = signal(null);
|
|
30
|
-
|
|
33
|
+
this.currentSidebarNode = signal(null);
|
|
34
|
+
this.expansaoState = signal(new Map());
|
|
35
|
+
this.formFiltro = new FormGroup({
|
|
36
|
+
search: new FormControl('')
|
|
37
|
+
});
|
|
38
|
+
this.searchValue = toSignal(this.formFiltro.get('search').valueChanges, { initialValue: '' });
|
|
39
|
+
this.dadosProcessados = computed(() => {
|
|
31
40
|
const estrutura = this.estruturaArvore();
|
|
32
41
|
const dados = this.dadosArvore();
|
|
33
42
|
const simples = this.nosSimples();
|
|
34
43
|
const arvore = this.arvoreDeDados();
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
this._dadosHash = dadosHash;
|
|
38
|
-
this.invalidarCache();
|
|
39
|
-
const temDados = estrutura.length > 0 || dados.length > 0 || simples.length > 0 || arvore.length > 0;
|
|
40
|
-
if (temDados) {
|
|
41
|
-
this.gerarListaPlanaOtimizada();
|
|
42
|
-
this.atualizarEstadoCollapseButton();
|
|
43
|
-
}
|
|
44
|
-
else {
|
|
45
|
-
this.listaPlana.set([]);
|
|
46
|
-
}
|
|
44
|
+
if (estrutura && estrutura.length > 0) {
|
|
45
|
+
return this.combinarEstruturaComDados(estrutura, dados || []);
|
|
47
46
|
}
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
47
|
+
else if (simples && simples.length > 0) {
|
|
48
|
+
return this.converterSimplesParaCompleto(simples);
|
|
49
|
+
}
|
|
50
|
+
else {
|
|
51
|
+
return arvore;
|
|
52
|
+
}
|
|
53
|
+
});
|
|
54
|
+
this.dadosFiltrados = computed(() => {
|
|
55
|
+
const search = this.searchValue()?.trim().toLowerCase() || '';
|
|
56
|
+
const dados = this.dadosProcessados();
|
|
57
|
+
if (!search) {
|
|
58
|
+
return dados;
|
|
59
|
+
}
|
|
60
|
+
return this.filtrarArvoreComHierarquia(dados, search);
|
|
61
|
+
});
|
|
62
|
+
this.listaPlana = computed(() => {
|
|
63
|
+
const dados = this.dadosFiltrados();
|
|
64
|
+
const expansaoMap = this.expansaoState();
|
|
65
|
+
return this.transformarParaListaPlana(dados, expansaoMap, 0);
|
|
66
|
+
});
|
|
67
|
+
this.iconCollapsed = computed(() => {
|
|
68
|
+
const nosExpandiveis = this.obterTodosNosExpandiveis(this.dadosProcessados());
|
|
69
|
+
const expansaoMap = this.expansaoState();
|
|
70
|
+
const algumExpandido = nosExpandiveis.some(node => expansaoMap.get(node.rotulo) ?? (node.expanded ?? false));
|
|
71
|
+
return algumExpandido ? 'collapse_all' : 'expand_content';
|
|
72
|
+
});
|
|
73
|
+
this.collapsedAll = computed(() => {
|
|
74
|
+
return this.iconCollapsed() === 'expand_content';
|
|
75
|
+
});
|
|
76
|
+
effect(() => {
|
|
77
|
+
const search = this.searchValue()?.trim().toLowerCase();
|
|
78
|
+
const dados = this.dadosFiltrados();
|
|
79
|
+
if (search) {
|
|
80
|
+
this.expandirTodosNos(dados);
|
|
81
|
+
}
|
|
82
|
+
});
|
|
53
83
|
}
|
|
54
84
|
alternarNo(noPlano) {
|
|
55
85
|
if (!noPlano.expansivel)
|
|
56
86
|
return;
|
|
57
|
-
const
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
forcarAtualizacaoLista() {
|
|
62
|
-
this._cachedListaPlana = null;
|
|
63
|
-
this._listaPlanaHash = null;
|
|
64
|
-
const dados = this.obterDadosOtimizado();
|
|
65
|
-
const novaListaPlana = this.transformarParaListaPlanaOtimizada(dados);
|
|
66
|
-
this.listaPlana.set(novaListaPlana);
|
|
67
|
-
this.cdr.detectChanges();
|
|
68
|
-
setTimeout(() => {
|
|
69
|
-
const expansaoHash = Array.from(this.mapaDeExpansao.entries())
|
|
70
|
-
.sort(([a], [b]) => a.localeCompare(b))
|
|
71
|
-
.map(([k, v]) => `${k}:${v}`)
|
|
72
|
-
.join(',');
|
|
73
|
-
this._listaPlanaHash = `${this._dadosHash}:${expansaoHash}`;
|
|
74
|
-
this._cachedListaPlana = novaListaPlana;
|
|
75
|
-
this.cdr.detectChanges();
|
|
76
|
-
this.atualizarEstadoCollapseButton();
|
|
77
|
-
}, 0);
|
|
78
|
-
}
|
|
79
|
-
criarHashDados(estrutura, dados, simples, arvore) {
|
|
80
|
-
const estruturaHash = `e:${estrutura.length}:${estrutura.map(e => `${e.id}:${e.label}`).join(',')}`;
|
|
81
|
-
const dadosHash = `d:${dados.length}:${dados.map(d => `${d.id}`).join(',')}`;
|
|
82
|
-
const simplesHash = `s:${simples.length}:${simples.map(s => s.key).join(',')}`;
|
|
83
|
-
const arvoreHash = `a:${arvore.length}:${arvore.map(a => a.rotulo).join(',')}`;
|
|
84
|
-
return `${estruturaHash}|${dadosHash}|${simplesHash}|${arvoreHash}`;
|
|
85
|
-
}
|
|
86
|
-
invalidarCache() {
|
|
87
|
-
this._cachedDados = null;
|
|
88
|
-
this._cachedListaPlana = null;
|
|
89
|
-
this._listaPlanaHash = null;
|
|
90
|
-
}
|
|
91
|
-
gerarListaPlanaOtimizada() {
|
|
92
|
-
const dados = this.obterDadosOtimizado();
|
|
93
|
-
const expansaoHash = Array.from(this.mapaDeExpansao.entries())
|
|
94
|
-
.sort(([a], [b]) => a.localeCompare(b))
|
|
95
|
-
.map(([k, v]) => `${k}:${v}`)
|
|
96
|
-
.join(',');
|
|
97
|
-
const listaPlanaHash = `${this._dadosHash}:${expansaoHash}`;
|
|
98
|
-
if (this._listaPlanaHash === listaPlanaHash && this._cachedListaPlana) {
|
|
99
|
-
this.listaPlana.set(this._cachedListaPlana);
|
|
100
|
-
return;
|
|
101
|
-
}
|
|
102
|
-
const novaListaPlana = this.transformarParaListaPlanaOtimizada(dados);
|
|
103
|
-
this._cachedListaPlana = novaListaPlana;
|
|
104
|
-
this._listaPlanaHash = listaPlanaHash;
|
|
105
|
-
this.listaPlana.set(novaListaPlana);
|
|
87
|
+
const novoMapa = new Map(this.expansaoState());
|
|
88
|
+
const estadoAtual = novoMapa.get(noPlano.dadosOriginais.rotulo) ?? (noPlano.dadosOriginais.expanded ?? false);
|
|
89
|
+
novoMapa.set(noPlano.dadosOriginais.rotulo, !estadoAtual);
|
|
90
|
+
this.expansaoState.set(novoMapa);
|
|
106
91
|
}
|
|
107
92
|
onActionExecuted(noPlano) {
|
|
108
93
|
const dados = noPlano.dadosOriginais;
|
|
109
94
|
this.selectedItem.set(dados);
|
|
110
95
|
this.onSelectedItem.emit(dados);
|
|
111
96
|
}
|
|
112
|
-
gerarListaPlana() {
|
|
113
|
-
this.gerarListaPlanaOtimizada();
|
|
114
|
-
}
|
|
115
|
-
obterDadosOtimizado() {
|
|
116
|
-
if (this._cachedDados && this._dadosHash) {
|
|
117
|
-
return this._cachedDados;
|
|
118
|
-
}
|
|
119
|
-
const estrutura = this.estruturaArvore();
|
|
120
|
-
const dados = this.dadosArvore();
|
|
121
|
-
let resultado;
|
|
122
|
-
if (estrutura && estrutura.length > 0) {
|
|
123
|
-
resultado = this.combinarEstruturaComDados(estrutura, dados || []);
|
|
124
|
-
}
|
|
125
|
-
else {
|
|
126
|
-
const nosSimples = this.nosSimples();
|
|
127
|
-
if (nosSimples && nosSimples.length > 0) {
|
|
128
|
-
resultado = this.converterSimplesParaCompleto(nosSimples);
|
|
129
|
-
}
|
|
130
|
-
else {
|
|
131
|
-
resultado = this.arvoreDeDados();
|
|
132
|
-
}
|
|
133
|
-
}
|
|
134
|
-
this._cachedDados = resultado;
|
|
135
|
-
return resultado;
|
|
136
|
-
}
|
|
137
|
-
obterDados() {
|
|
138
|
-
return this.obterDadosOtimizado();
|
|
139
|
-
}
|
|
140
97
|
converterSimplesParaCompleto(nosSimples) {
|
|
141
98
|
const mapa = new Map();
|
|
142
99
|
const raiz = [];
|
|
@@ -146,7 +103,7 @@ export class KvTreeEnvironmentComponent {
|
|
|
146
103
|
icone: simples.icone,
|
|
147
104
|
cor: simples.cor,
|
|
148
105
|
ativo: simples.ativo,
|
|
149
|
-
|
|
106
|
+
expanded: simples.expanded,
|
|
150
107
|
filhos: []
|
|
151
108
|
};
|
|
152
109
|
mapa.set(simples.key, no);
|
|
@@ -168,26 +125,23 @@ export class KvTreeEnvironmentComponent {
|
|
|
168
125
|
});
|
|
169
126
|
return raiz;
|
|
170
127
|
}
|
|
171
|
-
transformarParaListaPlana(nodes, nivel = 0) {
|
|
172
|
-
return this.transformarParaListaPlanaOtimizada(nodes, nivel);
|
|
173
|
-
}
|
|
174
|
-
transformarParaListaPlanaOtimizada(nodes, nivel = 0) {
|
|
128
|
+
transformarParaListaPlana(nodes, expansaoMap, nivel = 0) {
|
|
175
129
|
const lista = [];
|
|
176
130
|
nodes.forEach((node, index) => {
|
|
177
131
|
const rotulo = node.rotulo;
|
|
178
|
-
const
|
|
132
|
+
const expanded = expansaoMap.get(rotulo) ?? (node.expanded ?? false);
|
|
179
133
|
const temFilhos = !!(node.filhos && node.filhos.length > 0);
|
|
180
134
|
const noPlano = {
|
|
181
135
|
id: rotulo,
|
|
182
136
|
nivel: nivel,
|
|
183
137
|
expansivel: temFilhos,
|
|
184
|
-
|
|
138
|
+
expanded: expanded,
|
|
185
139
|
isLast: index === nodes.length - 1,
|
|
186
140
|
dadosOriginais: node
|
|
187
141
|
};
|
|
188
142
|
lista.push(noPlano);
|
|
189
|
-
if (
|
|
190
|
-
const filhosPlanos = this.
|
|
143
|
+
if (expanded && temFilhos) {
|
|
144
|
+
const filhosPlanos = this.transformarParaListaPlana(node.filhos, expansaoMap, nivel + 1);
|
|
191
145
|
lista.push(...filhosPlanos);
|
|
192
146
|
}
|
|
193
147
|
});
|
|
@@ -196,72 +150,50 @@ export class KvTreeEnvironmentComponent {
|
|
|
196
150
|
trackByNode(index, noPlano) {
|
|
197
151
|
return noPlano.id;
|
|
198
152
|
}
|
|
199
|
-
executeCollapsed() {
|
|
200
|
-
const todosColapsados = this.collapsedAll();
|
|
201
|
-
if (todosColapsados) {
|
|
202
|
-
this.expandirTodosOtimizado();
|
|
203
|
-
}
|
|
204
|
-
else {
|
|
205
|
-
this.colapsarTodosOtimizado();
|
|
206
|
-
}
|
|
207
|
-
this.forcarAtualizacaoLista();
|
|
208
|
-
}
|
|
209
153
|
expandirTodos() {
|
|
210
|
-
this.
|
|
154
|
+
const novoMapa = new Map(this.expansaoState());
|
|
155
|
+
this.expandirTodosNos(this.dadosProcessados(), novoMapa);
|
|
156
|
+
this.expansaoState.set(novoMapa);
|
|
211
157
|
}
|
|
212
158
|
colapsarTodos() {
|
|
213
|
-
this.
|
|
159
|
+
const novoMapa = new Map(this.expansaoState());
|
|
160
|
+
this.colapsarTodosNos(this.dadosProcessados(), novoMapa);
|
|
161
|
+
this.expansaoState.set(novoMapa);
|
|
214
162
|
}
|
|
215
|
-
|
|
216
|
-
const
|
|
217
|
-
const stack = [...
|
|
163
|
+
expandirTodosNos(nodes, mapa) {
|
|
164
|
+
const mapaDeExpansao = mapa || new Map(this.expansaoState());
|
|
165
|
+
const stack = [...nodes];
|
|
218
166
|
while (stack.length > 0) {
|
|
219
167
|
const node = stack.pop();
|
|
220
168
|
if (node.filhos && node.filhos.length > 0) {
|
|
221
|
-
|
|
169
|
+
mapaDeExpansao.set(node.rotulo, true);
|
|
222
170
|
stack.push(...node.filhos);
|
|
223
171
|
}
|
|
224
172
|
}
|
|
173
|
+
if (!mapa) {
|
|
174
|
+
this.expansaoState.set(mapaDeExpansao);
|
|
175
|
+
}
|
|
225
176
|
}
|
|
226
|
-
|
|
227
|
-
const
|
|
228
|
-
const stack = [...dados];
|
|
177
|
+
colapsarTodosNos(nodes, mapa) {
|
|
178
|
+
const stack = [...nodes];
|
|
229
179
|
while (stack.length > 0) {
|
|
230
180
|
const node = stack.pop();
|
|
231
181
|
if (node.filhos && node.filhos.length > 0) {
|
|
232
|
-
|
|
182
|
+
mapa.set(node.rotulo, false);
|
|
233
183
|
stack.push(...node.filhos);
|
|
234
184
|
}
|
|
235
185
|
}
|
|
236
186
|
}
|
|
237
|
-
|
|
238
|
-
nodes.forEach(node => {
|
|
239
|
-
callback(node);
|
|
240
|
-
if (node.filhos && node.filhos.length > 0) {
|
|
241
|
-
this.percorrerTodosNos(node.filhos, callback);
|
|
242
|
-
}
|
|
243
|
-
});
|
|
244
|
-
}
|
|
245
|
-
atualizarEstadoCollapseButton() {
|
|
246
|
-
const nosExpandiveis = this.obterTodosNosExpandiveis();
|
|
247
|
-
const nosExpandidos = nosExpandiveis.filter(node => this.mapaDeExpansao.get(node.rotulo) ?? (node.estaExpandido ?? false));
|
|
248
|
-
const todosFechados = nosExpandidos.length === 0;
|
|
249
|
-
if (todosFechados) {
|
|
250
|
-
this.collapsedAll.set(true);
|
|
251
|
-
this.iconCollapsed.set('expand_content');
|
|
252
|
-
}
|
|
253
|
-
else {
|
|
254
|
-
this.collapsedAll.set(false);
|
|
255
|
-
this.iconCollapsed.set('collapse_all');
|
|
256
|
-
}
|
|
257
|
-
}
|
|
258
|
-
obterTodosNosExpandiveis() {
|
|
187
|
+
obterTodosNosExpandiveis(nodes) {
|
|
259
188
|
const nosExpandiveis = [];
|
|
260
|
-
|
|
189
|
+
const stack = [...nodes];
|
|
190
|
+
while (stack.length > 0) {
|
|
191
|
+
const node = stack.pop();
|
|
261
192
|
if (node.filhos && node.filhos.length > 0) {
|
|
262
193
|
nosExpandiveis.push(node);
|
|
194
|
+
stack.push(...node.filhos);
|
|
263
195
|
}
|
|
264
|
-
}
|
|
196
|
+
}
|
|
265
197
|
return nosExpandiveis;
|
|
266
198
|
}
|
|
267
199
|
combinarEstruturaComDados(estrutura, dados) {
|
|
@@ -277,10 +209,11 @@ export class KvTreeEnvironmentComponent {
|
|
|
277
209
|
icone: est.icone,
|
|
278
210
|
cor: est.cor,
|
|
279
211
|
ativo: dado?.ativo ?? true,
|
|
280
|
-
|
|
212
|
+
expanded: est.expanded,
|
|
281
213
|
filhos: [],
|
|
282
214
|
actions: est.actions,
|
|
283
|
-
data: est.data
|
|
215
|
+
data: est.data,
|
|
216
|
+
showSidebarAction: est.showSidebarAction
|
|
284
217
|
};
|
|
285
218
|
mapaEstrutura.set(est.id, no);
|
|
286
219
|
});
|
|
@@ -301,26 +234,53 @@ export class KvTreeEnvironmentComponent {
|
|
|
301
234
|
executeAdd() {
|
|
302
235
|
this.onAddClick.emit();
|
|
303
236
|
}
|
|
304
|
-
|
|
305
|
-
this.
|
|
306
|
-
this.
|
|
307
|
-
this.
|
|
308
|
-
|
|
237
|
+
abrirSidebarParaNo(no) {
|
|
238
|
+
this.currentSidebarNode.set(no);
|
|
239
|
+
this.sidebarVisible.set(true);
|
|
240
|
+
this.onSidebarNodeClick.emit(no);
|
|
241
|
+
}
|
|
242
|
+
filtrarArvoreComHierarquia(nodes, textoBusca) {
|
|
243
|
+
const resultado = [];
|
|
244
|
+
for (const node of nodes) {
|
|
245
|
+
const rotuloLower = node.rotulo.toLowerCase();
|
|
246
|
+
const corresponde = rotuloLower.includes(textoBusca);
|
|
247
|
+
let filhosFiltrados = [];
|
|
248
|
+
if (node.filhos && node.filhos.length > 0) {
|
|
249
|
+
filhosFiltrados = this.filtrarArvoreComHierarquia(node.filhos, textoBusca);
|
|
250
|
+
}
|
|
251
|
+
if (corresponde || filhosFiltrados.length > 0) {
|
|
252
|
+
const noClonado = {
|
|
253
|
+
...node,
|
|
254
|
+
filhos: filhosFiltrados.length > 0 ? filhosFiltrados : node.filhos,
|
|
255
|
+
expanded: true
|
|
256
|
+
};
|
|
257
|
+
resultado.push(noClonado);
|
|
258
|
+
}
|
|
259
|
+
}
|
|
260
|
+
return resultado;
|
|
309
261
|
}
|
|
310
262
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvTreeEnvironmentComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
311
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.
|
|
263
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: KvTreeEnvironmentComponent, isStandalone: true, selector: "kv-tree-environment", inputs: { arvoreDeDados: { classPropertyName: "arvoreDeDados", publicName: "arvoreDeDados", isSignal: true, isRequired: false, transformFunction: null }, nosSimples: { classPropertyName: "nosSimples", publicName: "nosSimples", isSignal: true, isRequired: false, transformFunction: null }, estruturaArvore: { classPropertyName: "estruturaArvore", publicName: "estruturaArvore", isSignal: true, isRequired: false, transformFunction: null }, dadosArvore: { classPropertyName: "dadosArvore", publicName: "dadosArvore", isSignal: true, isRequired: false, transformFunction: null }, configuracao: { classPropertyName: "configuracao", publicName: "configuracao", isSignal: true, isRequired: false, transformFunction: null }, showButtonCollapsed: { classPropertyName: "showButtonCollapsed", publicName: "showButtonCollapsed", isSignal: true, isRequired: false, transformFunction: null }, showAddButton: { classPropertyName: "showAddButton", publicName: "showAddButton", isSignal: true, isRequired: false, transformFunction: null }, showSearchField: { classPropertyName: "showSearchField", publicName: "showSearchField", isSignal: true, isRequired: false, transformFunction: null }, enableSidebar: { classPropertyName: "enableSidebar", publicName: "enableSidebar", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { onAddClick: "onAddClick", onSelectedItem: "onSelectedItem", onSidebarNodeClick: "onSidebarNodeClick" }, queries: [{ propertyName: "sidebarTemplate", first: true, predicate: ["sidebar"], descendants: true }], ngImport: i0, template: "<div class=\"flex flex-column h-full\">\n <div class=\"flex flex-row gap-2 p-2\" [formGroup]=\"formFiltro\">\n @if(showSearchField()) {\n <kv-input-text\n placeholder=\"Pesquisar...\"\n icon=\"search\"\n formControlName=\"search\"\n ></kv-input-text>\n }\n\n <kv-button\n severity=\"tertiary\"\n class=\"w-auto\"\n label=\"Expandir\"\n icon=\"expand_content\"\n (click)=\"expandirTodos()\"\n ></kv-button>\n\n <kv-button\n severity=\"tertiary\"\n class=\"w-auto\"\n label=\"Recolher\"\n icon=\"collapse_all\"\n (click)=\"colapsarTodos()\"\n ></kv-button>\n </div>\n\n <div class=\"pl-2 pb-2 flex-1 w-full flex flex-row items-center gap-2\" style=\"min-height: 0; position: relative;\">\n <cdk-virtual-scroll-viewport class=\"h-full flex-1\" itemSize=\"40\">\n <ul class=\"lista-arvore-virtual pr-2 py-2\">\n <no-arvore \n *cdkVirtualFor=\"let no of listaPlana(); trackBy: trackByNode\" \n [noPlano]=\"no\"\n [enableSidebar]=\"enableSidebar()\"\n (noAlternado)=\"alternarNo($event)\"\n (actionExecuted)=\"onActionExecuted($event)\"\n (sidebarClick)=\"abrirSidebarParaNo($event)\" />\n </ul>\n </cdk-virtual-scroll-viewport>\n\n @if (sidebarVisible() && enableSidebar()) {\n <kv-button\n severity=\"tertiary\"\n icon=\"menu\"\n (click)=\"sidebarVisible.set(false)\"\n ></kv-button>\n }\n\n <p-sidebar [visible]=\"sidebarVisible()\" (visibleChange)=\"sidebarVisible.set($event)\" position=\"right\" class=\"pr-2\" [ngStyle]=\"{'flex': '0.6 1 0%'}\" styleClass=\"w-full\">\n <ng-template pTemplate=\"headless\">\n @if (sidebarTemplate && currentSidebarNode()) {\n <ng-container [ngTemplateOutlet]=\"sidebarTemplate\" [ngTemplateOutletContext]=\"{ $implicit: currentSidebarNode() }\"></ng-container>\n }\n </ng-template>\n </p-sidebar>\n </div>\n</div>\n", styles: [".grid-container{display:grid;grid-template-columns:auto 1fr;align-items:start}.lista-arvore-virtual{list-style:none;padding:0;margin:0}::ng-deep .p-component-overlay{display:none}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: NoArvoreComponent, selector: "no-arvore", inputs: ["noPlano", "enableSidebar"], outputs: ["noAlternado", "actionExecuted", "sidebarClick"] }, { kind: "ngmodule", type: ScrollingModule }, { kind: "directive", type: i2.CdkFixedSizeVirtualScroll, selector: "cdk-virtual-scroll-viewport[itemSize]", inputs: ["itemSize", "minBufferPx", "maxBufferPx"] }, { kind: "directive", type: i2.CdkVirtualForOf, selector: "[cdkVirtualFor][cdkVirtualForOf]", inputs: ["cdkVirtualForOf", "cdkVirtualForTrackBy", "cdkVirtualForTemplate", "cdkVirtualForTemplateCacheSize"] }, { kind: "component", type: i2.CdkVirtualScrollViewport, selector: "cdk-virtual-scroll-viewport", inputs: ["orientation", "appendOnly"], outputs: ["scrolledIndexChange"] }, { kind: "ngmodule", type: PrimeNgModule }, { kind: "directive", type: i3.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "component", type: i4.Sidebar, selector: "p-sidebar", inputs: ["appendTo", "blockScroll", "style", "styleClass", "ariaCloseLabel", "autoZIndex", "baseZIndex", "modal", "dismissible", "showCloseIcon", "closeOnEscape", "transitionOptions", "visible", "position", "fullScreen"], outputs: ["onShow", "onHide", "visibleChange"] }, { kind: "ngmodule", type: KeevoComponentsModule }, { kind: "component", type: i5.KvButtonComponent, selector: "kv-button", inputs: ["fullWidth", "type", "loading", "severity", "size", "icon", "iconPosition", "label", "disabled", "items", "popup", "popupIcon"], outputs: ["iconChange", "onClick"] }, { kind: "component", type: i6.KvInputTextComponent, selector: "kv-input-text", inputs: ["textCaptalized"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i7.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i7.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i7.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
312
264
|
}
|
|
313
265
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvTreeEnvironmentComponent, decorators: [{
|
|
314
266
|
type: Component,
|
|
315
|
-
args: [{ standalone: true, selector: 'kv-tree-environment', imports: [
|
|
267
|
+
args: [{ standalone: true, selector: 'kv-tree-environment', changeDetection: ChangeDetectionStrategy.OnPush, imports: [
|
|
316
268
|
CommonModule,
|
|
317
269
|
NoArvoreComponent,
|
|
318
270
|
ScrollingModule,
|
|
319
|
-
PrimeNgModule
|
|
320
|
-
|
|
271
|
+
PrimeNgModule,
|
|
272
|
+
KeevoComponentsModule,
|
|
273
|
+
FormsModule,
|
|
274
|
+
ReactiveFormsModule
|
|
275
|
+
], template: "<div class=\"flex flex-column h-full\">\n <div class=\"flex flex-row gap-2 p-2\" [formGroup]=\"formFiltro\">\n @if(showSearchField()) {\n <kv-input-text\n placeholder=\"Pesquisar...\"\n icon=\"search\"\n formControlName=\"search\"\n ></kv-input-text>\n }\n\n <kv-button\n severity=\"tertiary\"\n class=\"w-auto\"\n label=\"Expandir\"\n icon=\"expand_content\"\n (click)=\"expandirTodos()\"\n ></kv-button>\n\n <kv-button\n severity=\"tertiary\"\n class=\"w-auto\"\n label=\"Recolher\"\n icon=\"collapse_all\"\n (click)=\"colapsarTodos()\"\n ></kv-button>\n </div>\n\n <div class=\"pl-2 pb-2 flex-1 w-full flex flex-row items-center gap-2\" style=\"min-height: 0; position: relative;\">\n <cdk-virtual-scroll-viewport class=\"h-full flex-1\" itemSize=\"40\">\n <ul class=\"lista-arvore-virtual pr-2 py-2\">\n <no-arvore \n *cdkVirtualFor=\"let no of listaPlana(); trackBy: trackByNode\" \n [noPlano]=\"no\"\n [enableSidebar]=\"enableSidebar()\"\n (noAlternado)=\"alternarNo($event)\"\n (actionExecuted)=\"onActionExecuted($event)\"\n (sidebarClick)=\"abrirSidebarParaNo($event)\" />\n </ul>\n </cdk-virtual-scroll-viewport>\n\n @if (sidebarVisible() && enableSidebar()) {\n <kv-button\n severity=\"tertiary\"\n icon=\"menu\"\n (click)=\"sidebarVisible.set(false)\"\n ></kv-button>\n }\n\n <p-sidebar [visible]=\"sidebarVisible()\" (visibleChange)=\"sidebarVisible.set($event)\" position=\"right\" class=\"pr-2\" [ngStyle]=\"{'flex': '0.6 1 0%'}\" styleClass=\"w-full\">\n <ng-template pTemplate=\"headless\">\n @if (sidebarTemplate && currentSidebarNode()) {\n <ng-container [ngTemplateOutlet]=\"sidebarTemplate\" [ngTemplateOutletContext]=\"{ $implicit: currentSidebarNode() }\"></ng-container>\n }\n </ng-template>\n </p-sidebar>\n </div>\n</div>\n", styles: [".grid-container{display:grid;grid-template-columns:auto 1fr;align-items:start}.lista-arvore-virtual{list-style:none;padding:0;margin:0}::ng-deep .p-component-overlay{display:none}\n"] }]
|
|
321
276
|
}], ctorParameters: () => [], propDecorators: { onAddClick: [{
|
|
322
277
|
type: Output
|
|
323
278
|
}], onSelectedItem: [{
|
|
324
279
|
type: Output
|
|
280
|
+
}], onSidebarNodeClick: [{
|
|
281
|
+
type: Output
|
|
282
|
+
}], sidebarTemplate: [{
|
|
283
|
+
type: ContentChild,
|
|
284
|
+
args: ['sidebar']
|
|
325
285
|
}] } });
|
|
326
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-tree-environment.component.js","sourceRoot":"","sources":["../../../../../../../../projects/keevo-components/src/lib/components/kv-tree-environment/components/kv-tree-environment/kv-tree-environment.component.ts","../../../../../../../../projects/keevo-components/src/lib/components/kv-tree-environment/components/kv-tree-environment/kv-tree-environment.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,EAAa,iBAAiB,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAC7H,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AAErE,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AACzD,OAAO,EAAE,aAAa,EAAE,MAAM,wCAAwC,CAAC;;;;AAcvE,MAAM,OAAO,0BAA0B;IA4BrC;QA1BA,kBAAa,GAAG,KAAK,CAAa,EAAE,CAAC,CAAC;QACtC,eAAU,GAAG,KAAK,CAAoB,EAAE,CAAC,CAAC;QAC1C,oBAAe,GAAG,KAAK,CAErB,EAAE,CAAC,CAAC;QACN,gBAAW,GAAG,KAAK,CAAgB,EAAE,CAAC,CAAC;QACvC,iBAAY,GAAG,KAAK,CAAsB,EAAE,CAAC,CAAC;QAC9C,wBAAmB,GAAG,KAAK,CAAU,IAAI,CAAC,CAAC;QAC3C,kBAAa,GAAG,KAAK,CAAU,IAAI,CAAC,CAAC;QAE3B,eAAU,GAAG,IAAI,YAAY,EAAQ,CAAC;QACtC,mBAAc,GAAG,IAAI,YAAY,EAAO,CAAC;QAE3C,QAAG,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QAChC,mBAAc,GAAG,IAAI,GAAG,EAAmB,CAAC;QAE5C,iBAAY,GAAsB,IAAI,CAAC;QACvC,eAAU,GAAkB,IAAI,CAAC;QACjC,sBAAiB,GAAqB,IAAI,CAAC;QAC3C,oBAAe,GAAkB,IAAI,CAAC;QAE9C,eAAU,GAAG,MAAM,CAAY,EAAE,CAAC,CAAC;QACnC,kBAAa,GAAG,MAAM,CAAS,cAAc,CAAC,CAAC;QAC/C,iBAAY,GAAG,MAAM,CAAU,IAAI,CAAC,CAAC;QACrC,iBAAY,GAAG,MAAM,CAAM,IAAI,CAAC,CAAC;QAG/B,MAAM,CAAC,GAAG,EAAE;YACV,MAAM,SAAS,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;YACzC,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;YACjC,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;YAClC,MAAM,MAAM,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC;YAEpC,MAAM,SAAS,GAAG,IAAI,CAAC,cAAc,CAAC,SAAS,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC;YAEzE,IAAI,IAAI,CAAC,UAAU,KAAK,SAAS,EAAE,CAAC;gBAClC,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;gBAC5B,IAAI,CAAC,cAAc,EAAE,CAAC;gBAEtB,MAAM,QAAQ,GAAG,SAAS,CAAC,MAAM,GAAG,CAAC,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC;gBAErG,IAAI,QAAQ,EAAE,CAAC;oBACb,IAAI,CAAC,wBAAwB,EAAE,CAAC;oBAChC,IAAI,CAAC,6BAA6B,EAAE,CAAC;gBACvC,CAAC;qBAAM,CAAC;oBACN,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;gBAC1B,CAAC;YACH,CAAC;QACH,CAAC,EAAE,EAAE,iBAAiB,EAAE,IAAI,EAAE,CAAC,CAAC;IAClC,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,eAAe,EAAE,CAAC;QACvB,IAAI,CAAC,6BAA6B,EAAE,CAAC;IACvC,CAAC;IAED,UAAU,CAAC,OAAgB;QACzB,IAAI,CAAC,OAAO,CAAC,UAAU;YAAE,OAAO;QAEhC,MAAM,WAAW,GAAG,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,OAAO,CAAC,cAAc,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC;QACpF,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,OAAO,CAAC,cAAc,CAAC,MAAM,EAAE,CAAC,WAAW,CAAC,CAAC;QAErE,IAAI,CAAC,sBAAsB,EAAE,CAAC;IAChC,CAAC;IAEO,sBAAsB;QAC5B,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;QAC9B,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;QAE5B,MAAM,KAAK,GAAG,IAAI,CAAC,mBAAmB,EAAE,CAAC;QACzC,MAAM,cAAc,GAAG,IAAI,CAAC,kCAAkC,CAAC,KAAK,CAAC,CAAC;QAEtE,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;QAEpC,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QAEzB,UAAU,CAAC,GAAG,EAAE;YACd,MAAM,YAAY,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,CAAC;iBAC3D,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;iBACtC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC;iBAC5B,IAAI,CAAC,GAAG,CAAC,CAAC;YAEb,IAAI,CAAC,eAAe,GAAG,GAAG,IAAI,CAAC,UAAU,IAAI,YAAY,EAAE,CAAC;YAC5D,IAAI,CAAC,iBAAiB,GAAG,cAAc,CAAC;YAExC,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;YACzB,IAAI,CAAC,6BAA6B,EAAE,CAAC;QACvC,CAAC,EAAE,CAAC,CAAC,CAAC;IACR,CAAC;IAEO,cAAc,CAAC,SAA4B,EAAE,KAAoB,EAAE,OAA0B,EAAE,MAAkB;QACvH,MAAM,aAAa,GAAG,KAAK,SAAS,CAAC,MAAM,IAAI,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC;QACpG,MAAM,SAAS,GAAG,KAAK,KAAK,CAAC,MAAM,IAAI,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC;QAC7E,MAAM,WAAW,GAAG,KAAK,OAAO,CAAC,MAAM,IAAI,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC;QAC/E,MAAM,UAAU,GAAG,KAAK,MAAM,CAAC,MAAM,IAAI,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC;QAE/E,OAAO,GAAG,aAAa,IAAI,SAAS,IAAI,WAAW,IAAI,UAAU,EAAE,CAAC;IACtE,CAAC;IAEO,cAAc;QACpB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QACzB,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;QAC9B,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;IAC9B,CAAC;IAEO,wBAAwB;QAC9B,MAAM,KAAK,GAAG,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAEzC,MAAM,YAAY,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,CAAC;aAC3D,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;aACtC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC;aAC5B,IAAI,CAAC,GAAG,CAAC,CAAC;QAEb,MAAM,cAAc,GAAG,GAAG,IAAI,CAAC,UAAU,IAAI,YAAY,EAAE,CAAC;QAE5D,IAAI,IAAI,CAAC,eAAe,KAAK,cAAc,IAAI,IAAI,CAAC,iBAAiB,EAAE,CAAC;YACtE,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;YAC5C,OAAO;QACT,CAAC;QAED,MAAM,cAAc,GAAG,IAAI,CAAC,kCAAkC,CAAC,KAAK,CAAC,CAAC;QAEtE,IAAI,CAAC,iBAAiB,GAAG,cAAc,CAAC;QACxC,IAAI,CAAC,eAAe,GAAG,cAAc,CAAC;QAEtC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;IACtC,CAAC;IAED,gBAAgB,CAAC,OAAgB;QAC/B,MAAM,KAAK,GAAG,OAAO,CAAC,cAAc,CAAC;QACrC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAC7B,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAClC,CAAC;IAEO,eAAe;QACrB,IAAI,CAAC,wBAAwB,EAAE,CAAC;IAClC,CAAC;IAEO,mBAAmB;QACzB,IAAI,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACzC,OAAO,IAAI,CAAC,YAAY,CAAC;QAC3B,CAAC;QAED,MAAM,SAAS,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;QACzC,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;QAEjC,IAAI,SAAqB,CAAC;QAE1B,IAAI,SAAS,IAAI,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACtC,SAAS,GAAG,IAAI,CAAC,yBAAyB,CAAC,SAAS,EAAE,KAAK,IAAI,EAAE,CAAC,CAAC;QACrE,CAAC;aAAM,CAAC;YACN,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;YACrC,IAAI,UAAU,IAAI,UAAU,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACxC,SAAS,GAAG,IAAI,CAAC,4BAA4B,CAAC,UAAU,CAAC,CAAC;YAC5D,CAAC;iBAAM,CAAC;gBACN,SAAS,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC;YACnC,CAAC;QACH,CAAC;QAED,IAAI,CAAC,YAAY,GAAG,SAAS,CAAC;QAC9B,OAAO,SAAS,CAAC;IACnB,CAAC;IAEO,UAAU;QAChB,OAAO,IAAI,CAAC,mBAAmB,EAAE,CAAC;IACpC,CAAC;IAEO,4BAA4B,CAAC,UAA6B;QAChE,MAAM,IAAI,GAAG,IAAI,GAAG,EAAoB,CAAC;QACzC,MAAM,IAAI,GAAe,EAAE,CAAC;QAE5B,UAAU,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;YAC3B,MAAM,EAAE,GAAa;gBACnB,MAAM,EAAE,OAAO,CAAC,MAAM;gBACtB,KAAK,EAAE,OAAO,CAAC,KAAK;gBACpB,GAAG,EAAE,OAAO,CAAC,GAAG;gBAChB,KAAK,EAAE,OAAO,CAAC,KAAK;gBACpB,aAAa,EAAE,OAAO,CAAC,aAAa;gBACpC,MAAM,EAAE,EAAE;aACX,CAAC;YACF,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;QAC5B,CAAC,CAAC,CAAC;QAEH,UAAU,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;YAC3B,MAAM,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,GAAG,CAAE,CAAC;YAClC,MAAM,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YAEtC,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBACxB,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YAChB,CAAC;iBAAM,CAAC;gBACN,MAAM,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;gBAC7C,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;gBAC7B,IAAI,GAAG,EAAE,CAAC;oBACR,GAAG,CAAC,MAAM,GAAG,GAAG,CAAC,MAAM,IAAI,EAAE,CAAC;oBAC9B,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;gBACtB,CAAC;YACH,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,OAAO,IAAI,CAAC;IACd,CAAC;IAEO,yBAAyB,CAAC,KAAiB,EAAE,KAAK,GAAG,CAAC;QAC5D,OAAO,IAAI,CAAC,kCAAkC,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;IAC/D,CAAC;IAEO,kCAAkC,CAAC,KAAiB,EAAE,KAAK,GAAG,CAAC;QACrE,MAAM,KAAK,GAAc,EAAE,CAAC;QAE5B,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE;YAC5B,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;YAC3B,MAAM,aAAa,GAAG,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,IAAI,KAAK,CAAC,CAAC;YACvF,MAAM,SAAS,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;YAE5D,MAAM,OAAO,GAAY;gBACvB,EAAE,EAAE,MAAM;gBACV,KAAK,EAAE,KAAK;gBACZ,UAAU,EAAE,SAAS;gBACrB,aAAa,EAAE,aAAa;gBAC5B,MAAM,EAAE,KAAK,KAAK,KAAK,CAAC,MAAM,GAAG,CAAC;gBAClC,cAAc,EAAE,IAAI;aACrB,CAAC;YAEF,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAEpB,IAAI,aAAa,IAAI,SAAS,EAAE,CAAC;gBAC/B,MAAM,YAAY,GAAG,IAAI,CAAC,kCAAkC,CAAC,IAAI,CAAC,MAAO,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC;gBACtF,KAAK,CAAC,IAAI,CAAC,GAAG,YAAY,CAAC,CAAC;YAC9B,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,OAAO,KAAK,CAAC;IACf,CAAC;IAED,WAAW,CAAC,KAAa,EAAE,OAAgB;QACzC,OAAO,OAAO,CAAC,EAAE,CAAC;IACpB,CAAC;IAED,gBAAgB;QACd,MAAM,eAAe,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;QAE5C,IAAI,eAAe,EAAE,CAAC;YACpB,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAChC,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAChC,CAAC;QAED,IAAI,CAAC,sBAAsB,EAAE,CAAC;IAChC,CAAC;IAEO,aAAa;QACnB,IAAI,CAAC,sBAAsB,EAAE,CAAC;IAChC,CAAC;IAEO,aAAa;QACnB,IAAI,CAAC,sBAAsB,EAAE,CAAC;IAChC,CAAC;IAEO,sBAAsB;QAC5B,MAAM,KAAK,GAAG,IAAI,CAAC,mBAAmB,EAAE,CAAC;QACzC,MAAM,KAAK,GAAe,CAAC,GAAG,KAAK,CAAC,CAAC;QAErC,OAAO,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACxB,MAAM,IAAI,GAAG,KAAK,CAAC,GAAG,EAAG,CAAC;YAE1B,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAC1C,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;gBAC3C,KAAK,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC;YAC7B,CAAC;QACH,CAAC;IACH,CAAC;IAEO,sBAAsB;QAC5B,MAAM,KAAK,GAAG,IAAI,CAAC,mBAAmB,EAAE,CAAC;QACzC,MAAM,KAAK,GAAe,CAAC,GAAG,KAAK,CAAC,CAAC;QAErC,OAAO,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACxB,MAAM,IAAI,GAAG,KAAK,CAAC,GAAG,EAAG,CAAC;YAE1B,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAC1C,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;gBAC5C,KAAK,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC;YAC7B,CAAC;QACH,CAAC;IACH,CAAC;IAEO,iBAAiB,CAAC,KAAiB,EAAE,QAAkC;QAC7E,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACnB,QAAQ,CAAC,IAAI,CAAC,CAAC;YACf,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAC1C,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;YAChD,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,6BAA6B;QACnC,MAAM,cAAc,GAAG,IAAI,CAAC,wBAAwB,EAAE,CAAC;QACvD,MAAM,aAAa,GAAG,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CACjD,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,IAAI,KAAK,CAAC,CACtE,CAAC;QAEF,MAAM,aAAa,GAAG,aAAa,CAAC,MAAM,KAAK,CAAC,CAAC;QAEjD,IAAI,aAAa,EAAE,CAAC;YAClB,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YAC5B,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC;QAC3C,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;YAC7B,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;QACzC,CAAC;IACH,CAAC;IAEO,wBAAwB;QAC9B,MAAM,cAAc,GAAe,EAAE,CAAC;QAEtC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,UAAU,EAAE,EAAE,CAAC,IAAI,EAAE,EAAE;YACjD,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAC1C,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAC5B,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,OAAO,cAAc,CAAC;IACxB,CAAC;IAEO,yBAAyB,CAAC,SAA4B,EAAE,KAAoB;QAClF,MAAM,SAAS,GAAG,IAAI,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QACrD,MAAM,aAAa,GAAG,IAAI,GAAG,EAAoB,CAAC;QAClD,MAAM,IAAI,GAAe,EAAE,CAAC;QAE5B,SAAS;aACN,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,CAAC;aAC/C,OAAO,CAAC,GAAG,CAAC,EAAE;YACb,MAAM,IAAI,GAAG,SAAS,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;YAEnC,MAAM,EAAE,GAAa;gBACnB,MAAM,EAAE,IAAI,EAAE,MAAM,IAAI,GAAG,CAAC,KAAK;gBACjC,KAAK,EAAE,GAAG,CAAC,KAAK;gBAChB,GAAG,EAAE,GAAG,CAAC,GAAG;gBACZ,KAAK,EAAE,IAAI,EAAE,KAAK,IAAI,IAAI;gBAC1B,aAAa,EAAE,GAAG,CAAC,aAAa;gBAChC,MAAM,EAAE,EAAE;gBACV,OAAO,EAAE,GAAG,CAAC,OAAO;gBACpB,IAAI,EAAE,GAAG,CAAC,IAAI;aACf,CAAC;YAEF,aAAa,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;QAChC,CAAC,CAAC,CAAC;QAEL,SAAS,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;YACtB,MAAM,EAAE,GAAG,aAAa,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAE,CAAC;YAEtC,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;gBAClB,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YAChB,CAAC;iBAAM,CAAC;gBACN,MAAM,GAAG,GAAG,aAAa,CAAC,GAAG,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;gBAC5C,IAAI,GAAG,EAAE,CAAC;oBACR,GAAG,CAAC,MAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;gBACvB,CAAC;YACH,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,OAAO,IAAI,CAAC;IACd,CAAC;IAED,UAAU;QACR,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;IACzB,CAAC;IAED,WAAW;QACT,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QACzB,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;QAC9B,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;QACrB,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;IAC5B,CAAC;8GAvXU,0BAA0B;kGAA1B,0BAA0B,0pCCnBvC,iyBAoBM,kMDPF,YAAY,+BACZ,iBAAiB,sHACjB,eAAe,2jBACf,aAAa;;2FAGJ,0BAA0B;kBAZtC,SAAS;iCACI,IAAI,YACN,qBAAqB,WAGtB;wBACP,YAAY;wBACZ,iBAAiB;wBACjB,eAAe;wBACf,aAAa;qBACd;wDAcS,UAAU;sBAAnB,MAAM;gBACG,cAAc;sBAAvB,MAAM","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, input, signal, Output, EventEmitter, effect, OnDestroy, ChangeDetectorRef, inject } from '@angular/core';\r\nimport { NoArvoreComponent } from '../no-arvore/no-arvore.component';\r\nimport { NoArvore, NoArvoreSimples, ConfigArvoreSimples, EstruturaArvore, DadosArvore, NoPlano } from '../../models/no-arvore.model';\r\nimport { ScrollingModule } from '@angular/cdk/scrolling';\r\nimport { PrimeNgModule } from '../../../../api/modules/primeng.module';\r\n\r\n@Component({\r\n  standalone: true,\r\n  selector: 'kv-tree-environment',\r\n  templateUrl: './kv-tree-environment.component.html',\r\n  styleUrls: ['./kv-tree-environment.component.scss'],\r\n  imports: [\r\n    CommonModule, \r\n    NoArvoreComponent,\r\n    ScrollingModule,\r\n    PrimeNgModule\r\n  ],\r\n})\r\nexport class KvTreeEnvironmentComponent implements OnDestroy {\r\n\r\n  arvoreDeDados = input<NoArvore[]>([]);\r\n  nosSimples = input<NoArvoreSimples[]>([]);\r\n  estruturaArvore = input<\r\n    EstruturaArvore[]\r\n  >([]);\r\n  dadosArvore = input<DadosArvore[]>([]);\r\n  configuracao = input<ConfigArvoreSimples>({});\r\n  showButtonCollapsed = input<boolean>(true);\r\n  showAddButton = input<boolean>(true);\r\n\r\n  @Output() onAddClick = new EventEmitter<void>();\r\n  @Output() onSelectedItem = new EventEmitter<any>();\r\n\r\n  private cdr = inject(ChangeDetectorRef);\r\n  private mapaDeExpansao = new Map<string, boolean>();\r\n  \r\n  private _cachedDados: NoArvore[] | null = null;\r\n  private _dadosHash: string | null = null;\r\n  private _cachedListaPlana: NoPlano[] | null = null;\r\n  private _listaPlanaHash: string | null = null;\r\n\r\n  listaPlana = signal<NoPlano[]>([]);\r\n  iconCollapsed = signal<string>('collapse_all');\r\n  collapsedAll = signal<boolean>(true);\r\n  selectedItem = signal<any>(null);\r\n\r\n  constructor() {\r\n    effect(() => {\r\n      const estrutura = this.estruturaArvore();\r\n      const dados = this.dadosArvore();\r\n      const simples = this.nosSimples();\r\n      const arvore = this.arvoreDeDados();\r\n      \r\n      const dadosHash = this.criarHashDados(estrutura, dados, simples, arvore);\r\n      \r\n      if (this._dadosHash !== dadosHash) {\r\n        this._dadosHash = dadosHash;\r\n        this.invalidarCache();\r\n        \r\n        const temDados = estrutura.length > 0 || dados.length > 0 || simples.length > 0 || arvore.length > 0;\r\n        \r\n        if (temDados) {\r\n          this.gerarListaPlanaOtimizada();\r\n          this.atualizarEstadoCollapseButton();\r\n        } else {\r\n          this.listaPlana.set([]);\r\n        }\r\n      }\r\n    }, { allowSignalWrites: true });\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.gerarListaPlana();\r\n    this.atualizarEstadoCollapseButton();\r\n  }\r\n\r\n  alternarNo(noPlano: NoPlano): void {\r\n    if (!noPlano.expansivel) return;\r\n\r\n    const estadoAtual = this.mapaDeExpansao.get(noPlano.dadosOriginais.rotulo) ?? false;\r\n    this.mapaDeExpansao.set(noPlano.dadosOriginais.rotulo, !estadoAtual);\r\n\r\n    this.forcarAtualizacaoLista();\r\n  }\r\n\r\n  private forcarAtualizacaoLista(): void {\r\n    this._cachedListaPlana = null;\r\n    this._listaPlanaHash = null;\r\n    \r\n    const dados = this.obterDadosOtimizado();\r\n    const novaListaPlana = this.transformarParaListaPlanaOtimizada(dados);\r\n    \r\n    this.listaPlana.set(novaListaPlana);\r\n    \r\n    this.cdr.detectChanges();\r\n    \r\n    setTimeout(() => {\r\n      const expansaoHash = Array.from(this.mapaDeExpansao.entries())\r\n        .sort(([a], [b]) => a.localeCompare(b))\r\n        .map(([k, v]) => `${k}:${v}`)\r\n        .join(',');\r\n      \r\n      this._listaPlanaHash = `${this._dadosHash}:${expansaoHash}`;\r\n      this._cachedListaPlana = novaListaPlana;\r\n      \r\n      this.cdr.detectChanges();\r\n      this.atualizarEstadoCollapseButton();\r\n    }, 0);\r\n  }\r\n\r\n  private criarHashDados(estrutura: EstruturaArvore[], dados: DadosArvore[], simples: NoArvoreSimples[], arvore: NoArvore[]): string {\r\n    const estruturaHash = `e:${estrutura.length}:${estrutura.map(e => `${e.id}:${e.label}`).join(',')}`;\r\n    const dadosHash = `d:${dados.length}:${dados.map(d => `${d.id}`).join(',')}`;\r\n    const simplesHash = `s:${simples.length}:${simples.map(s => s.key).join(',')}`;\r\n    const arvoreHash = `a:${arvore.length}:${arvore.map(a => a.rotulo).join(',')}`;\r\n    \r\n    return `${estruturaHash}|${dadosHash}|${simplesHash}|${arvoreHash}`;\r\n  }\r\n\r\n  private invalidarCache(): void {\r\n    this._cachedDados = null;\r\n    this._cachedListaPlana = null;\r\n    this._listaPlanaHash = null;\r\n  }\r\n\r\n  private gerarListaPlanaOtimizada(): void {\r\n    const dados = this.obterDadosOtimizado();\r\n    \r\n    const expansaoHash = Array.from(this.mapaDeExpansao.entries())\r\n      .sort(([a], [b]) => a.localeCompare(b))\r\n      .map(([k, v]) => `${k}:${v}`)\r\n      .join(',');\r\n    \r\n    const listaPlanaHash = `${this._dadosHash}:${expansaoHash}`;\r\n    \r\n    if (this._listaPlanaHash === listaPlanaHash && this._cachedListaPlana) {\r\n      this.listaPlana.set(this._cachedListaPlana);\r\n      return;\r\n    }\r\n    \r\n    const novaListaPlana = this.transformarParaListaPlanaOtimizada(dados);\r\n    \r\n    this._cachedListaPlana = novaListaPlana;\r\n    this._listaPlanaHash = listaPlanaHash;\r\n    \r\n    this.listaPlana.set(novaListaPlana);\r\n  }\r\n\r\n  onActionExecuted(noPlano: NoPlano): void {\r\n    const dados = noPlano.dadosOriginais;\r\n    this.selectedItem.set(dados);\r\n    this.onSelectedItem.emit(dados);\r\n  }\r\n\r\n  private gerarListaPlana(): void {\r\n    this.gerarListaPlanaOtimizada();\r\n  }\r\n\r\n  private obterDadosOtimizado(): NoArvore[] {\r\n    if (this._cachedDados && this._dadosHash) {\r\n      return this._cachedDados;\r\n    }\r\n\r\n    const estrutura = this.estruturaArvore();\r\n    const dados = this.dadosArvore();\r\n    \r\n    let resultado: NoArvore[];\r\n    \r\n    if (estrutura && estrutura.length > 0) {\r\n      resultado = this.combinarEstruturaComDados(estrutura, dados || []);\r\n    } else {\r\n      const nosSimples = this.nosSimples();\r\n      if (nosSimples && nosSimples.length > 0) {\r\n        resultado = this.converterSimplesParaCompleto(nosSimples);\r\n      } else {\r\n        resultado = this.arvoreDeDados();\r\n      }\r\n    }\r\n    \r\n    this._cachedDados = resultado;\r\n    return resultado;\r\n  }\r\n\r\n  private obterDados(): NoArvore[] {\r\n    return this.obterDadosOtimizado();\r\n  }\r\n\r\n  private converterSimplesParaCompleto(nosSimples: NoArvoreSimples[]): NoArvore[] {\r\n    const mapa = new Map<string, NoArvore>();\r\n    const raiz: NoArvore[] = [];\r\n\r\n    nosSimples.forEach(simples => {\r\n      const no: NoArvore = {\r\n        rotulo: simples.rotulo,\r\n        icone: simples.icone,\r\n        cor: simples.cor,\r\n        ativo: simples.ativo,\r\n        estaExpandido: simples.estaExpandido,\r\n        filhos: []\r\n      };\r\n      mapa.set(simples.key, no);\r\n    });\r\n\r\n    nosSimples.forEach(simples => {\r\n      const no = mapa.get(simples.key)!;\r\n      const partes = simples.key.split('-');\r\n      \r\n      if (partes.length === 1) {\r\n        raiz.push(no);\r\n      } else {\r\n        const keyPai = partes.slice(0, -1).join('-');\r\n        const pai = mapa.get(keyPai);\r\n        if (pai) {\r\n          pai.filhos = pai.filhos || [];\r\n          pai.filhos.push(no);\r\n        }\r\n      }\r\n    });\r\n\r\n    return raiz;\r\n  }\r\n\r\n  private transformarParaListaPlana(nodes: NoArvore[], nivel = 0): NoPlano[] {\r\n    return this.transformarParaListaPlanaOtimizada(nodes, nivel);\r\n  }\r\n\r\n  private transformarParaListaPlanaOtimizada(nodes: NoArvore[], nivel = 0): NoPlano[] {\r\n    const lista: NoPlano[] = [];\r\n    \r\n    nodes.forEach((node, index) => {\r\n      const rotulo = node.rotulo;\r\n      const estaExpandido = this.mapaDeExpansao.get(rotulo) ?? (node.estaExpandido ?? false);\r\n      const temFilhos = !!(node.filhos && node.filhos.length > 0);\r\n      \r\n      const noPlano: NoPlano = {\r\n        id: rotulo,\r\n        nivel: nivel,\r\n        expansivel: temFilhos,\r\n        estaExpandido: estaExpandido,\r\n        isLast: index === nodes.length - 1,\r\n        dadosOriginais: node\r\n      };\r\n      \r\n      lista.push(noPlano);\r\n\r\n      if (estaExpandido && temFilhos) {\r\n        const filhosPlanos = this.transformarParaListaPlanaOtimizada(node.filhos!, nivel + 1);\r\n        lista.push(...filhosPlanos);\r\n      }\r\n    });\r\n    \r\n    return lista;\r\n  }\r\n\r\n  trackByNode(index: number, noPlano: NoPlano): string {\r\n    return noPlano.id;\r\n  }\r\n\r\n  executeCollapsed() {\r\n    const todosColapsados = this.collapsedAll();\r\n    \r\n    if (todosColapsados) {\r\n      this.expandirTodosOtimizado();\r\n    } else {\r\n      this.colapsarTodosOtimizado();\r\n    }\r\n    \r\n    this.forcarAtualizacaoLista();\r\n  }\r\n\r\n  private expandirTodos(): void {\r\n    this.expandirTodosOtimizado();\r\n  }\r\n\r\n  private colapsarTodos(): void {\r\n    this.colapsarTodosOtimizado();\r\n  }\r\n\r\n  private expandirTodosOtimizado(): void {\r\n    const dados = this.obterDadosOtimizado();\r\n    const stack: NoArvore[] = [...dados];\r\n    \r\n    while (stack.length > 0) {\r\n      const node = stack.pop()!;\r\n      \r\n      if (node.filhos && node.filhos.length > 0) {\r\n        this.mapaDeExpansao.set(node.rotulo, true);\r\n        stack.push(...node.filhos);\r\n      }\r\n    }\r\n  }\r\n\r\n  private colapsarTodosOtimizado(): void {\r\n    const dados = this.obterDadosOtimizado();\r\n    const stack: NoArvore[] = [...dados];\r\n    \r\n    while (stack.length > 0) {\r\n      const node = stack.pop()!;\r\n      \r\n      if (node.filhos && node.filhos.length > 0) {\r\n        this.mapaDeExpansao.set(node.rotulo, false);\r\n        stack.push(...node.filhos);\r\n      }\r\n    }\r\n  }\r\n\r\n  private percorrerTodosNos(nodes: NoArvore[], callback: (node: NoArvore) => void): void {\r\n    nodes.forEach(node => {\r\n      callback(node);\r\n      if (node.filhos && node.filhos.length > 0) {\r\n        this.percorrerTodosNos(node.filhos, callback);\r\n      }\r\n    });\r\n  }\r\n\r\n  private atualizarEstadoCollapseButton(): void {\r\n    const nosExpandiveis = this.obterTodosNosExpandiveis();\r\n    const nosExpandidos = nosExpandiveis.filter(node => \r\n      this.mapaDeExpansao.get(node.rotulo) ?? (node.estaExpandido ?? false)\r\n    );\r\n\r\n    const todosFechados = nosExpandidos.length === 0;\r\n\r\n    if (todosFechados) {\r\n      this.collapsedAll.set(true);\r\n      this.iconCollapsed.set('expand_content');\r\n    } else {\r\n      this.collapsedAll.set(false);\r\n      this.iconCollapsed.set('collapse_all');\r\n    }\r\n  }\r\n\r\n  private obterTodosNosExpandiveis(): NoArvore[] {\r\n    const nosExpandiveis: NoArvore[] = [];\r\n    \r\n    this.percorrerTodosNos(this.obterDados(), (node) => {\r\n      if (node.filhos && node.filhos.length > 0) {\r\n        nosExpandiveis.push(node);\r\n      }\r\n    });\r\n    \r\n    return nosExpandiveis;\r\n  }\r\n\r\n  private combinarEstruturaComDados(estrutura: EstruturaArvore[], dados: DadosArvore[]): NoArvore[] {\r\n    const mapaDados = new Map(dados.map(d => [d.id, d]));\r\n    const mapaEstrutura = new Map<number, NoArvore>();\r\n    const raiz: NoArvore[] = [];\r\n\r\n    estrutura\r\n      .sort((a, b) => (a.ordem || 0) - (b.ordem || 0)) \r\n      .forEach(est => {\r\n        const dado = mapaDados.get(est.id);\r\n        \r\n        const no: NoArvore = {\r\n          rotulo: dado?.rotulo || est.label,\r\n          icone: est.icone,\r\n          cor: est.cor,\r\n          ativo: dado?.ativo ?? true,\r\n          estaExpandido: est.estaExpandido,\r\n          filhos: [],\r\n          actions: est.actions,\r\n          data: est.data\r\n        };\r\n        \r\n        mapaEstrutura.set(est.id, no);\r\n      });\r\n\r\n    estrutura.forEach(est => {\r\n      const no = mapaEstrutura.get(est.id)!;\r\n      \r\n      if (!est.parentId) {\r\n        raiz.push(no);\r\n      } else {\r\n        const pai = mapaEstrutura.get(est.parentId);\r\n        if (pai) {\r\n          pai.filhos!.push(no);\r\n        }\r\n      }\r\n    });\r\n\r\n    return raiz;\r\n  }\r\n\r\n  executeAdd() {\r\n    this.onAddClick.emit();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._cachedDados = null;\r\n    this._cachedListaPlana = null;\r\n    this._dadosHash = '';\r\n    this._listaPlanaHash = ''; \r\n  }\r\n\r\n}\r\n","<div class=\"grid-container h-full\">\r\n  <span \r\n    class=\"material-symbols-outlined text-sm text-500 mx-1 p-1 cursor-pointer hover:surface-300\"\r\n    style=\"border-radius: 4px; margin-top: 12px;\" \r\n    (click)=\"executeCollapsed()\"\r\n    [pTooltip]=\"collapsedAll() ? 'Expandir tudo' : 'Recolher tudo'\"\r\n  >\r\n    {{ iconCollapsed() }}\r\n  </span>\r\n  <cdk-virtual-scroll-viewport class=\"h-full w-full\" itemSize=\"40\">\r\n    \r\n    <ul class=\"lista-arvore-virtual pr-2 py-2\">\r\n      <no-arvore \r\n        *cdkVirtualFor=\"let no of listaPlana(); trackBy: trackByNode\" \r\n        [noPlano]=\"no\"\r\n        (noAlternado)=\"alternarNo($event)\"\r\n        (actionExecuted)=\"onActionExecuted($event)\" />\r\n    </ul>\r\n\r\n  </cdk-virtual-scroll-viewport>\r\n</div>"]}
|
|
286
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-tree-environment.component.js","sourceRoot":"","sources":["../../../../../../../../projects/keevo-components/src/lib/components/kv-tree-environment/components/kv-tree-environment/kv-tree-environment.component.ts","../../../../../../../../projects/keevo-components/src/lib/components/kv-tree-environment/components/kv-tree-environment/kv-tree-environment.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { ChangeDetectionStrategy, Component, input, signal, Output, EventEmitter, computed, inject, ContentChild, TemplateRef, effect } from '@angular/core';\nimport { NoArvoreComponent } from '../no-arvore/no-arvore.component';\nimport { NoArvore, NoArvoreSimples, ConfigArvoreSimples, EstruturaArvore, DadosArvore, NoPlano } from '../../models/no-arvore.model';\nimport { ScrollingModule } from '@angular/cdk/scrolling';\nimport { PrimeNgModule } from '../../../../api/modules/primeng.module';\nimport { FormControl, FormGroup, FormsModule, ReactiveFormsModule } from \"@angular/forms\";\nimport { toSignal } from '@angular/core/rxjs-interop';\nimport { KeevoComponentsModule } from '../../../keevo-components.module';\n\n@Component({\n  standalone: true,\n  selector: 'kv-tree-environment',\n  templateUrl: './kv-tree-environment.component.html',\n  styleUrls: ['./kv-tree-environment.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    CommonModule,\n    NoArvoreComponent,\n    ScrollingModule,\n    PrimeNgModule,\n    KeevoComponentsModule,\n    FormsModule,\n    ReactiveFormsModule\n],\n})\nexport class KvTreeEnvironmentComponent {\n\n  @Output() onAddClick = new EventEmitter<void>();\n  @Output() onSelectedItem = new EventEmitter<any>();\n  @Output() onSidebarNodeClick = new EventEmitter<NoArvore>();\n\n  @ContentChild('sidebar') sidebarTemplate?: TemplateRef<any>;\n\n  arvoreDeDados = input<NoArvore[]>([]);\n  nosSimples = input<NoArvoreSimples[]>([]);\n  estruturaArvore = input<EstruturaArvore[]>([]);\n  dadosArvore = input<DadosArvore[]>([]);\n  configuracao = input<ConfigArvoreSimples>({});\n  showButtonCollapsed = input<boolean>(true);\n  showAddButton = input<boolean>(true);\n  showSearchField = input<boolean>(false);\n  enableSidebar = input<boolean>(false);\n\n  sidebarVisible = signal<boolean>(false);\n  selectedItem = signal<any>(null);\n  currentSidebarNode = signal<NoArvore | null>(null);\n  \n  private expansaoState = signal<Map<string, boolean>>(new Map());\n  \n  formFiltro = new FormGroup({\n    search: new FormControl('')\n  });\n\n  private searchValue = toSignal(this.formFiltro.get('search')!.valueChanges, { initialValue: '' });\n\n  private dadosProcessados = computed<NoArvore[]>(() => {\n    const estrutura = this.estruturaArvore();\n    const dados = this.dadosArvore();\n    const simples = this.nosSimples();\n    const arvore = this.arvoreDeDados();\n\n    if (estrutura && estrutura.length > 0) {\n      return this.combinarEstruturaComDados(estrutura, dados || []);\n    } else if (simples && simples.length > 0) {\n      return this.converterSimplesParaCompleto(simples);\n    } else {\n      return arvore;\n    }\n  });\n\n  private dadosFiltrados = computed<NoArvore[]>(() => {\n    const search = this.searchValue()?.trim().toLowerCase() || '';\n    const dados = this.dadosProcessados();\n\n    if (!search) {\n      return dados;\n    }\n\n    return this.filtrarArvoreComHierarquia(dados, search);\n  });\n\n  listaPlana = computed<NoPlano[]>(() => {\n    const dados = this.dadosFiltrados();\n    const expansaoMap = this.expansaoState();\n    \n    return this.transformarParaListaPlana(dados, expansaoMap, 0);\n  });\n\n  iconCollapsed = computed<string>(() => {\n    const nosExpandiveis = this.obterTodosNosExpandiveis(this.dadosProcessados());\n    const expansaoMap = this.expansaoState();\n    \n    const algumExpandido = nosExpandiveis.some(node => \n      expansaoMap.get(node.rotulo) ?? (node.expanded ?? false)\n    );\n\n    return algumExpandido ? 'collapse_all' : 'expand_content';\n  });\n\n  collapsedAll = computed<boolean>(() => {\n    return this.iconCollapsed() === 'expand_content';\n  });\n\n  constructor() {\n    effect(() => {\n      const search = this.searchValue()?.trim().toLowerCase();\n      const dados = this.dadosFiltrados();\n      \n      if (search) {\n        this.expandirTodosNos(dados);\n      }\n    });\n  }\n\n  alternarNo(noPlano: NoPlano): void {\n    if (!noPlano.expansivel) return;\n\n    const novoMapa = new Map(this.expansaoState());\n    const estadoAtual = novoMapa.get(noPlano.dadosOriginais.rotulo) ?? (noPlano.dadosOriginais.expanded ?? false);\n    novoMapa.set(noPlano.dadosOriginais.rotulo, !estadoAtual);\n    \n    this.expansaoState.set(novoMapa);\n  }\n\n  onActionExecuted(noPlano: NoPlano): void {\n    const dados = noPlano.dadosOriginais;\n    this.selectedItem.set(dados);\n    this.onSelectedItem.emit(dados);\n  }\n\n  private converterSimplesParaCompleto(nosSimples: NoArvoreSimples[]): NoArvore[] {\n    const mapa = new Map<string, NoArvore>();\n    const raiz: NoArvore[] = [];\n\n    nosSimples.forEach(simples => {\n      const no: NoArvore = {\n        rotulo: simples.rotulo,\n        icone: simples.icone,\n        cor: simples.cor,\n        ativo: simples.ativo,\n        expanded: simples.expanded,\n        filhos: []\n      };\n      mapa.set(simples.key, no);\n    });\n\n    nosSimples.forEach(simples => {\n      const no = mapa.get(simples.key)!;\n      const partes = simples.key.split('-');\n      \n      if (partes.length === 1) {\n        raiz.push(no);\n      } else {\n        const keyPai = partes.slice(0, -1).join('-');\n        const pai = mapa.get(keyPai);\n        if (pai) {\n          pai.filhos = pai.filhos || [];\n          pai.filhos.push(no);\n        }\n      }\n    });\n\n    return raiz;\n  }\n\n  private transformarParaListaPlana(\n    nodes: NoArvore[], \n    expansaoMap: Map<string, boolean>, \n    nivel = 0\n  ): NoPlano[] {\n    const lista: NoPlano[] = [];\n    \n    nodes.forEach((node, index) => {\n      const rotulo = node.rotulo;\n      const expanded = expansaoMap.get(rotulo) ?? (node.expanded ?? false);\n      const temFilhos = !!(node.filhos && node.filhos.length > 0);\n      \n      const noPlano: NoPlano = {\n        id: rotulo,\n        nivel: nivel,\n        expansivel: temFilhos,\n        expanded: expanded,\n        isLast: index === nodes.length - 1,\n        dadosOriginais: node\n      };\n      \n      lista.push(noPlano);\n\n      if (expanded && temFilhos) {\n        const filhosPlanos = this.transformarParaListaPlana(node.filhos!, expansaoMap, nivel + 1);\n        lista.push(...filhosPlanos);\n      }\n    });\n    \n    return lista;\n  }\n\n  trackByNode(index: number, noPlano: NoPlano): string {\n    return noPlano.id;\n  }\n\n  protected expandirTodos(): void {\n    const novoMapa = new Map(this.expansaoState());\n    this.expandirTodosNos(this.dadosProcessados(), novoMapa);\n    this.expansaoState.set(novoMapa);\n  }\n\n  protected colapsarTodos(): void {\n    const novoMapa = new Map(this.expansaoState());\n    this.colapsarTodosNos(this.dadosProcessados(), novoMapa);\n    this.expansaoState.set(novoMapa);\n  }\n\n  private expandirTodosNos(nodes: NoArvore[], mapa?: Map<string, boolean>): void {\n    const mapaDeExpansao = mapa || new Map(this.expansaoState());\n    const stack: NoArvore[] = [...nodes];\n    \n    while (stack.length > 0) {\n      const node = stack.pop()!;\n      \n      if (node.filhos && node.filhos.length > 0) {\n        mapaDeExpansao.set(node.rotulo, true);\n        stack.push(...node.filhos);\n      }\n    }\n    \n    if (!mapa) {\n      this.expansaoState.set(mapaDeExpansao);\n    }\n  }\n\n  private colapsarTodosNos(nodes: NoArvore[], mapa: Map<string, boolean>): void {\n    const stack: NoArvore[] = [...nodes];\n    \n    while (stack.length > 0) {\n      const node = stack.pop()!;\n      \n      if (node.filhos && node.filhos.length > 0) {\n        mapa.set(node.rotulo, false);\n        stack.push(...node.filhos);\n      }\n    }\n  }\n\n  private obterTodosNosExpandiveis(nodes: NoArvore[]): NoArvore[] {\n    const nosExpandiveis: NoArvore[] = [];\n    const stack: NoArvore[] = [...nodes];\n    \n    while (stack.length > 0) {\n      const node = stack.pop()!;\n      \n      if (node.filhos && node.filhos.length > 0) {\n        nosExpandiveis.push(node);\n        stack.push(...node.filhos);\n      }\n    }\n    \n    return nosExpandiveis;\n  }\n\n  private combinarEstruturaComDados(estrutura: EstruturaArvore[], dados: DadosArvore[]): NoArvore[] {\n    const mapaDados = new Map(dados.map(d => [d.id, d]));\n    const mapaEstrutura = new Map<number, NoArvore>();\n    const raiz: NoArvore[] = [];\n\n    estrutura\n      .sort((a, b) => (a.ordem || 0) - (b.ordem || 0)) \n      .forEach(est => {\n        const dado = mapaDados.get(est.id);\n        \n        const no: NoArvore = {\n          rotulo: dado?.rotulo || est.label,\n          icone: est.icone,\n          cor: est.cor,\n          ativo: dado?.ativo ?? true,\n          expanded: est.expanded,\n          filhos: [],\n          actions: est.actions,\n          data: est.data,\n          showSidebarAction: est.showSidebarAction\n        };\n        \n        mapaEstrutura.set(est.id, no);\n      });\n\n    estrutura.forEach(est => {\n      const no = mapaEstrutura.get(est.id)!;\n      \n      if (!est.parentId) {\n        raiz.push(no);\n      } else {\n        const pai = mapaEstrutura.get(est.parentId);\n        if (pai) {\n          pai.filhos!.push(no);\n        }\n      }\n    });\n\n    return raiz;\n  }\n\n  executeAdd() {\n    this.onAddClick.emit();\n  }\n\n  abrirSidebarParaNo(no: NoArvore): void {\n    this.currentSidebarNode.set(no);\n    this.sidebarVisible.set(true);\n    this.onSidebarNodeClick.emit(no);\n  }\n\n  private filtrarArvoreComHierarquia(nodes: NoArvore[], textoBusca: string): NoArvore[] {\n    const resultado: NoArvore[] = [];\n\n    for (const node of nodes) {\n      const rotuloLower = node.rotulo.toLowerCase();\n      const corresponde = rotuloLower.includes(textoBusca);\n\n      let filhosFiltrados: NoArvore[] = [];\n      if (node.filhos && node.filhos.length > 0) {\n        filhosFiltrados = this.filtrarArvoreComHierarquia(node.filhos, textoBusca);\n      }\n\n      if (corresponde || filhosFiltrados.length > 0) {\n        const noClonado: NoArvore = {\n          ...node,\n          filhos: filhosFiltrados.length > 0 ? filhosFiltrados : node.filhos,\n          expanded: true\n        };\n        resultado.push(noClonado);\n      }\n    }\n\n    return resultado;\n  }\n\n}\n","<div class=\"flex flex-column h-full\">\n  <div class=\"flex flex-row gap-2 p-2\" [formGroup]=\"formFiltro\">\n    @if(showSearchField()) {\n      <kv-input-text\n        placeholder=\"Pesquisar...\"\n        icon=\"search\"\n        formControlName=\"search\"\n      ></kv-input-text>\n    }\n\n    <kv-button\n      severity=\"tertiary\"\n      class=\"w-auto\"\n      label=\"Expandir\"\n      icon=\"expand_content\"\n      (click)=\"expandirTodos()\"\n    ></kv-button>\n\n    <kv-button\n      severity=\"tertiary\"\n      class=\"w-auto\"\n      label=\"Recolher\"\n      icon=\"collapse_all\"\n      (click)=\"colapsarTodos()\"\n    ></kv-button>\n  </div>\n\n  <div class=\"pl-2 pb-2 flex-1 w-full flex flex-row items-center gap-2\" style=\"min-height: 0; position: relative;\">\n    <cdk-virtual-scroll-viewport class=\"h-full flex-1\" itemSize=\"40\">\n        <ul class=\"lista-arvore-virtual pr-2 py-2\">\n          <no-arvore \n            *cdkVirtualFor=\"let no of listaPlana(); trackBy: trackByNode\" \n            [noPlano]=\"no\"\n            [enableSidebar]=\"enableSidebar()\"\n            (noAlternado)=\"alternarNo($event)\"\n            (actionExecuted)=\"onActionExecuted($event)\"\n            (sidebarClick)=\"abrirSidebarParaNo($event)\" />\n        </ul>\n      </cdk-virtual-scroll-viewport>\n\n    @if (sidebarVisible() && enableSidebar()) {\n      <kv-button\n        severity=\"tertiary\"\n        icon=\"menu\"\n        (click)=\"sidebarVisible.set(false)\"\n      ></kv-button>\n    }\n\n    <p-sidebar [visible]=\"sidebarVisible()\" (visibleChange)=\"sidebarVisible.set($event)\" position=\"right\" class=\"pr-2\" [ngStyle]=\"{'flex': '0.6 1 0%'}\" styleClass=\"w-full\">\n      <ng-template pTemplate=\"headless\">\n        @if (sidebarTemplate && currentSidebarNode()) {\n          <ng-container [ngTemplateOutlet]=\"sidebarTemplate\" [ngTemplateOutletContext]=\"{ $implicit: currentSidebarNode() }\"></ng-container>\n        }\n      </ng-template>\n    </p-sidebar>\n  </div>\n</div>\n"]}
|