@sapphire-ion/framework 1.0.17 → 1.0.20
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/classes/inputs/table-field-form-builder.mjs +1 -1
- package/esm2022/lib/components/default/default-list/abstract-list.mjs +1 -1
- package/esm2022/lib/components/default/default-list/default-list.component.mjs +4 -4
- package/esm2022/lib/components/default/default-list/header-list/header-list.component.mjs +1 -1
- package/esm2022/lib/components/default/default-list/list.mjs +1 -1
- package/esm2022/lib/components/default/default-pagination/default-pagination.component.mjs +5 -5
- package/esm2022/lib/components/default/default-table/default-table.component.mjs +161 -163
- package/esm2022/lib/components/default/default-table/th-filter/th-filter.component.mjs +3 -3
- package/esm2022/lib/components/default/default-view/abstract-view.mjs +1 -1
- package/esm2022/lib/components/default/default-view/default-view.component.mjs +3 -3
- package/esm2022/lib/components/default/default-view/view.mjs +19 -6
- package/esm2022/lib/components/default-page/default.page.mjs +3 -3
- package/esm2022/lib/components/drawer/drawer-group/drawer-group.component.mjs +3 -3
- package/esm2022/lib/components/drawer/drawer.component.mjs +5 -5
- package/esm2022/lib/components/filter/filter.component.mjs +8 -3
- package/esm2022/lib/components/inputs/custom-input.mjs +1 -1
- package/esm2022/lib/components/inputs/input-bool/input-bool.component.mjs +11 -5
- package/esm2022/lib/components/inputs/input-cep/input-cep.component.mjs +19 -10
- package/esm2022/lib/components/inputs/input-color/input-color.component.mjs +15 -8
- package/esm2022/lib/components/inputs/input-cpf-cnpj/input-cpf-cnpj.component.mjs +46 -15
- package/esm2022/lib/components/inputs/input-date/input-date.component.mjs +12 -6
- package/esm2022/lib/components/inputs/input-decimal/input-decimal.component.mjs +11 -5
- package/esm2022/lib/components/inputs/input-file/input-file.component.mjs +14 -6
- package/esm2022/lib/components/inputs/input-icon/input-icon.component.mjs +12 -6
- package/esm2022/lib/components/inputs/input-select/directives/sion-label-template.directive.mjs +1 -1
- package/esm2022/lib/components/inputs/input-select/directives/sion-option-template.directive.mjs +1 -3
- package/esm2022/lib/components/inputs/input-select/directives/sion-placeholder-template.directive.mjs +1 -1
- package/esm2022/lib/components/inputs/input-select/input-select.component.mjs +13 -5
- package/esm2022/lib/components/inputs/input-select/input.select.configuration.mjs +5 -5
- package/esm2022/lib/components/inputs/input-string/input-string.component.mjs +12 -6
- package/esm2022/lib/components/inputs/input-telefone/input-telefone.component.mjs +22 -11
- package/esm2022/lib/components/inputs/input-textarea/input-textarea.component.mjs +12 -6
- package/esm2022/lib/components/login/login-admin/login-admin.component.mjs +2 -2
- package/esm2022/lib/components/login/login.component.mjs +4 -4
- package/esm2022/lib/components/popover/sion-popover/sion-popover.component.mjs +15 -4
- package/esm2022/lib/components/sion-card/sion-card.component.mjs +26 -0
- package/esm2022/lib/components/stepper/stepper.component.mjs +4 -4
- package/esm2022/lib/guards/error.interceptor.mjs +3 -3
- package/esm2022/lib/index.mjs +4 -2
- package/esm2022/lib/services/generic.service.mjs +84 -0
- package/esm2022/lib/services/usuario.service.mjs +3 -3
- package/esm2022/lib/services/web/http.ativo.service.mjs +4 -22
- package/esm2022/lib/services/web/http.service.mjs +26 -15
- package/esm2022/lib/services/web/storage.service.mjs +3 -3
- package/fesm2022/sapphire-ion-framework.mjs +662 -510
- package/fesm2022/sapphire-ion-framework.mjs.map +1 -1
- package/lib/classes/inputs/table-field-form-builder.d.ts +1 -1
- package/lib/components/default/default-list/abstract-list.d.ts +1 -1
- package/lib/components/default/default-list/default-list.component.d.ts +1 -1
- package/lib/components/default/default-list/list.d.ts +1 -1
- package/lib/components/default/default-pagination/default-pagination.component.d.ts +1 -1
- package/lib/components/default/default-table/default-table.component.d.ts +60 -44
- package/lib/components/default/default-view/abstract-view.d.ts +1 -1
- package/lib/components/default/default-view/default-view.component.d.ts +1 -1
- package/lib/components/default/default-view/view.d.ts +5 -2
- package/lib/components/default-page/default.page.d.ts +1 -1
- package/lib/components/drawer/drawer-group/drawer-group.component.d.ts +1 -1
- package/lib/components/drawer/drawer.component.d.ts +1 -1
- package/lib/components/inputs/custom-input.d.ts +1 -1
- package/lib/components/inputs/input-bool/input-bool.component.d.ts +1 -1
- package/lib/components/inputs/input-cep/input-cep.component.d.ts +3 -3
- package/lib/components/inputs/input-color/input-color.component.d.ts +2 -2
- package/lib/components/inputs/input-cpf-cnpj/input-cpf-cnpj.component.d.ts +3 -4
- package/lib/components/inputs/input-date/input-date.component.d.ts +1 -1
- package/lib/components/inputs/input-decimal/input-decimal.component.d.ts +1 -1
- package/lib/components/inputs/input-file/input-file.component.d.ts +1 -1
- package/lib/components/inputs/input-icon/input-icon.component.d.ts +1 -1
- package/lib/components/inputs/input-select/directives/sion-label-template.directive.d.ts +6 -0
- package/lib/components/inputs/input-select/directives/sion-option-template.directive.d.ts +4 -1
- package/lib/components/inputs/input-select/directives/sion-placeholder-template.directive.d.ts +8 -2
- package/lib/components/inputs/input-select/input-select.component.d.ts +1 -1
- package/lib/components/inputs/input-select/input.select.configuration.d.ts +1 -1
- package/lib/components/inputs/input-string/input-string.component.d.ts +1 -1
- package/lib/components/inputs/input-telefone/input-telefone.component.d.ts +2 -1
- package/lib/components/inputs/input-textarea/input-textarea.component.d.ts +1 -1
- package/lib/components/login/login.component.d.ts +1 -1
- package/lib/components/popover/sion-popover/sion-popover.component.d.ts +1 -0
- package/lib/components/sion-card/sion-card.component.d.ts +11 -0
- package/lib/components/stepper/stepper.component.d.ts +2 -2
- package/lib/guards/error.interceptor.d.ts +1 -1
- package/lib/index.d.ts +2 -1
- package/lib/services/usuario.service.d.ts +1 -1
- package/lib/services/web/http.ativo.service.d.ts +1 -12
- package/lib/services/web/http.service.d.ts +16 -7
- package/lib/services/web/storage.service.d.ts +1 -1
- package/package.json +5 -5
- package/themes/compiled-styles.scss +17 -6
- package/themes/components/default/default-pagination/default-pagination.component.scss +1 -4
- package/themes/components/default/default-table/default-table.component.scss +3 -19
- package/themes/components/inputs/inputs.scss +1 -1
- package/themes/components/popover/sion-popover/sion-popover.component.scss +1 -1
- package/themes/components/sion-card/sion-card.component.scss +0 -0
- package/themes/styles/core.styles.scss +16 -12
- package/themes/styles/login-default.scss +1 -1
- package/themes/styles/styles.scss +1 -1
- package/esm2022/lib/components/inputs/input-cep/input-cep.configuration.mjs +0 -6
- package/esm2022/lib/services/generics.service.mjs +0 -84
- package/lib/components/inputs/input-cep/input-cep.configuration.d.ts +0 -5
- /package/lib/services/{generics.service.d.ts → generic.service.d.ts} +0 -0
|
@@ -1,9 +1,11 @@
|
|
|
1
|
-
import { Component, EventEmitter, Input, Output, TemplateRef } from '@angular/core';
|
|
2
|
-
import { ActivatedRoute, Router } from '@angular/router';
|
|
3
1
|
import { formatNumber } from '@angular/common';
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
2
|
+
import { Component, computed, effect, Input, input, model, output, TemplateRef } from '@angular/core';
|
|
3
|
+
import { ActivatedRoute, Router } from '@angular/router';
|
|
4
|
+
import { FormatTelefoneCelular } from '../../inputs/input-telefone/input-telefone.component';
|
|
6
5
|
import { StorageService } from '../../../services/web/storage.service';
|
|
6
|
+
import { FormatCpfCnpj } from '../../inputs/input-cpf-cnpj/input-cpf-cnpj.component';
|
|
7
|
+
import { CompileLstTableField } from '../../../classes/comparison/comparison';
|
|
8
|
+
import { FormatCep } from '../../inputs/input-cep/input-cep.component';
|
|
7
9
|
import { InputType } from '../../inputs/input-type';
|
|
8
10
|
import { Utils } from '../../../services/utils.service';
|
|
9
11
|
import * as i0 from "@angular/core";
|
|
@@ -17,202 +19,198 @@ import * as i7 from "../../loading/loading.component";
|
|
|
17
19
|
import * as i8 from "../../content-block/content-block.component";
|
|
18
20
|
import * as i9 from "../default-pagination/default-pagination.component";
|
|
19
21
|
import * as i10 from "./th-filter/th-filter.component";
|
|
20
|
-
/** Componente de tabela padrão */
|
|
21
22
|
export class DefaultTableComponent {
|
|
22
23
|
constructor(storageService, activatedRoute, router) {
|
|
23
24
|
this.storageService = storageService;
|
|
24
25
|
this.activatedRoute = activatedRoute;
|
|
25
26
|
this.router = router;
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
this.
|
|
30
|
-
|
|
27
|
+
/** Template de ações, deve ser um elemento ```<ng-template>``` */
|
|
28
|
+
// acoesTemplate: InputSignal<TemplateRef<any>> = input<TemplateRef<any>>();
|
|
29
|
+
/** Service a ser utilizado na listagem */
|
|
30
|
+
this.service = input();
|
|
31
|
+
this.total = model(0);
|
|
32
|
+
/** Número de items máximo (usando two way data binding) */
|
|
33
|
+
this.limit = model();
|
|
34
|
+
/** Valor da pagina, setado = 1 quando troca-se o valor de limite de paginas (usando two way data binding) */
|
|
35
|
+
this.page = model(1);
|
|
36
|
+
/** Propriedade de ordenação (usando two way data binding) */
|
|
37
|
+
this.orderByProperty = model(null);
|
|
38
|
+
/** Propriedade de ordenação
|
|
39
|
+
* Se = true Ordenará de menor ao maior
|
|
40
|
+
* Se = false Ordenará de maior ao menor (usando two way data binding) */
|
|
41
|
+
this.ascending = model(true);
|
|
31
42
|
/** Filtros (usando two way data binding) */
|
|
32
|
-
this.filter = [];
|
|
33
|
-
this.filterChange = new EventEmitter();
|
|
43
|
+
this.filter = model([]);
|
|
34
44
|
/** Evento emitido quando um dos dados é ativado. Emite o id do dado */
|
|
35
|
-
this.
|
|
36
|
-
this.
|
|
45
|
+
this.ativar = output();
|
|
46
|
+
this.refresh = output();
|
|
47
|
+
this.loading = model(false);
|
|
37
48
|
/** Lista de dados a ser exibidos */
|
|
38
|
-
this.items = [];
|
|
49
|
+
this.items = model([]);
|
|
39
50
|
/** Lista de campos a ser exibidos */
|
|
40
|
-
this.lstTableFields = [];
|
|
51
|
+
this.lstTableFields = model([]);
|
|
52
|
+
this.lstTableFieldsAvailable = computed(() => {
|
|
53
|
+
return this.lstTableFields().filter(p => !p.hidden).map(tf => {
|
|
54
|
+
return new AvailableTableField(tf, this.ascending() && this.orderByProperty() == tf.index, !this.ascending() && this.orderByProperty() == tf.index);
|
|
55
|
+
});
|
|
56
|
+
});
|
|
41
57
|
/** Remove os filtros no cabeçalho da tabela */
|
|
42
|
-
this.noFilters = false;
|
|
58
|
+
this.noFilters = input(false);
|
|
43
59
|
/** Aplica classes de CSS na coluna de acirdo com o retorno da função passada como parametro */
|
|
44
|
-
this.columnClass = null;
|
|
45
|
-
/** Aplica style de CSS na coluna de
|
|
46
|
-
this.columnStyle = null;
|
|
60
|
+
this.columnClass = input(null);
|
|
61
|
+
/** Aplica style de CSS na coluna de acirco com o retorno da função passada como parametro */
|
|
62
|
+
this.columnStyle = input(null);
|
|
47
63
|
/** Remove a paginação da listagem */
|
|
48
|
-
this.noPagination = false;
|
|
64
|
+
this.noPagination = input(false);
|
|
49
65
|
/** Caminho de redirecionamento do item */
|
|
50
|
-
this.itemPath =
|
|
51
|
-
this.
|
|
66
|
+
this.itemPath = input('view/:id');
|
|
67
|
+
this.itemClick = output();
|
|
68
|
+
this.InputType = InputType;
|
|
69
|
+
this.lstRows = [];
|
|
70
|
+
effect(() => {
|
|
71
|
+
for (const tf of this.lstTableFields().filter(p => p.type == InputType.Select)) {
|
|
72
|
+
tf.configuration.loader.Refresh().then(() => this.SetLstRows());
|
|
73
|
+
}
|
|
74
|
+
this.SetLstRows();
|
|
75
|
+
});
|
|
52
76
|
}
|
|
53
77
|
Redirect(field, item) {
|
|
54
|
-
|
|
78
|
+
this.itemClick.emit(item);
|
|
79
|
+
if (!field) {
|
|
55
80
|
return;
|
|
56
81
|
}
|
|
57
|
-
else if (field.
|
|
82
|
+
else if (field.index == 'ativo') {
|
|
58
83
|
return;
|
|
59
84
|
}
|
|
60
|
-
else {
|
|
61
|
-
|
|
62
|
-
const id = item.id;
|
|
63
|
-
const path = this.itemPath.replace(":id", id.toString());
|
|
64
|
-
this.router.navigate([`./${path}`], { relativeTo: this.activatedRoute });
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
ngOnInit() {
|
|
69
|
-
if (this.defaultService && this.lstTableFields.length == 0) {
|
|
70
|
-
this.lstTableFields = this.defaultService.lstTableFields;
|
|
71
|
-
}
|
|
72
|
-
if (this.lstTableFields.length == 0) {
|
|
73
|
-
console.warn("[ Warning! ] [ Table configuration is empty]");
|
|
74
|
-
}
|
|
75
|
-
this.lstTableFields.filter(tf => tf.configuration instanceof InputSelectConfiguration).forEach(tf => tf.configuration.loader.Refresh());
|
|
76
|
-
}
|
|
77
|
-
SwitchOrder(field) {
|
|
78
|
-
if (this.orderByProperty != field.index) {
|
|
79
|
-
this.orderByProperty = field.index;
|
|
80
|
-
this.ascending = true;
|
|
81
|
-
}
|
|
82
|
-
else if (this.ascending) {
|
|
83
|
-
this.ascending = false;
|
|
85
|
+
else if (field.type == 'File') {
|
|
86
|
+
return;
|
|
84
87
|
}
|
|
85
|
-
else {
|
|
86
|
-
|
|
88
|
+
else if (this.itemPath()) {
|
|
89
|
+
const id = item['id'];
|
|
90
|
+
const path = this.itemPath().replace(":id", id.toString());
|
|
91
|
+
this.router.navigate([`./${path}`], { relativeTo: this.activatedRoute });
|
|
87
92
|
}
|
|
88
|
-
this.orderByPropertyChange.emit(this.orderByProperty);
|
|
89
|
-
this.ascendingChange.emit(this.ascending);
|
|
90
|
-
this.EmitChange();
|
|
91
|
-
}
|
|
92
|
-
EmitPage(value) {
|
|
93
|
-
this.pageChange.emit(value);
|
|
94
|
-
this.EmitChange();
|
|
95
93
|
}
|
|
96
|
-
|
|
97
|
-
this.
|
|
94
|
+
SetLstRows() {
|
|
95
|
+
this.lstRows = this.items().map(item => {
|
|
96
|
+
return new DefaultTableRow(item, item['id'], this.GetColumns(item), this.columnClass() ? this.columnClass()('acoes', item) : '', this.columnStyle() ? this.columnClass()('acoes', item) : '');
|
|
97
|
+
});
|
|
98
98
|
}
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
}
|
|
106
|
-
else if (type == 'DateTime') {
|
|
99
|
+
GetColumns(item) {
|
|
100
|
+
return this.lstTableFields().filter(p => !p.hidden).map(tf => {
|
|
101
|
+
const value = item[tf.index];
|
|
102
|
+
const column = new DefaultTableColumn(value, tf);
|
|
103
|
+
column.class = this.columnClass() ? this.columnClass()(tf.index, item) : '';
|
|
104
|
+
column.style = this.columnStyle() ? this.columnStyle()(tf.index, item) : '';
|
|
107
105
|
if (!value) {
|
|
108
|
-
|
|
106
|
+
column.label = '-';
|
|
107
|
+
return column;
|
|
109
108
|
}
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
else if (type == 'Date') {
|
|
113
|
-
if (!value) {
|
|
114
|
-
return "-";
|
|
109
|
+
if (tf.type == InputType.Bool) {
|
|
110
|
+
column.label = "<bool>";
|
|
115
111
|
}
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
112
|
+
else if (tf.type == InputType.Cep) {
|
|
113
|
+
column.label = FormatCep(value);
|
|
114
|
+
}
|
|
115
|
+
else if (tf.type == InputType.Color) {
|
|
116
|
+
column.label = value;
|
|
117
|
+
}
|
|
118
|
+
else if ([InputType.Cpf, InputType.Cnpj, InputType.CpfCnpj].includes(tf.type)) {
|
|
119
|
+
column.label = FormatCpfCnpj(value);
|
|
120
|
+
}
|
|
121
|
+
else if (tf.type == InputType.DateTime) {
|
|
122
|
+
column.class += ' font-mono';
|
|
123
|
+
column.label = Utils.DateISOToDDMMYYYYHHMM(value);
|
|
124
|
+
}
|
|
125
|
+
else if (tf.type == InputType.Date) {
|
|
126
|
+
column.class += ' font-mono';
|
|
127
|
+
column.label = Utils.DateISOToDDMMYYYYHHMM(value);
|
|
128
|
+
}
|
|
129
|
+
else if (tf.type == InputType.Time) {
|
|
130
|
+
column.class += ' font-mono';
|
|
131
|
+
column.label = value;
|
|
132
|
+
}
|
|
133
|
+
else if ([InputType.Decimal, InputType.Decimal, InputType.Currency].includes(tf.type)) {
|
|
134
|
+
const configuration = tf.configuration;
|
|
135
|
+
column.label = [
|
|
136
|
+
configuration.prefix,
|
|
137
|
+
formatNumber(value, 'pt-BR', `1.${configuration.precision}-${configuration.precision}`),
|
|
138
|
+
configuration.sufix,
|
|
139
|
+
].join(' ');
|
|
140
|
+
}
|
|
141
|
+
else if (tf.type == InputType.File) {
|
|
142
|
+
column.label = '<file>';
|
|
143
|
+
}
|
|
144
|
+
else if (tf.type == InputType.Icon) {
|
|
145
|
+
column.label = 'icon';
|
|
146
|
+
}
|
|
147
|
+
else if (tf.type == InputType.Select) {
|
|
148
|
+
column.label = tf.configuration.loader.GetLabel(value);
|
|
149
|
+
column.loading = !tf.configuration.loader.isLoaded;
|
|
150
|
+
}
|
|
151
|
+
else if ([InputType.String, InputType.TextArea].includes(tf.type)) {
|
|
152
|
+
column.label = value;
|
|
153
|
+
}
|
|
154
|
+
else if ([InputType.Telefone, InputType.Celular, InputType.TelefoneCelular].includes(tf.type)) {
|
|
155
|
+
column.label = FormatTelefoneCelular(value);
|
|
156
|
+
}
|
|
157
|
+
return column;
|
|
158
|
+
});
|
|
119
159
|
}
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
if (
|
|
123
|
-
|
|
160
|
+
ngOnInit() { this.SetLstRows(); }
|
|
161
|
+
SwitchOrder(tf) {
|
|
162
|
+
if (this.orderByProperty() != tf.index) {
|
|
163
|
+
this.orderByProperty.set(tf.index);
|
|
164
|
+
this.ascending.set(true);
|
|
165
|
+
}
|
|
166
|
+
else if (this.ascending()) {
|
|
167
|
+
this.ascending.set(false);
|
|
124
168
|
}
|
|
125
169
|
else {
|
|
126
|
-
|
|
127
|
-
if (values && values.length > 0) {
|
|
128
|
-
return values.map(v => configuration.loader.GetLabel(v)).join(", ");
|
|
129
|
-
}
|
|
130
|
-
else {
|
|
131
|
-
return "";
|
|
132
|
-
}
|
|
170
|
+
this.orderByProperty.set(null);
|
|
133
171
|
}
|
|
134
|
-
|
|
135
|
-
GetTypeOf(val) {
|
|
136
|
-
return typeof (val);
|
|
137
|
-
}
|
|
138
|
-
Ativar(id) {
|
|
139
|
-
this.ativarEmitter.emit(id);
|
|
172
|
+
this.refresh.emit();
|
|
140
173
|
}
|
|
141
174
|
ChangeFilter() {
|
|
142
|
-
this.
|
|
143
|
-
this.
|
|
175
|
+
this.filter.set(CompileLstTableField(this.lstTableFields()));
|
|
176
|
+
this.page.set(1);
|
|
177
|
+
this.refresh.emit();
|
|
144
178
|
}
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
if (['DateTime', 'Time', 'Date'].includes(field.type)) {
|
|
148
|
-
classes += 'font-mono ';
|
|
149
|
-
}
|
|
150
|
-
if (this.columnClass) {
|
|
151
|
-
classes += this.columnClass(field.index, item);
|
|
152
|
-
}
|
|
153
|
-
return classes;
|
|
154
|
-
}
|
|
155
|
-
GetTdStyle(field, item) {
|
|
156
|
-
if (this.columnStyle) {
|
|
157
|
-
return this.columnStyle(field, item);
|
|
158
|
-
}
|
|
159
|
-
return "";
|
|
179
|
+
Ativar(id) {
|
|
180
|
+
this.ativar.emit(id);
|
|
160
181
|
}
|
|
161
182
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DefaultTableComponent, deps: [{ token: i1.StorageService }, { token: i2.ActivatedRoute }, { token: i2.Router }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
162
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: DefaultTableComponent, selector: "default-table", inputs: { defaultService: ["service", "defaultService"], acoesTemplate: "acoesTemplate", total: "total", limit: "limit", page: "page", orderByProperty: "orderByProperty", ascending: "ascending", filter: "filter", loading: "loading", items: "items", lstTableFields: "lstTableFields", noFilters: "noFilters", columnClass: "columnClass", columnStyle: "columnStyle", noPagination: "noPagination", itemPath: "itemPath" }, outputs: { limitChange: "limitChange", pageChange: "pageChange", orderByPropertyChange: "orderByPropertyChange", ascendingChange: "ascendingChange", filterChange: "filterChange", ativarEmitter: "ativar", refreshEmitter: "refresh" }, ngImport: i0, template: "<!-- <section class=\"w-full h-full rounded-2xl flex flex-col overflow-y-hidden relative\" [ngClass]=\"{ 'loading' : loading }\">\r\n \r\n <div class=\"unique-conteiner default-transition\" [ngClass]=\"{'!-z-50 !-translate-y-12 !opacity-0': !loading }\">\r\n <loading [type]=\"2\"></loading>\r\n </div>\r\n <div class=\"unique-conteiner default-transition\" [ngClass]=\"{'!-z-50 !-translate-y-12 !opacity-0': items.length != 0 || loading }\">\r\n <b><ion-icon class=\"align-sub\" name=\"remove-circle\"></ion-icon> Sem dados</b>\r\n </div>\r\n\r\n <div id=\"wrapper\" class=\"relative overflow-y-auto w-full grow-0 mb-auto pb-2\">\r\n <table class=\"z-20 overflow-visible\">\r\n <thead>\r\n <tr>\r\n <th scope=\"col\" class=\"px-3 !h-10\" *ngIf=\"acoesTemplate\">\r\n <span>A\u00E7\u00F5es</span>\r\n </th>\r\n @for (field of lstTableFields; let i = $index; track i) {\r\n @if (!field.hidden) {\r\n <th scope=\"col\" class=\"p-2 px-3\" id=\"th-filter-select\">\r\n <div class=\"flex items-center justify-start h-full\" style=\"white-space: var(--ion-table-filter-wrap);\"> \r\n @if(!noFilters){\r\n <th-filter class=\"!text-base\" style=\"text-transform: none !important\" *ngIf=\"(field.type != InputTypeFile) && !(field.filter && field.disabledChange()) && !noFilters\"\r\n [field]=\"field\"\r\n (change)=\"ChangeFilter()\"\r\n ></th-filter>\r\n }\r\n <span>{{field.header}}</span>\r\n\r\n <a *ngIf=\"!(!(field.type != InputTypeFile) && !(field.filter && field.disabledChange())) && !noFilters\" class=\"order-switch h-5 flex items-center justify-center px-1 ml-2 shrink-0 cursor-pointer rounded-2xl\" (click)=\"SwitchOrder(field)\" [ngClass]=\"{ 'ordering-asc' : orderByProperty == field.index && ascending, 'ordering-desc' : orderByProperty == field.index && !ascending}\">\r\n <ion-icon id=\"up\" name=\"arrow-up\" class=\"-mt-1\"></ion-icon>\r\n <ion-icon id=\"down\" name=\"arrow-down\" class=\"-ml-1 -mb-1\"></ion-icon>\r\n </a>\r\n </div>\r\n </th>\r\n }\r\n }\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr [hidden]=\"loading\" *ngFor=\"let item of items\">\r\n @if(acoesTemplate){\r\n <td class=\"whitespace-nowrap py-1 px-3\" [style]=\"GetTdStyle('Acoes', item)\" >\r\n <ng-container *ngTemplateOutlet=\"acoesTemplate; context: { $implicit: item }\"></ng-container>\r\n </td>\r\n }\r\n\r\n @for (field of lstTableFields; track $index) {\r\n @if (!field.hidden) {\r\n <td class=\"px-3 py-2\" \r\n [ngClass]=\"GetTdClasses(field, item)\" \r\n [style]=\"GetTdStyle(field, item)\" \r\n (click)=\"Redirect(field, item)\"\r\n style=\"white-space: var(--ion-table-row-wrap);\"\r\n >\r\n @if (field.index == 'ativo') {\r\n <div class=\"w-full h-full flex items-center justify-start\" [routerLink]=\"null\">\r\n <ion-toggle [checked]=\"item[field.index]\" [disabled]=\"loading\" (ionChange)=\"Ativar(item.id)\" ></ion-toggle>\r\n </div>\r\n } @else {\r\n @switch (field.type) {\r\n @case (\"Bool\") {\r\n @if (field.configuration.type == \"toggle\") {\r\n <div class=\"-full h-full flex items-center justify-start\">\r\n <ion-toggle [checked]=\"item[field.index]\" [disabled]=\"true\"></ion-toggle>\r\n </div>\r\n }\r\n @else {\r\n <div class=\"-full h-full flex items-center justify-start\">\r\n <ion-checkbox [checked]=\"item[field.index]\" [disabled]=\"true\"></ion-checkbox>\r\n </div>\r\n }\r\n }\r\n @case (\"File\") {\r\n <download-button [(ngModel)]=\"item[field.index]\" [configuration]=\"field.configuration\"></download-button>\r\n }\r\n @case (\"Select\") {\r\n {{GetSelectLabel(item, field)}}\r\n }\r\n @default {\r\n {{GetField(item, field)}} \r\n }\r\n }\r\n }\r\n </td>\r\n }\r\n }\r\n </tr>\r\n\r\n <ng-content select=\"[slot=item-end]\"></ng-content>\r\n </tbody>\r\n </table>\r\n </div>\r\n @if(!noPagination){\r\n <div class=\"shrink-0 mt-auto w-full\">\r\n <default-pagination\r\n [page]=\"page\"\r\n (pageChange)=\"EmitPage($event)\"\r\n [total]=\"total\"\r\n [limit]=\"limit\"\r\n [length]=\"items.length\"\r\n [loading]=\"loading\"\r\n ></default-pagination>\r\n </div>\r\n }\r\n</section> -->\r\n<div class=\"size-full rounded-2xl flex flex-col overflow-hidden relative\">\r\n <loading [type]=\"3\" [loading]=\"loading\"></loading>\r\n <content-block text=\"Sem Dados\" [value]=\"!(items.length != 0 || loading)\"></content-block>\r\n\r\n <div class=\"size-full shrink relative overflow-y-auto\">\r\n <table>\r\n <thead>\r\n <tr>\r\n <th scope=\"col\" class=\"px-3 !h-10\" *ngIf=\"acoesTemplate\"> A\u00E7\u00F5es </th>\r\n @for (field of lstTableFields; let i = $index; track i) {\r\n @if (!field.hidden) {\r\n <th scope=\"col\" class=\"p-2 px-3\" id=\"th-filter-select\">\r\n <div class=\"flex items-center justify-start h-full\" style=\"white-space: var(--ion-table-filter-wrap);\"> \r\n @if(!noFilters){\r\n <th-filter class=\"!text-base\" style=\"text-transform: none !important\" *ngIf=\"(field.type != InputTypeFile) && !(field.filter && field.disabledChange()) && !noFilters\"\r\n [field]=\"field\"\r\n (change)=\"ChangeFilter()\"\r\n ></th-filter>\r\n }\r\n <span>{{field.header}}</span>\r\n\r\n <a *ngIf=\"!(!(field.type != InputTypeFile) && !(field.filter && field.disabledChange())) && !noFilters\" class=\"order-switch h-5 flex items-center justify-center px-1 ml-2 shrink-0 cursor-pointer rounded-2xl\" (click)=\"SwitchOrder(field)\" [ngClass]=\"{ 'ordering-asc' : orderByProperty == field.index && ascending, 'ordering-desc' : orderByProperty == field.index && !ascending}\">\r\n <ion-icon id=\"up\" name=\"arrow-up\" class=\"-mt-1\"></ion-icon>\r\n <ion-icon id=\"down\" name=\"arrow-down\" class=\"-ml-1 -mb-1\"></ion-icon>\r\n </a>\r\n </div>\r\n </th>\r\n }\r\n }\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr [hidden]=\"loading\" *ngFor=\"let item of items\">\r\n @if(acoesTemplate){\r\n <td class=\"whitespace-nowrap py-1 px-3\" [style]=\"GetTdStyle('Acoes', item)\" >\r\n <ng-container *ngTemplateOutlet=\"acoesTemplate; context: { $implicit: item }\"></ng-container>\r\n </td>\r\n }\r\n\r\n @for (field of lstTableFields; track $index) {\r\n @if (!field.hidden) {\r\n <td class=\"px-3 py-2\" \r\n [ngClass]=\"GetTdClasses(field, item)\" \r\n [style]=\"GetTdStyle(field, item)\" \r\n (click)=\"Redirect(field, item)\"\r\n style=\"white-space: var(--ion-table-row-wrap);\"\r\n >\r\n @if (field.index == 'ativo') {\r\n <div class=\"w-full h-full flex items-center justify-start\" [routerLink]=\"null\">\r\n <ion-toggle [checked]=\"item[field.index]\" [disabled]=\"loading\" (ionChange)=\"Ativar(item.id)\" ></ion-toggle>\r\n </div>\r\n } @else {\r\n @switch (field.type) {\r\n @case (\"Bool\") {\r\n @if (field.configuration.type == \"toggle\") {\r\n <div class=\"-full h-full flex items-center justify-start\">\r\n <ion-toggle [checked]=\"item[field.index]\" [disabled]=\"true\"></ion-toggle>\r\n </div>\r\n }\r\n @else {\r\n <div class=\"-full h-full flex items-center justify-start\">\r\n <ion-checkbox [checked]=\"item[field.index]\" [disabled]=\"true\"></ion-checkbox>\r\n </div>\r\n }\r\n }\r\n @case (\"File\") {\r\n <download-button [(ngModel)]=\"item[field.index]\" [configuration]=\"field.configuration\"></download-button>\r\n }\r\n @case (\"Select\") {\r\n {{GetSelectLabel(item, field)}}\r\n }\r\n @default {\r\n {{GetField(item, field)}} \r\n }\r\n }\r\n }\r\n </td>\r\n }\r\n }\r\n </tr>\r\n\r\n <ng-content select=\"[slot=item-end]\"></ng-content>\r\n </tbody>\r\n </table>\r\n </div>\r\n @if(!noPagination){\r\n <div class=\"shrink-0 z-[100]\">\r\n <default-pagination\r\n [page]=\"page\"\r\n (pageChange)=\"EmitPage($event)\"\r\n [total]=\"total\"\r\n [limit]=\"limit\"\r\n [length]=\"items.length\"\r\n [loading]=\"loading\"\r\n ></default-pagination>\r\n </div>\r\n }\r\n</div>", styles: ["#th-filter-select:hover .order-switch{background-color:var(--ion-color-step-200)}#th-filter-select:hover .order-switch #up,#th-filter-select:hover .order-switch #down{opacity:1!important;color:var(--ion-color-step-700)!important}#th-filter-select .order-switch{transition:background-color .3s}#th-filter-select .order-switch #up,#th-filter-select .order-switch #down{opacity:0;transition:all .3s}#th-filter-select .order-switch.ordering-asc #up{color:var(--ion-color-primary)!important;opacity:1}#th-filter-select .order-switch.ordering-asc #down,#th-filter-select .order-switch.ordering-desc #up{color:var(--ion-color-step-800)!important;opacity:1}#th-filter-select .order-switch.ordering-desc #down{color:var(--ion-color-primary)!important;opacity:1}\n"], dependencies: [{ kind: "component", type: i3.IonCheckbox, selector: "ion-checkbox", inputs: ["alignment", "checked", "color", "disabled", "errorText", "helperText", "indeterminate", "justify", "labelPlacement", "mode", "name", "required", "value"] }, { kind: "component", type: i3.IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }, { kind: "component", type: i3.IonToggle, selector: "ion-toggle", inputs: ["alignment", "checked", "color", "disabled", "enableOnOffLabels", "errorText", "helperText", "justify", "labelPlacement", "mode", "name", "required", "value"] }, { kind: "directive", type: i3.BooleanValueAccessor, selector: "ion-checkbox,ion-toggle" }, { kind: "directive", type: i3.RouterLinkDelegate, selector: ":not(a):not(area)[routerLink]" }, { kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i5.DownloadButtonComponent, selector: "download-button", inputs: ["expand", "value", "size", "color", "params", "disabled", "post", "configuration"], outputs: ["valueChange"] }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i7.LoadingComponent, selector: "loading", inputs: ["text", "type", "loading"] }, { kind: "component", type: i8.ContentBlockComponent, selector: "content-block", inputs: ["text", "value"] }, { kind: "component", type: i9.DefaultPaginationComponent, selector: "default-pagination", inputs: ["total", "limit", "length", "loading", "page"], outputs: ["pageChange", "change"] }, { kind: "component", type: i10.ThFilterComponent, selector: "th-filter", inputs: ["field"], outputs: ["change"] }] }); }
|
|
183
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: DefaultTableComponent, selector: "default-table", inputs: { acoesTemplate: { classPropertyName: "acoesTemplate", publicName: "acoesTemplate", isSignal: false, isRequired: false, transformFunction: null }, service: { classPropertyName: "service", publicName: "service", isSignal: true, isRequired: false, transformFunction: null }, total: { classPropertyName: "total", publicName: "total", isSignal: true, isRequired: false, transformFunction: null }, limit: { classPropertyName: "limit", publicName: "limit", isSignal: true, isRequired: false, transformFunction: null }, page: { classPropertyName: "page", publicName: "page", isSignal: true, isRequired: false, transformFunction: null }, orderByProperty: { classPropertyName: "orderByProperty", publicName: "orderByProperty", isSignal: true, isRequired: false, transformFunction: null }, ascending: { classPropertyName: "ascending", publicName: "ascending", isSignal: true, isRequired: false, transformFunction: null }, filter: { classPropertyName: "filter", publicName: "filter", isSignal: true, isRequired: false, transformFunction: null }, loading: { classPropertyName: "loading", publicName: "loading", isSignal: true, isRequired: false, transformFunction: null }, items: { classPropertyName: "items", publicName: "items", isSignal: true, isRequired: false, transformFunction: null }, lstTableFields: { classPropertyName: "lstTableFields", publicName: "lstTableFields", isSignal: true, isRequired: false, transformFunction: null }, noFilters: { classPropertyName: "noFilters", publicName: "noFilters", isSignal: true, isRequired: false, transformFunction: null }, columnClass: { classPropertyName: "columnClass", publicName: "columnClass", isSignal: true, isRequired: false, transformFunction: null }, columnStyle: { classPropertyName: "columnStyle", publicName: "columnStyle", isSignal: true, isRequired: false, transformFunction: null }, noPagination: { classPropertyName: "noPagination", publicName: "noPagination", isSignal: true, isRequired: false, transformFunction: null }, itemPath: { classPropertyName: "itemPath", publicName: "itemPath", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { total: "totalChange", limit: "limitChange", page: "pageChange", orderByProperty: "orderByPropertyChange", ascending: "ascendingChange", filter: "filterChange", ativar: "ativar", refresh: "refresh", loading: "loadingChange", items: "itemsChange", lstTableFields: "lstTableFieldsChange", itemClick: "itemClick" }, ngImport: i0, template: "<!-- <div class=\"size-full rounded-2xl flex flex-col overflow-hidden relative\">\r\n <loading [type]=\"3\" [loading]=\"loading\"></loading>\r\n <content-block text=\"Sem Dados\" [value]=\"!(items.length != 0 || loading)\"></content-block>\r\n\r\n <div class=\"size-full shrink relative overflow-y-auto\">\r\n <table>\r\n <thead>\r\n <tr>\r\n <th scope=\"col\" class=\"px-3 !h-10\" *ngIf=\"acoesTemplate\"> A\u00E7\u00F5es </th>\r\n @for (field of lstTableFields; let i = $index; track i) {\r\n @if (!field.hidden) {\r\n <th scope=\"col\" class=\"p-2 px-3\" id=\"th-filter-select\">\r\n <div class=\"flex items-center justify-start h-full\" style=\"white-space: var(--ion-table-filter-wrap);\"> \r\n @if(!noFilters){\r\n <th-filter class=\"!text-base\" style=\"text-transform: none !important\" *ngIf=\"(field.type != InputTypeFile) && !(field.filter && field.disabledChange()) && !noFilters\"\r\n [field]=\"field\"\r\n (change)=\"ChangeFilter()\"\r\n ></th-filter>\r\n }\r\n <span>{{field.header}}</span>\r\n\r\n <a *ngIf=\"!(!(field.type != InputTypeFile) && !(field.filter && field.disabledChange())) && !noFilters\" class=\"order-switch h-5 flex items-center justify-center px-1 ml-2 shrink-0 cursor-pointer rounded-2xl\" (click)=\"SwitchOrder(field)\" [ngClass]=\"{ 'ordering-asc' : orderByProperty == field.index && ascending, 'ordering-desc' : orderByProperty == field.index && !ascending}\">\r\n <ion-icon id=\"up\" name=\"arrow-up\" class=\"-mt-1\"></ion-icon>\r\n <ion-icon id=\"down\" name=\"arrow-down\" class=\"-ml-1 -mb-1\"></ion-icon>\r\n </a>\r\n </div>\r\n </th>\r\n }\r\n }\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr [hidden]=\"loading\" *ngFor=\"let item of items\">\r\n @if(acoesTemplate){\r\n <td class=\"whitespace-nowrap py-1 px-3\" [style]=\"GetTdStyle('Acoes', item)\" >\r\n <ng-container *ngTemplateOutlet=\"acoesTemplate; context: { $implicit: item }\"></ng-container>\r\n </td>\r\n }\r\n\r\n @for (field of lstTableFields; track $index) {\r\n @if (!field.hidden) {\r\n <td class=\"px-3 py-2\" \r\n [ngClass]=\"GetTdClasses(field, item)\" \r\n [style]=\"GetTdStyle(field, item)\" \r\n (click)=\"Redirect(field, item)\"\r\n style=\"white-space: var(--ion-table-row-wrap);\"\r\n >\r\n @if (field.index == 'ativo') {\r\n <div class=\"w-full h-full flex items-center justify-start\" [routerLink]=\"null\">\r\n <ion-toggle [checked]=\"item[field.index]\" [disabled]=\"loading\" (ionChange)=\"Ativar(item.id)\" ></ion-toggle>\r\n </div>\r\n } @else {\r\n @switch (field.type) {\r\n @case (\"Bool\") {\r\n @if (field.configuration.type == \"toggle\") {\r\n <div class=\"-full h-full flex items-center justify-start\">\r\n <ion-toggle [checked]=\"item[field.index]\" [disabled]=\"true\"></ion-toggle>\r\n </div>\r\n }\r\n @else {\r\n <div class=\"-full h-full flex items-center justify-start\">\r\n <ion-checkbox [checked]=\"item[field.index]\" [disabled]=\"true\"></ion-checkbox>\r\n </div>\r\n }\r\n }\r\n @case (\"File\") {\r\n <download-button [(ngModel)]=\"item[field.index]\" [configuration]=\"field.configuration\"></download-button>\r\n }\r\n @case (\"Select\") {\r\n {{GetSelectLabel(item, field)}}\r\n }\r\n @default {\r\n {{GetField(item, field)}} \r\n }\r\n }\r\n }\r\n </td>\r\n }\r\n }\r\n </tr>\r\n\r\n <ng-content select=\"[slot=item-end]\"></ng-content>\r\n </tbody>\r\n </table>\r\n </div>\r\n @if(!noPagination){\r\n <div class=\"shrink-0 z-[100]\">\r\n <default-pagination\r\n [page]=\"page\"\r\n (pageChange)=\"EmitPage($event)\"\r\n [total]=\"total\"\r\n [limit]=\"limit\"\r\n [length]=\"items.length\"\r\n [loading]=\"loading\"\r\n ></default-pagination>\r\n </div>\r\n }\r\n</div> -->\r\n\r\n<div class=\"size-full rounded-xl flex flex-col overflow-hidden relative\">\r\n <loading [type]=\"3\" [loading]=\"loading()\"></loading>\r\n <content-block text=\"Sem Dados\" [value]=\"!(items.length != 0 || loading)\"></content-block>\r\n\r\n <div class=\"size-full shrink relative overflow-y-auto\">\r\n <table>\r\n <thead>\r\n <tr>\r\n @if(acoesTemplate){\r\n\r\n }\r\n <th scope=\"col\" class=\"p-2\"> \r\n A\u00E7\u00F5es \r\n </th>\r\n\r\n @for (tfa of lstTableFieldsAvailable(); track tfa.tf.index) {\r\n <th scope=\"col\" class=\"p-2\"> \r\n <div class=\"flex gap-2 items-center justify-start th\">\r\n @if(!noFilters()){\r\n <th-filter class=\"!text-base\" style=\"text-transform: none !important\" \r\n *ngIf=\"((tfa.tf.type != InputType.File || (tfa.tf.filter && tfa.tf.disabledChange())) && !noFilters())\"\r\n [field]=\"tfa.tf\"\r\n (change)=\"ChangeFilter()\"\r\n ></th-filter>\r\n }\r\n\r\n {{tfa.tf.header}} \r\n\r\n @if((tfa.tf.type != InputType.File || (tfa.tf.filter && tfa.tf.disabledChange())) && !noFilters()){\r\n <a [ngClass]=\"{ 'bg-light/10 !opacity-100': tfa.ascending || tfa.descending }\"\r\n class=\"order h-4 w-5 relative cursor-pointer rounded-lg opacity-0 default-transition\" \r\n (click)=\"SwitchOrder(tfa.tf)\"\r\n >\r\n <ion-icon \r\n [class.text-primary]=\"tfa.ascending\"\r\n class=\"absolute left-0 top-0\" \r\n name=\"arrow-up\"\r\n ></ion-icon> \r\n <ion-icon \r\n [class.text-primary]=\"tfa.descending\"\r\n class=\"absolute right-0 bottom-0\" \r\n name=\"arrow-down\"\r\n ></ion-icon> \r\n </a>\r\n }\r\n </div>\r\n </th>\r\n }\r\n </tr>\r\n </thead>\r\n <tbody>\r\n @for (row of lstRows; track row.id || $index) {\r\n <tr [hidden]=\"loading()\">\r\n @if(acoesTemplate){\r\n <td (click)=\"Redirect(undefined, row.item)\" class=\"whitespace-nowrap py-1 px-3 {{row.acoesClass}}\" [style]=\"row.acoesStyle\" >\r\n <ng-container *ngTemplateOutlet=\"acoesTemplate; context: { $implicit: row.item }\"></ng-container>\r\n </td>\r\n }\r\n\r\n @for (col of row.lstColumns; track col.tf.index) {\r\n <td class=\"{{col.class}} p-2 cursor-pointer\" (click)=\"Redirect(col.tf, row.item)\" [style]=\"'white-space: var(--ion-table-row-wrap);' + col.style\">\r\n @if(col.tf.index == 'ativo') {\r\n <div class=\"size-full flex items-center justify-start\" [routerLink]=\"null\">\r\n <ion-toggle [checked]=\"col.value\" [disabled]=\"loading()\" (ionChange)=\"Ativar(row.id)\" ></ion-toggle>\r\n </div>\r\n }\r\n @else if (col.tf.type == InputType.Bool){\r\n <div class=\"h-full flex items-center justify-start\">\r\n @if(col.tf.configuration.type == 'toggle') {\r\n <ion-toggle [checked]=\"col.value\" [disabled]=\"true\"></ion-toggle>\r\n }\r\n @else {\r\n <ion-checkbox [checked]=\"col.value\" [disabled]=\"true\"></ion-checkbox>\r\n }\r\n </div>\r\n }\r\n @else if (col.tf.type == InputType.File) {\r\n <download-button [(ngModel)]=\"col.value\" [configuration]=\"col.tf.configuration\"></download-button>\r\n }\r\n @else if (col.loading){\r\n <ion-spinner name=\"dots\"></ion-spinner>\r\n } @else {\r\n {{col.label}}\r\n }\r\n </td>\r\n }\r\n </tr>\r\n <ng-content select=\"[slot=item-end]\"></ng-content>\r\n }\r\n </tbody>\r\n </table>\r\n </div>\r\n @if(!noPagination()){\r\n <div class=\"shrink-0 z-[100]\">\r\n <default-pagination\r\n [page]=\"page()\"\r\n (pageChange)=\"page.set($event); refresh.emit()\"\r\n [total]=\"total()\"\r\n [limit]=\"limit()\"\r\n [length]=\"items().length\"\r\n [loading]=\"loading()\"\r\n ></default-pagination>\r\n </div>\r\n }\r\n\r\n <!-- <div class=\"overflow-y-auto\">\r\n @for (item of lstRows; track $index) {\r\n <div class=\"border border-red-500 flex\">\r\n {{$index}} - \r\n @for (lbl of item.lstColumns; track $index) {\r\n ([{{lbl.label}}])\r\n }\r\n </div>\r\n }\r\n </div> -->\r\n</div>", styles: [".th:hover>.order{opacity:1;background-color:color-mix(in srgb,var(--ion-color-light) 10%,transparent)}\n"], dependencies: [{ kind: "component", type: i3.IonCheckbox, selector: "ion-checkbox", inputs: ["alignment", "checked", "color", "disabled", "errorText", "helperText", "indeterminate", "justify", "labelPlacement", "mode", "name", "required", "value"] }, { kind: "component", type: i3.IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }, { kind: "component", type: i3.IonSpinner, selector: "ion-spinner", inputs: ["color", "duration", "name", "paused"] }, { kind: "component", type: i3.IonToggle, selector: "ion-toggle", inputs: ["alignment", "checked", "color", "disabled", "enableOnOffLabels", "errorText", "helperText", "justify", "labelPlacement", "mode", "name", "required", "value"] }, { kind: "directive", type: i3.BooleanValueAccessor, selector: "ion-checkbox,ion-toggle" }, { kind: "directive", type: i3.RouterLinkDelegate, selector: ":not(a):not(area)[routerLink]" }, { kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i5.DownloadButtonComponent, selector: "download-button", inputs: ["expand", "value", "size", "color", "params", "disabled", "post", "configuration"], outputs: ["valueChange"] }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i7.LoadingComponent, selector: "loading", inputs: ["text", "type", "loading"] }, { kind: "component", type: i8.ContentBlockComponent, selector: "content-block", inputs: ["text", "value"] }, { kind: "component", type: i9.DefaultPaginationComponent, selector: "default-pagination", inputs: ["total", "limit", "length", "loading", "page"], outputs: ["pageChange", "change"] }, { kind: "component", type: i10.ThFilterComponent, selector: "th-filter", inputs: ["field"], outputs: ["change"] }] }); }
|
|
163
184
|
}
|
|
164
185
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DefaultTableComponent, decorators: [{
|
|
165
186
|
type: Component,
|
|
166
|
-
args: [{ selector: 'default-table', template: "<!-- <section class=\"w-full h-full rounded-2xl flex flex-col overflow-y-hidden relative\" [ngClass]=\"{ 'loading' : loading }\">\r\n \r\n <div class=\"unique-conteiner default-transition\" [ngClass]=\"{'!-z-50 !-translate-y-12 !opacity-0': !loading }\">\r\n <loading [type]=\"2\"></loading>\r\n </div>\r\n <div class=\"unique-conteiner default-transition\" [ngClass]=\"{'!-z-50 !-translate-y-12 !opacity-0': items.length != 0 || loading }\">\r\n <b><ion-icon class=\"align-sub\" name=\"remove-circle\"></ion-icon> Sem dados</b>\r\n </div>\r\n\r\n <div id=\"wrapper\" class=\"relative overflow-y-auto w-full grow-0 mb-auto pb-2\">\r\n <table class=\"z-20 overflow-visible\">\r\n <thead>\r\n <tr>\r\n <th scope=\"col\" class=\"px-3 !h-10\" *ngIf=\"acoesTemplate\">\r\n <span>A\u00E7\u00F5es</span>\r\n </th>\r\n @for (field of lstTableFields; let i = $index; track i) {\r\n @if (!field.hidden) {\r\n <th scope=\"col\" class=\"p-2 px-3\" id=\"th-filter-select\">\r\n <div class=\"flex items-center justify-start h-full\" style=\"white-space: var(--ion-table-filter-wrap);\"> \r\n @if(!noFilters){\r\n <th-filter class=\"!text-base\" style=\"text-transform: none !important\" *ngIf=\"(field.type != InputTypeFile) && !(field.filter && field.disabledChange()) && !noFilters\"\r\n [field]=\"field\"\r\n (change)=\"ChangeFilter()\"\r\n ></th-filter>\r\n }\r\n <span>{{field.header}}</span>\r\n\r\n <a *ngIf=\"!(!(field.type != InputTypeFile) && !(field.filter && field.disabledChange())) && !noFilters\" class=\"order-switch h-5 flex items-center justify-center px-1 ml-2 shrink-0 cursor-pointer rounded-2xl\" (click)=\"SwitchOrder(field)\" [ngClass]=\"{ 'ordering-asc' : orderByProperty == field.index && ascending, 'ordering-desc' : orderByProperty == field.index && !ascending}\">\r\n <ion-icon id=\"up\" name=\"arrow-up\" class=\"-mt-1\"></ion-icon>\r\n <ion-icon id=\"down\" name=\"arrow-down\" class=\"-ml-1 -mb-1\"></ion-icon>\r\n </a>\r\n </div>\r\n </th>\r\n }\r\n }\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr [hidden]=\"loading\" *ngFor=\"let item of items\">\r\n @if(acoesTemplate){\r\n <td class=\"whitespace-nowrap py-1 px-3\" [style]=\"GetTdStyle('Acoes', item)\" >\r\n <ng-container *ngTemplateOutlet=\"acoesTemplate; context: { $implicit: item }\"></ng-container>\r\n </td>\r\n }\r\n\r\n @for (field of lstTableFields; track $index) {\r\n @if (!field.hidden) {\r\n <td class=\"px-3 py-2\" \r\n [ngClass]=\"GetTdClasses(field, item)\" \r\n [style]=\"GetTdStyle(field, item)\" \r\n (click)=\"Redirect(field, item)\"\r\n style=\"white-space: var(--ion-table-row-wrap);\"\r\n >\r\n @if (field.index == 'ativo') {\r\n <div class=\"w-full h-full flex items-center justify-start\" [routerLink]=\"null\">\r\n <ion-toggle [checked]=\"item[field.index]\" [disabled]=\"loading\" (ionChange)=\"Ativar(item.id)\" ></ion-toggle>\r\n </div>\r\n } @else {\r\n @switch (field.type) {\r\n @case (\"Bool\") {\r\n @if (field.configuration.type == \"toggle\") {\r\n <div class=\"-full h-full flex items-center justify-start\">\r\n <ion-toggle [checked]=\"item[field.index]\" [disabled]=\"true\"></ion-toggle>\r\n </div>\r\n }\r\n @else {\r\n <div class=\"-full h-full flex items-center justify-start\">\r\n <ion-checkbox [checked]=\"item[field.index]\" [disabled]=\"true\"></ion-checkbox>\r\n </div>\r\n }\r\n }\r\n @case (\"File\") {\r\n <download-button [(ngModel)]=\"item[field.index]\" [configuration]=\"field.configuration\"></download-button>\r\n }\r\n @case (\"Select\") {\r\n {{GetSelectLabel(item, field)}}\r\n }\r\n @default {\r\n {{GetField(item, field)}} \r\n }\r\n }\r\n }\r\n </td>\r\n }\r\n }\r\n </tr>\r\n\r\n <ng-content select=\"[slot=item-end]\"></ng-content>\r\n </tbody>\r\n </table>\r\n </div>\r\n @if(!noPagination){\r\n <div class=\"shrink-0 mt-auto w-full\">\r\n <default-pagination\r\n [page]=\"page\"\r\n (pageChange)=\"EmitPage($event)\"\r\n [total]=\"total\"\r\n [limit]=\"limit\"\r\n [length]=\"items.length\"\r\n [loading]=\"loading\"\r\n ></default-pagination>\r\n </div>\r\n }\r\n</section> -->\r\n<div class=\"size-full rounded-2xl flex flex-col overflow-hidden relative\">\r\n <loading [type]=\"3\" [loading]=\"loading\"></loading>\r\n <content-block text=\"Sem Dados\" [value]=\"!(items.length != 0 || loading)\"></content-block>\r\n\r\n <div class=\"size-full shrink relative overflow-y-auto\">\r\n <table>\r\n <thead>\r\n <tr>\r\n <th scope=\"col\" class=\"px-3 !h-10\" *ngIf=\"acoesTemplate\"> A\u00E7\u00F5es </th>\r\n @for (field of lstTableFields; let i = $index; track i) {\r\n @if (!field.hidden) {\r\n <th scope=\"col\" class=\"p-2 px-3\" id=\"th-filter-select\">\r\n <div class=\"flex items-center justify-start h-full\" style=\"white-space: var(--ion-table-filter-wrap);\"> \r\n @if(!noFilters){\r\n <th-filter class=\"!text-base\" style=\"text-transform: none !important\" *ngIf=\"(field.type != InputTypeFile) && !(field.filter && field.disabledChange()) && !noFilters\"\r\n [field]=\"field\"\r\n (change)=\"ChangeFilter()\"\r\n ></th-filter>\r\n }\r\n <span>{{field.header}}</span>\r\n\r\n <a *ngIf=\"!(!(field.type != InputTypeFile) && !(field.filter && field.disabledChange())) && !noFilters\" class=\"order-switch h-5 flex items-center justify-center px-1 ml-2 shrink-0 cursor-pointer rounded-2xl\" (click)=\"SwitchOrder(field)\" [ngClass]=\"{ 'ordering-asc' : orderByProperty == field.index && ascending, 'ordering-desc' : orderByProperty == field.index && !ascending}\">\r\n <ion-icon id=\"up\" name=\"arrow-up\" class=\"-mt-1\"></ion-icon>\r\n <ion-icon id=\"down\" name=\"arrow-down\" class=\"-ml-1 -mb-1\"></ion-icon>\r\n </a>\r\n </div>\r\n </th>\r\n }\r\n }\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr [hidden]=\"loading\" *ngFor=\"let item of items\">\r\n @if(acoesTemplate){\r\n <td class=\"whitespace-nowrap py-1 px-3\" [style]=\"GetTdStyle('Acoes', item)\" >\r\n <ng-container *ngTemplateOutlet=\"acoesTemplate; context: { $implicit: item }\"></ng-container>\r\n </td>\r\n }\r\n\r\n @for (field of lstTableFields; track $index) {\r\n @if (!field.hidden) {\r\n <td class=\"px-3 py-2\" \r\n [ngClass]=\"GetTdClasses(field, item)\" \r\n [style]=\"GetTdStyle(field, item)\" \r\n (click)=\"Redirect(field, item)\"\r\n style=\"white-space: var(--ion-table-row-wrap);\"\r\n >\r\n @if (field.index == 'ativo') {\r\n <div class=\"w-full h-full flex items-center justify-start\" [routerLink]=\"null\">\r\n <ion-toggle [checked]=\"item[field.index]\" [disabled]=\"loading\" (ionChange)=\"Ativar(item.id)\" ></ion-toggle>\r\n </div>\r\n } @else {\r\n @switch (field.type) {\r\n @case (\"Bool\") {\r\n @if (field.configuration.type == \"toggle\") {\r\n <div class=\"-full h-full flex items-center justify-start\">\r\n <ion-toggle [checked]=\"item[field.index]\" [disabled]=\"true\"></ion-toggle>\r\n </div>\r\n }\r\n @else {\r\n <div class=\"-full h-full flex items-center justify-start\">\r\n <ion-checkbox [checked]=\"item[field.index]\" [disabled]=\"true\"></ion-checkbox>\r\n </div>\r\n }\r\n }\r\n @case (\"File\") {\r\n <download-button [(ngModel)]=\"item[field.index]\" [configuration]=\"field.configuration\"></download-button>\r\n }\r\n @case (\"Select\") {\r\n {{GetSelectLabel(item, field)}}\r\n }\r\n @default {\r\n {{GetField(item, field)}} \r\n }\r\n }\r\n }\r\n </td>\r\n }\r\n }\r\n </tr>\r\n\r\n <ng-content select=\"[slot=item-end]\"></ng-content>\r\n </tbody>\r\n </table>\r\n </div>\r\n @if(!noPagination){\r\n <div class=\"shrink-0 z-[100]\">\r\n <default-pagination\r\n [page]=\"page\"\r\n (pageChange)=\"EmitPage($event)\"\r\n [total]=\"total\"\r\n [limit]=\"limit\"\r\n [length]=\"items.length\"\r\n [loading]=\"loading\"\r\n ></default-pagination>\r\n </div>\r\n }\r\n</div>", styles: ["#th-filter-select:hover .order-switch{background-color:var(--ion-color-step-200)}#th-filter-select:hover .order-switch #up,#th-filter-select:hover .order-switch #down{opacity:1!important;color:var(--ion-color-step-700)!important}#th-filter-select .order-switch{transition:background-color .3s}#th-filter-select .order-switch #up,#th-filter-select .order-switch #down{opacity:0;transition:all .3s}#th-filter-select .order-switch.ordering-asc #up{color:var(--ion-color-primary)!important;opacity:1}#th-filter-select .order-switch.ordering-asc #down,#th-filter-select .order-switch.ordering-desc #up{color:var(--ion-color-step-800)!important;opacity:1}#th-filter-select .order-switch.ordering-desc #down{color:var(--ion-color-primary)!important;opacity:1}\n"] }]
|
|
167
|
-
}], ctorParameters: () => [{ type: i1.StorageService }, { type: i2.ActivatedRoute }, { type: i2.Router }], propDecorators: {
|
|
168
|
-
type: Input,
|
|
169
|
-
args: ['service']
|
|
170
|
-
}], acoesTemplate: [{
|
|
171
|
-
type: Input
|
|
172
|
-
}], total: [{
|
|
173
|
-
type: Input
|
|
174
|
-
}], limit: [{
|
|
175
|
-
type: Input
|
|
176
|
-
}], limitChange: [{
|
|
177
|
-
type: Output
|
|
178
|
-
}], page: [{
|
|
179
|
-
type: Input
|
|
180
|
-
}], pageChange: [{
|
|
181
|
-
type: Output
|
|
182
|
-
}], orderByProperty: [{
|
|
183
|
-
type: Input
|
|
184
|
-
}], orderByPropertyChange: [{
|
|
185
|
-
type: Output
|
|
186
|
-
}], ascending: [{
|
|
187
|
-
type: Input
|
|
188
|
-
}], ascendingChange: [{
|
|
189
|
-
type: Output
|
|
190
|
-
}], filter: [{
|
|
191
|
-
type: Input,
|
|
192
|
-
args: ['filter']
|
|
193
|
-
}], filterChange: [{
|
|
194
|
-
type: Output
|
|
195
|
-
}], ativarEmitter: [{
|
|
196
|
-
type: Output,
|
|
197
|
-
args: ['ativar']
|
|
198
|
-
}], refreshEmitter: [{
|
|
199
|
-
type: Output,
|
|
200
|
-
args: ['refresh']
|
|
201
|
-
}], loading: [{
|
|
202
|
-
type: Input
|
|
203
|
-
}], items: [{
|
|
204
|
-
type: Input
|
|
205
|
-
}], lstTableFields: [{
|
|
206
|
-
type: Input
|
|
207
|
-
}], noFilters: [{
|
|
208
|
-
type: Input
|
|
209
|
-
}], columnClass: [{
|
|
210
|
-
type: Input
|
|
211
|
-
}], columnStyle: [{
|
|
212
|
-
type: Input
|
|
213
|
-
}], noPagination: [{
|
|
214
|
-
type: Input
|
|
215
|
-
}], itemPath: [{
|
|
187
|
+
args: [{ selector: 'default-table', template: "<!-- <div class=\"size-full rounded-2xl flex flex-col overflow-hidden relative\">\r\n <loading [type]=\"3\" [loading]=\"loading\"></loading>\r\n <content-block text=\"Sem Dados\" [value]=\"!(items.length != 0 || loading)\"></content-block>\r\n\r\n <div class=\"size-full shrink relative overflow-y-auto\">\r\n <table>\r\n <thead>\r\n <tr>\r\n <th scope=\"col\" class=\"px-3 !h-10\" *ngIf=\"acoesTemplate\"> A\u00E7\u00F5es </th>\r\n @for (field of lstTableFields; let i = $index; track i) {\r\n @if (!field.hidden) {\r\n <th scope=\"col\" class=\"p-2 px-3\" id=\"th-filter-select\">\r\n <div class=\"flex items-center justify-start h-full\" style=\"white-space: var(--ion-table-filter-wrap);\"> \r\n @if(!noFilters){\r\n <th-filter class=\"!text-base\" style=\"text-transform: none !important\" *ngIf=\"(field.type != InputTypeFile) && !(field.filter && field.disabledChange()) && !noFilters\"\r\n [field]=\"field\"\r\n (change)=\"ChangeFilter()\"\r\n ></th-filter>\r\n }\r\n <span>{{field.header}}</span>\r\n\r\n <a *ngIf=\"!(!(field.type != InputTypeFile) && !(field.filter && field.disabledChange())) && !noFilters\" class=\"order-switch h-5 flex items-center justify-center px-1 ml-2 shrink-0 cursor-pointer rounded-2xl\" (click)=\"SwitchOrder(field)\" [ngClass]=\"{ 'ordering-asc' : orderByProperty == field.index && ascending, 'ordering-desc' : orderByProperty == field.index && !ascending}\">\r\n <ion-icon id=\"up\" name=\"arrow-up\" class=\"-mt-1\"></ion-icon>\r\n <ion-icon id=\"down\" name=\"arrow-down\" class=\"-ml-1 -mb-1\"></ion-icon>\r\n </a>\r\n </div>\r\n </th>\r\n }\r\n }\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr [hidden]=\"loading\" *ngFor=\"let item of items\">\r\n @if(acoesTemplate){\r\n <td class=\"whitespace-nowrap py-1 px-3\" [style]=\"GetTdStyle('Acoes', item)\" >\r\n <ng-container *ngTemplateOutlet=\"acoesTemplate; context: { $implicit: item }\"></ng-container>\r\n </td>\r\n }\r\n\r\n @for (field of lstTableFields; track $index) {\r\n @if (!field.hidden) {\r\n <td class=\"px-3 py-2\" \r\n [ngClass]=\"GetTdClasses(field, item)\" \r\n [style]=\"GetTdStyle(field, item)\" \r\n (click)=\"Redirect(field, item)\"\r\n style=\"white-space: var(--ion-table-row-wrap);\"\r\n >\r\n @if (field.index == 'ativo') {\r\n <div class=\"w-full h-full flex items-center justify-start\" [routerLink]=\"null\">\r\n <ion-toggle [checked]=\"item[field.index]\" [disabled]=\"loading\" (ionChange)=\"Ativar(item.id)\" ></ion-toggle>\r\n </div>\r\n } @else {\r\n @switch (field.type) {\r\n @case (\"Bool\") {\r\n @if (field.configuration.type == \"toggle\") {\r\n <div class=\"-full h-full flex items-center justify-start\">\r\n <ion-toggle [checked]=\"item[field.index]\" [disabled]=\"true\"></ion-toggle>\r\n </div>\r\n }\r\n @else {\r\n <div class=\"-full h-full flex items-center justify-start\">\r\n <ion-checkbox [checked]=\"item[field.index]\" [disabled]=\"true\"></ion-checkbox>\r\n </div>\r\n }\r\n }\r\n @case (\"File\") {\r\n <download-button [(ngModel)]=\"item[field.index]\" [configuration]=\"field.configuration\"></download-button>\r\n }\r\n @case (\"Select\") {\r\n {{GetSelectLabel(item, field)}}\r\n }\r\n @default {\r\n {{GetField(item, field)}} \r\n }\r\n }\r\n }\r\n </td>\r\n }\r\n }\r\n </tr>\r\n\r\n <ng-content select=\"[slot=item-end]\"></ng-content>\r\n </tbody>\r\n </table>\r\n </div>\r\n @if(!noPagination){\r\n <div class=\"shrink-0 z-[100]\">\r\n <default-pagination\r\n [page]=\"page\"\r\n (pageChange)=\"EmitPage($event)\"\r\n [total]=\"total\"\r\n [limit]=\"limit\"\r\n [length]=\"items.length\"\r\n [loading]=\"loading\"\r\n ></default-pagination>\r\n </div>\r\n }\r\n</div> -->\r\n\r\n<div class=\"size-full rounded-xl flex flex-col overflow-hidden relative\">\r\n <loading [type]=\"3\" [loading]=\"loading()\"></loading>\r\n <content-block text=\"Sem Dados\" [value]=\"!(items.length != 0 || loading)\"></content-block>\r\n\r\n <div class=\"size-full shrink relative overflow-y-auto\">\r\n <table>\r\n <thead>\r\n <tr>\r\n @if(acoesTemplate){\r\n\r\n }\r\n <th scope=\"col\" class=\"p-2\"> \r\n A\u00E7\u00F5es \r\n </th>\r\n\r\n @for (tfa of lstTableFieldsAvailable(); track tfa.tf.index) {\r\n <th scope=\"col\" class=\"p-2\"> \r\n <div class=\"flex gap-2 items-center justify-start th\">\r\n @if(!noFilters()){\r\n <th-filter class=\"!text-base\" style=\"text-transform: none !important\" \r\n *ngIf=\"((tfa.tf.type != InputType.File || (tfa.tf.filter && tfa.tf.disabledChange())) && !noFilters())\"\r\n [field]=\"tfa.tf\"\r\n (change)=\"ChangeFilter()\"\r\n ></th-filter>\r\n }\r\n\r\n {{tfa.tf.header}} \r\n\r\n @if((tfa.tf.type != InputType.File || (tfa.tf.filter && tfa.tf.disabledChange())) && !noFilters()){\r\n <a [ngClass]=\"{ 'bg-light/10 !opacity-100': tfa.ascending || tfa.descending }\"\r\n class=\"order h-4 w-5 relative cursor-pointer rounded-lg opacity-0 default-transition\" \r\n (click)=\"SwitchOrder(tfa.tf)\"\r\n >\r\n <ion-icon \r\n [class.text-primary]=\"tfa.ascending\"\r\n class=\"absolute left-0 top-0\" \r\n name=\"arrow-up\"\r\n ></ion-icon> \r\n <ion-icon \r\n [class.text-primary]=\"tfa.descending\"\r\n class=\"absolute right-0 bottom-0\" \r\n name=\"arrow-down\"\r\n ></ion-icon> \r\n </a>\r\n }\r\n </div>\r\n </th>\r\n }\r\n </tr>\r\n </thead>\r\n <tbody>\r\n @for (row of lstRows; track row.id || $index) {\r\n <tr [hidden]=\"loading()\">\r\n @if(acoesTemplate){\r\n <td (click)=\"Redirect(undefined, row.item)\" class=\"whitespace-nowrap py-1 px-3 {{row.acoesClass}}\" [style]=\"row.acoesStyle\" >\r\n <ng-container *ngTemplateOutlet=\"acoesTemplate; context: { $implicit: row.item }\"></ng-container>\r\n </td>\r\n }\r\n\r\n @for (col of row.lstColumns; track col.tf.index) {\r\n <td class=\"{{col.class}} p-2 cursor-pointer\" (click)=\"Redirect(col.tf, row.item)\" [style]=\"'white-space: var(--ion-table-row-wrap);' + col.style\">\r\n @if(col.tf.index == 'ativo') {\r\n <div class=\"size-full flex items-center justify-start\" [routerLink]=\"null\">\r\n <ion-toggle [checked]=\"col.value\" [disabled]=\"loading()\" (ionChange)=\"Ativar(row.id)\" ></ion-toggle>\r\n </div>\r\n }\r\n @else if (col.tf.type == InputType.Bool){\r\n <div class=\"h-full flex items-center justify-start\">\r\n @if(col.tf.configuration.type == 'toggle') {\r\n <ion-toggle [checked]=\"col.value\" [disabled]=\"true\"></ion-toggle>\r\n }\r\n @else {\r\n <ion-checkbox [checked]=\"col.value\" [disabled]=\"true\"></ion-checkbox>\r\n }\r\n </div>\r\n }\r\n @else if (col.tf.type == InputType.File) {\r\n <download-button [(ngModel)]=\"col.value\" [configuration]=\"col.tf.configuration\"></download-button>\r\n }\r\n @else if (col.loading){\r\n <ion-spinner name=\"dots\"></ion-spinner>\r\n } @else {\r\n {{col.label}}\r\n }\r\n </td>\r\n }\r\n </tr>\r\n <ng-content select=\"[slot=item-end]\"></ng-content>\r\n }\r\n </tbody>\r\n </table>\r\n </div>\r\n @if(!noPagination()){\r\n <div class=\"shrink-0 z-[100]\">\r\n <default-pagination\r\n [page]=\"page()\"\r\n (pageChange)=\"page.set($event); refresh.emit()\"\r\n [total]=\"total()\"\r\n [limit]=\"limit()\"\r\n [length]=\"items().length\"\r\n [loading]=\"loading()\"\r\n ></default-pagination>\r\n </div>\r\n }\r\n\r\n <!-- <div class=\"overflow-y-auto\">\r\n @for (item of lstRows; track $index) {\r\n <div class=\"border border-red-500 flex\">\r\n {{$index}} - \r\n @for (lbl of item.lstColumns; track $index) {\r\n ([{{lbl.label}}])\r\n }\r\n </div>\r\n }\r\n </div> -->\r\n</div>", styles: [".th:hover>.order{opacity:1;background-color:color-mix(in srgb,var(--ion-color-light) 10%,transparent)}\n"] }]
|
|
188
|
+
}], ctorParameters: () => [{ type: i1.StorageService }, { type: i2.ActivatedRoute }, { type: i2.Router }], propDecorators: { acoesTemplate: [{
|
|
216
189
|
type: Input
|
|
217
190
|
}] } });
|
|
218
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"default-table.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/default/default-table/default-table.component.ts","../../../../../../src/lib/components/default/default-table/default-table.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5F,OAAO,EAAE,cAAc,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AACzD,OAAO,EAAE,YAAY,EAAG,MAAM,iBAAiB,CAAC;AAEhD,OAAO,EAAc,oBAAoB,EAAE,MAAM,wCAAwC,CAAC;AAE1F,OAAO,EAAE,wBAAwB,EAAE,MAAM,oEAAoE,CAAC;AAC9G,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAC;AAGvE,OAAO,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAC;AACpD,OAAO,EAAE,KAAK,EAAE,MAAM,iCAAiC,CAAC;;;;;;;;;;;;AAExD,kCAAkC;AAMlC,MAAM,OAAO,qBAAqB;IA0DhC,YACS,cAA+B,EAC9B,cAA8B,EAC9B,MAAsB;QAFvB,mBAAc,GAAd,cAAc,CAAiB;QAC9B,mBAAc,GAAd,cAAc,CAAgB;QAC9B,WAAM,GAAN,MAAM,CAAgB;QAhDtB,gBAAW,GAAyB,IAAI,YAAY,EAAU,CAAC;QAI/D,eAAU,GAAyB,IAAI,YAAY,EAAU,CAAC;QAI9D,0BAAqB,GAAgC,IAAI,YAAY,EAAiB,CAAC;QAMvF,oBAAe,GAA0B,IAAI,YAAY,EAAW,CAAC;QAC/E,2BAA2B;QAE3B,4CAA4C;QAC3B,WAAM,GAAiB,EAAE,CAAC;QACjC,iBAAY,GAA+B,IAAI,YAAY,EAAgB,CAAC;QAEtF,uEAAuE;QACrD,kBAAa,GAAyB,IAAI,YAAoB,CAAC;QAC9D,mBAAc,GAAuB,IAAI,YAAY,EAAQ,CAAC;QAGjF,oCAAoC;QAC3B,UAAK,GAAU,EAAE,CAAC;QAE3B,qCAAqC;QAC5B,mBAAc,GAAiB,EAAE,CAAC;QAE3C,gDAAgD;QACvC,cAAS,GAAY,KAAK,CAAC;QAEpC,gGAAgG;QACvF,gBAAW,GAAmD,IAAI,CAAC;QAC5E,8FAA8F;QACrF,gBAAW,GAAmD,IAAI,CAAC;QAC5E,qCAAqC;QAC5B,iBAAY,GAAY,KAAK,CAAC;QACvC,0CAA0C;QACjC,aAAQ,GAAkB,UAAU,CAAA;QAC7C,kBAAa,GAAG,SAAS,CAAC,IAAI,CAAA;IAM1B,CAAC;IAEL,QAAQ,CAAC,KAAiB,EAAE,IAAS;QACnC,IAAG,KAAK,CAAC,KAAK,IAAI,OAAO,EAAC,CAAC;YACzB,OAAO;QACT,CAAC;aACD,IAAG,KAAK,CAAC,IAAI,IAAK,MAAM,EAAC,CAAC;YACxB,OAAO;QACT,CAAC;aAAI,CAAC;YACJ,IAAG,IAAI,CAAC,QAAQ,EAAC,CAAC;gBAChB,MAAM,EAAE,GAAG,IAAI,CAAC,EAAE,CAAC;gBACnB,MAAM,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,QAAQ,EAAE,CAAC,CAAC;gBACzD,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,KAAK,IAAI,EAAE,CAAC,EAAE,EAAE,UAAU,EAAE,IAAI,CAAC,cAAc,EAAE,CAAC,CAAA;YAC1E,CAAC;QACH,CAAC;IACH,CAAC;IAED,QAAQ;QACN,IAAG,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,cAAc,CAAC,MAAM,IAAI,CAAC,EAAC,CAAC;YACzD,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC;QAC3D,CAAC;QACD,IAAG,IAAI,CAAC,cAAc,CAAC,MAAM,IAAI,CAAC,EAAC,CAAC;YAAC,OAAO,CAAC,IAAI,CAAC,8CAA8C,CAAC,CAAA;QAAC,CAAC;QAEnG,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,aAAa,YAAY,wBAAwB,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,aAAa,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC,CAAC;IAC1I,CAAC;IAED,WAAW,CAAC,KAAiB;QAC3B,IAAG,IAAI,CAAC,eAAe,IAAI,KAAK,CAAC,KAAK,EAAC,CAAC;YACtC,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC,KAAK,CAAC;YACnC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACxB,CAAC;aACI,IAAG,IAAI,CAAC,SAAS,EAAC,CAAC;YACtB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACzB,CAAC;aACG,CAAC;YAAC,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;QAAC,CAAC;QAEpC,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,CAAA;QACrD,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAE1C,IAAI,CAAC,UAAU,EAAE,CAAC;IACpB,CAAC;IAED,QAAQ,CAAC,KAAa;QACpB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC5B,IAAI,CAAC,UAAU,EAAE,CAAA;IACnB,CAAC;IAED,UAAU;QACR,IAAI,CAAC,cAAc,CAAC,IAAI,EAAE,CAAC;IAC7B,CAAC;IAED,QAAQ,CAAC,IAAS,EAAE,KAAkB;QACpC,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QAChC,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC;QACxB,IAAG,CAAC,QAAQ,EAAC,SAAS,EAAC,UAAU,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAC,CAAC;YACjD,MAAM,MAAM,GAA+B,KAAK,CAAC,aAA2C,CAAA;YAC5F,OAAO,MAAM,CAAC,MAAM,GAAG,GAAG,GAAG,YAAY,CAAC,KAAK,EAAE,OAAO,EAAE,KAAK,MAAM,CAAC,SAAS,IAAI,MAAM,CAAC,SAAS,EAAE,CAAC,GAAG,GAAG,GAAG,MAAM,CAAC,KAAK,CAAC;QAC9H,CAAC;aACD,IAAG,IAAI,IAAI,UAAU,EAAC,CAAC;YACrB,IAAG,CAAC,KAAK,EAAC,CAAC;gBAAC,OAAO,GAAG,CAAC;YAAC,CAAC;YACzB,OAAO,KAAK,CAAC,qBAAqB,CAAC,KAAK,CAAC,CAAC;QAC5C,CAAC;aACD,IAAG,IAAI,IAAI,MAAM,EAAC,CAAC;YACjB,IAAG,CAAC,KAAK,EAAC,CAAC;gBAAC,OAAO,GAAG,CAAC;YAAC,CAAC;YACzB,OAAO,KAAK,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;QACxC,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IAED,cAAc,CAAC,IAAS,EAAE,MAAkB;QAC1C,MAAM,aAAa,GAA6B,MAAM,CAAC,aAAa,CAAC;QACrE,IAAG,CAAC,aAAa,CAAC,QAAQ,EAAC,CAAC;YAC1B,OAAO,aAAa,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC,CAAC;QACpE,CAAC;aAAI,CAAC;YACJ,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;YAC3C,IAAG,MAAM,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAC,CAAC;gBAC9B,OAAO,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,aAAa,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACtE,CAAC;iBAAI,CAAC;gBACJ,OAAO,EAAE,CAAC;YACZ,CAAC;QACH,CAAC;IACH,CAAC;IAED,SAAS,CAAC,GAAG;QACX,OAAO,OAAM,CAAC,GAAG,CAAC,CAAA;IACpB,CAAC;IAED,MAAM,CAAC,EAAE;QACP,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAC9B,CAAC;IAED,YAAY;QACV,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC;QAClE,IAAI,CAAC,cAAc,CAAC,IAAI,EAAE,CAAC;IAC7B,CAAC;IAED,YAAY,CAAC,KAAK,EAAE,IAAI;QACtB,IAAI,OAAO,GAAY,EAAE,CAAC;QAC1B,IAAG,CAAC,UAAU,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,EAAC,CAAC;YACpD,OAAO,IAAI,YAAY,CAAC;QAC1B,CAAC;QACD,IAAG,IAAI,CAAC,WAAW,EAAC,CAAC;YACnB,OAAO,IAAI,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;QACjD,CAAC;QACD,OAAO,OAAO,CAAC;IACjB,CAAC;IACD,UAAU,CAAC,KAAK,EAAE,IAAI;QACpB,IAAG,IAAI,CAAC,WAAW,EAAC,CAAC;YACnB,OAAO,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;QACvC,CAAC;QACD,OAAO,EAAE,CAAC;IACZ,CAAC;+GA7KU,qBAAqB;mGAArB,qBAAqB,+rBCnBlC,69YA0MM;;4FDvLO,qBAAqB;kBALjC,SAAS;+BACE,eAAe;qIAOP,cAAc;sBAA/B,KAAK;uBAAC,SAAS;gBAEP,aAAa;sBAArB,KAAK;gBAIG,KAAK;sBAAb,KAAK;gBAGG,KAAK;sBAAb,KAAK;gBACI,WAAW;sBAApB,MAAM;gBAGE,IAAI;sBAAZ,KAAK;gBACI,UAAU;sBAAnB,MAAM;gBAGE,eAAe;sBAAvB,KAAK;gBACI,qBAAqB;sBAA9B,MAAM;gBAKE,SAAS;sBAAjB,KAAK;gBACI,eAAe;sBAAxB,MAAM;gBAIU,MAAM;sBAAtB,KAAK;uBAAC,QAAQ;gBACL,YAAY;sBAArB,MAAM;gBAGW,aAAa;sBAA9B,MAAM;uBAAC,QAAQ;gBACG,cAAc;sBAAhC,MAAM;uBAAC,SAAS;gBACR,OAAO;sBAAf,KAAK;gBAGG,KAAK;sBAAb,KAAK;gBAGG,cAAc;sBAAtB,KAAK;gBAGG,SAAS;sBAAjB,KAAK;gBAGG,WAAW;sBAAnB,KAAK;gBAEG,WAAW;sBAAnB,KAAK;gBAEG,YAAY;sBAApB,KAAK;gBAEG,QAAQ;sBAAhB,KAAK","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output, TemplateRef } from '@angular/core';\r\nimport { ActivatedRoute, Router } from '@angular/router';\r\nimport { formatNumber  } from '@angular/common';\r\n\r\nimport { Comparison, CompileLstTableField } from '../../../classes/comparison/comparison';\r\nimport { InputDecimalConfiguration } from '../../../components/inputs/input-decimal/input-decimal.configuration';\r\nimport { InputSelectConfiguration } from '../../../components/inputs/input-select/input.select.configuration';\r\nimport { StorageService } from '../../../services/web/storage.service';\r\nimport { HttpService } from '../../../services/web/http.service';\r\nimport { TableField } from '../../../classes/inputs/table-field';\r\nimport { InputType } from '../../inputs/input-type';\r\nimport { Utils } from '../../../services/utils.service';\r\n\r\n/** Componente de tabela padrão */\r\n@Component({\r\n  selector: 'default-table',\r\n  templateUrl: './default-table.component.html',\r\n  styleUrls: ['./default-table.component.scss'],\r\n})\r\nexport class DefaultTableComponent<T extends HttpService> implements OnInit {\r\n  \r\n  /** Service a ser utilizado na listagem */\r\n  @Input('service') defaultService: T;\r\n/** Template de ações, deve ser um elemento ```<ng-template>``` */\r\n  @Input() acoesTemplate: TemplateRef<any>;\r\n\r\n  //#region [ Pagination ]\r\n  /** Valor total de dados */\r\n  @Input() total: number;\r\n\r\n  /** Número de páginas máximo (usando two way data binding) */\r\n  @Input() limit: number;\r\n  @Output() limitChange: EventEmitter<number> = new EventEmitter<number>();\r\n  \r\n  /** Valor da pagina, setado = 1 quando troca-se o valor de limite de paginas (usando two way data binding) */\r\n  @Input() page: number;\r\n  @Output() pageChange: EventEmitter<number> = new EventEmitter<number>();\r\n  \r\n  /** Propriedade de ordenação (usando two way data binding) */\r\n  @Input() orderByProperty: string | null;\r\n  @Output() orderByPropertyChange: EventEmitter<string | null> = new EventEmitter<string | null>();\r\n  \r\n  /** Propriedade de ordenação\r\n   * Se = true  Ordenará de menor ao maior \r\n   * Se = false Ordenará de maior ao menor (usando two way data binding) */\r\n  @Input() ascending: boolean;\r\n  @Output() ascendingChange: EventEmitter<boolean> = new EventEmitter<boolean>();\r\n  //#endregion [ Pagination ]\r\n\r\n  /** Filtros (usando two way data binding) */  \r\n  @Input('filter') filter: Comparison[] = [];\r\n  @Output() filterChange: EventEmitter<Comparison[]> = new EventEmitter<Comparison[]>();\r\n  \r\n  /** Evento emitido quando um dos dados é ativado. Emite o id do dado */  \r\n  @Output('ativar') ativarEmitter: EventEmitter<number> = new EventEmitter<number>;\r\n  @Output('refresh') refreshEmitter: EventEmitter<void> = new EventEmitter<void>();\r\n  @Input() loading: boolean;\r\n\r\n  /** Lista de dados a ser exibidos */\r\n  @Input() items: any[] = [];\r\n  \r\n  /** Lista de campos a ser exibidos */\r\n  @Input() lstTableFields: TableField[] = [];\r\n\r\n  /** Remove os filtros no cabeçalho da tabela  */\r\n  @Input() noFilters: boolean = false;\r\n  \r\n  /** Aplica classes de CSS na coluna de acirdo com o retorno da função passada como parametro  */\r\n  @Input() columnClass: ((index:string, object: any) => string) | null = null;\r\n  /** Aplica style de CSS na coluna de acirdo com o retorno da função passada como parametro  */\r\n  @Input() columnStyle: ((index:string, object: any) => string) | null = null;\r\n  /** Remove a paginação da listagem */\r\n  @Input() noPagination: boolean = false;\r\n  /** Caminho de redirecionamento do item */\r\n  @Input() itemPath: string | null = \"view/:id\"\r\n  InputTypeFile = InputType.File\r\n\r\n  constructor(\r\n    public storageService : StorageService,\r\n    private activatedRoute: ActivatedRoute,\r\n    private router        : Router,\r\n  ) { }\r\n\r\n  Redirect(field: TableField, item: any): void{\r\n    if(field.index == 'ativo'){\r\n      return;\r\n    }else\r\n    if(field.type  == 'File'){\r\n      return;\r\n    }else{\r\n      if(this.itemPath){\r\n        const id = item.id; \r\n        const path = this.itemPath.replace(\":id\", id.toString());\r\n        this.router.navigate([`./${path}`], { relativeTo: this.activatedRoute })\r\n      }\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n    if(this.defaultService && this.lstTableFields.length == 0){\r\n      this.lstTableFields = this.defaultService.lstTableFields;\r\n    }\r\n    if(this.lstTableFields.length == 0){ console.warn(\"[ Warning! ] [ Table configuration is empty]\") }\r\n\r\n    this.lstTableFields.filter(tf => tf.configuration instanceof InputSelectConfiguration).forEach(tf => tf.configuration.loader.Refresh());\r\n  }\r\n\r\n  SwitchOrder(field: TableField): void{\r\n    if(this.orderByProperty != field.index){\r\n      this.orderByProperty = field.index;\r\n      this.ascending = true;\r\n    }\r\n    else if(this.ascending){\r\n      this.ascending = false;\r\n    }\r\n    else{ this.orderByProperty = null; }\r\n\r\n    this.orderByPropertyChange.emit(this.orderByProperty)\r\n    this.ascendingChange.emit(this.ascending);\r\n\r\n    this.EmitChange();\r\n  }\r\n\r\n  EmitPage(value: number): void{\r\n    this.pageChange.emit(value);\r\n    this.EmitChange()\r\n  }\r\n\r\n  EmitChange(): void{\r\n    this.refreshEmitter.emit();\r\n  }\r\n\r\n  GetField(item: any, field : TableField): any{\r\n    const value = item[field.index];\r\n    const type = field.type;\r\n    if(['Number','Decimal','Currency'].includes(type)){\r\n      const config: InputDecimalConfiguration = (field.configuration as InputDecimalConfiguration)\r\n      return config.prefix + ' ' + formatNumber(value, \"pt-BR\", `1.${config.precision}-${config.precision}`) + ' ' + config.sufix;\r\n    }else\r\n    if(type == 'DateTime'){\r\n      if(!value){ return \"-\"; }\r\n      return Utils.DateISOToDDMMYYYYHHMM(value);\r\n    }else\r\n    if(type == 'Date'){\r\n      if(!value){ return \"-\"; }\r\n      return Utils.DateISOToDDMMYYYY(value);\r\n    } \r\n    return value;\r\n  }\r\n\r\n  GetSelectLabel(item: any, tField: TableField): string{\r\n    const configuration: InputSelectConfiguration = tField.configuration;\r\n    if(!configuration.multiple){\r\n      return configuration.loader.GetLabel(this.GetField(item, tField));\r\n    }else{\r\n      const values = this.GetField(item, tField);\r\n      if(values && values.length > 0){\r\n        return values.map(v => configuration.loader.GetLabel(v)).join(\", \");\r\n      }else{\r\n        return \"\";\r\n      }\r\n    }\r\n  }\r\n\r\n  GetTypeOf(val): string{\r\n    return typeof(val)\r\n  }\r\n\r\n  Ativar(id): void{\r\n    this.ativarEmitter.emit(id);\r\n  }\r\n\r\n  ChangeFilter(): void{\r\n    this.filterChange.emit(CompileLstTableField(this.lstTableFields));\r\n    this.refreshEmitter.emit();\r\n  }\r\n\r\n  GetTdClasses(field, item): string{\r\n    var classes : string = \"\";\r\n    if(['DateTime', 'Time', 'Date'].includes(field.type)){\r\n      classes += 'font-mono ';\r\n    }\r\n    if(this.columnClass){\r\n      classes += this.columnClass(field.index, item);\r\n    }\r\n    return classes;\r\n  }\r\n  GetTdStyle(field, item): string{\r\n    if(this.columnStyle){\r\n      return this.columnStyle(field, item);\r\n    }\r\n    return \"\";\r\n  }\r\n}","<!-- <section class=\"w-full h-full rounded-2xl flex flex-col overflow-y-hidden relative\" [ngClass]=\"{ 'loading' : loading }\">\r\n    \r\n    <div class=\"unique-conteiner default-transition\" [ngClass]=\"{'!-z-50 !-translate-y-12 !opacity-0': !loading }\">\r\n        <loading [type]=\"2\"></loading>\r\n    </div>\r\n    <div class=\"unique-conteiner default-transition\" [ngClass]=\"{'!-z-50 !-translate-y-12 !opacity-0': items.length != 0 || loading }\">\r\n        <b><ion-icon class=\"align-sub\" name=\"remove-circle\"></ion-icon> Sem dados</b>\r\n    </div>\r\n\r\n    <div id=\"wrapper\" class=\"relative overflow-y-auto w-full grow-0 mb-auto pb-2\">\r\n        <table class=\"z-20 overflow-visible\">\r\n            <thead>\r\n                <tr>\r\n                    <th scope=\"col\" class=\"px-3 !h-10\" *ngIf=\"acoesTemplate\">\r\n                        <span>Ações</span>\r\n                    </th>\r\n                    @for (field of lstTableFields; let i = $index; track i) {\r\n                        @if (!field.hidden) {\r\n                            <th scope=\"col\" class=\"p-2 px-3\" id=\"th-filter-select\">\r\n                                <div class=\"flex items-center justify-start h-full\" style=\"white-space: var(--ion-table-filter-wrap);\"> \r\n                                    @if(!noFilters){\r\n                                        <th-filter class=\"!text-base\" style=\"text-transform: none !important\" *ngIf=\"(field.type != InputTypeFile) && !(field.filter && field.disabledChange()) && !noFilters\"\r\n                                            [field]=\"field\"\r\n                                            (change)=\"ChangeFilter()\"\r\n                                        ></th-filter>\r\n                                    }\r\n                                    <span>{{field.header}}</span>\r\n\r\n                                    <a *ngIf=\"!(!(field.type != InputTypeFile) && !(field.filter && field.disabledChange())) && !noFilters\" class=\"order-switch h-5 flex items-center justify-center px-1 ml-2 shrink-0 cursor-pointer rounded-2xl\" (click)=\"SwitchOrder(field)\" [ngClass]=\"{ 'ordering-asc' : orderByProperty == field.index && ascending, 'ordering-desc' : orderByProperty == field.index && !ascending}\">\r\n                                        <ion-icon id=\"up\"   name=\"arrow-up\"   class=\"-mt-1\"></ion-icon>\r\n                                        <ion-icon id=\"down\" name=\"arrow-down\" class=\"-ml-1 -mb-1\"></ion-icon>\r\n                                    </a>\r\n                                </div>\r\n                            </th>\r\n                        }\r\n                    }\r\n                </tr>\r\n            </thead>\r\n            <tbody>\r\n                <tr [hidden]=\"loading\" *ngFor=\"let item of items\">\r\n                    @if(acoesTemplate){\r\n                        <td class=\"whitespace-nowrap py-1 px-3\" [style]=\"GetTdStyle('Acoes', item)\" >\r\n                            <ng-container *ngTemplateOutlet=\"acoesTemplate; context: { $implicit: item }\"></ng-container>\r\n                        </td>\r\n                    }\r\n\r\n                    @for (field of lstTableFields; track $index) {\r\n                        @if (!field.hidden) {\r\n                            <td class=\"px-3 py-2\" \r\n                                [ngClass]=\"GetTdClasses(field, item)\" \r\n                                [style]=\"GetTdStyle(field, item)\" \r\n                                (click)=\"Redirect(field, item)\"\r\n                                style=\"white-space: var(--ion-table-row-wrap);\"\r\n                            >\r\n                                @if (field.index == 'ativo') {\r\n                                    <div class=\"w-full h-full flex items-center justify-start\" [routerLink]=\"null\">\r\n                                        <ion-toggle [checked]=\"item[field.index]\" [disabled]=\"loading\" (ionChange)=\"Ativar(item.id)\" ></ion-toggle>\r\n                                    </div>\r\n                                } @else {\r\n                                    @switch (field.type) {\r\n                                        @case (\"Bool\") {\r\n                                            @if (field.configuration.type == \"toggle\") {\r\n                                                <div class=\"-full h-full flex items-center justify-start\">\r\n                                                    <ion-toggle [checked]=\"item[field.index]\" [disabled]=\"true\"></ion-toggle>\r\n                                                </div>\r\n                                            }\r\n                                            @else {\r\n                                                <div class=\"-full h-full flex items-center justify-start\">\r\n                                                    <ion-checkbox [checked]=\"item[field.index]\" [disabled]=\"true\"></ion-checkbox>\r\n                                                </div>\r\n                                            }\r\n                                        }\r\n                                        @case (\"File\") {\r\n                                            <download-button [(ngModel)]=\"item[field.index]\" [configuration]=\"field.configuration\"></download-button>\r\n                                        }\r\n                                        @case (\"Select\") {\r\n                                            {{GetSelectLabel(item, field)}}\r\n                                        }\r\n                                        @default {\r\n                                            {{GetField(item, field)}} \r\n                                        }\r\n                                    }\r\n                                }\r\n                            </td>\r\n                        }\r\n                    }\r\n                </tr>\r\n\r\n                <ng-content select=\"[slot=item-end]\"></ng-content>\r\n            </tbody>\r\n        </table>\r\n    </div>\r\n    @if(!noPagination){\r\n        <div class=\"shrink-0 mt-auto w-full\">\r\n            <default-pagination\r\n                [page]=\"page\"\r\n                (pageChange)=\"EmitPage($event)\"\r\n                [total]=\"total\"\r\n                [limit]=\"limit\"\r\n                [length]=\"items.length\"\r\n                [loading]=\"loading\"\r\n            ></default-pagination>\r\n        </div>\r\n    }\r\n</section> -->\r\n<div class=\"size-full rounded-2xl flex flex-col overflow-hidden relative\">\r\n    <loading [type]=\"3\" [loading]=\"loading\"></loading>\r\n    <content-block text=\"Sem Dados\" [value]=\"!(items.length != 0 || loading)\"></content-block>\r\n\r\n    <div class=\"size-full shrink relative overflow-y-auto\">\r\n        <table>\r\n            <thead>\r\n                <tr>\r\n                    <th scope=\"col\" class=\"px-3 !h-10\" *ngIf=\"acoesTemplate\"> Ações </th>\r\n                        @for (field of lstTableFields; let i = $index; track i) {\r\n                            @if (!field.hidden) {\r\n                                <th scope=\"col\" class=\"p-2 px-3\" id=\"th-filter-select\">\r\n                                    <div class=\"flex items-center justify-start h-full\" style=\"white-space: var(--ion-table-filter-wrap);\"> \r\n                                        @if(!noFilters){\r\n                                            <th-filter class=\"!text-base\" style=\"text-transform: none !important\" *ngIf=\"(field.type != InputTypeFile) && !(field.filter && field.disabledChange()) && !noFilters\"\r\n                                                [field]=\"field\"\r\n                                                (change)=\"ChangeFilter()\"\r\n                                            ></th-filter>\r\n                                        }\r\n                                        <span>{{field.header}}</span>\r\n\r\n                                        <a *ngIf=\"!(!(field.type != InputTypeFile) && !(field.filter && field.disabledChange())) && !noFilters\" class=\"order-switch h-5 flex items-center justify-center px-1 ml-2 shrink-0 cursor-pointer rounded-2xl\" (click)=\"SwitchOrder(field)\" [ngClass]=\"{ 'ordering-asc' : orderByProperty == field.index && ascending, 'ordering-desc' : orderByProperty == field.index && !ascending}\">\r\n                                            <ion-icon id=\"up\"   name=\"arrow-up\"   class=\"-mt-1\"></ion-icon>\r\n                                            <ion-icon id=\"down\" name=\"arrow-down\" class=\"-ml-1 -mb-1\"></ion-icon>\r\n                                        </a>\r\n                                    </div>\r\n                                </th>\r\n                            }\r\n                        }\r\n                </tr>\r\n            </thead>\r\n            <tbody>\r\n                <tr [hidden]=\"loading\" *ngFor=\"let item of items\">\r\n                    @if(acoesTemplate){\r\n                        <td class=\"whitespace-nowrap py-1 px-3\" [style]=\"GetTdStyle('Acoes', item)\" >\r\n                            <ng-container *ngTemplateOutlet=\"acoesTemplate; context: { $implicit: item }\"></ng-container>\r\n                        </td>\r\n                    }\r\n\r\n                    @for (field of lstTableFields; track $index) {\r\n                        @if (!field.hidden) {\r\n                            <td class=\"px-3 py-2\" \r\n                                [ngClass]=\"GetTdClasses(field, item)\" \r\n                                [style]=\"GetTdStyle(field, item)\" \r\n                                (click)=\"Redirect(field, item)\"\r\n                                style=\"white-space: var(--ion-table-row-wrap);\"\r\n                            >\r\n                                @if (field.index == 'ativo') {\r\n                                    <div class=\"w-full h-full flex items-center justify-start\" [routerLink]=\"null\">\r\n                                        <ion-toggle [checked]=\"item[field.index]\" [disabled]=\"loading\" (ionChange)=\"Ativar(item.id)\" ></ion-toggle>\r\n                                    </div>\r\n                                } @else {\r\n                                    @switch (field.type) {\r\n                                        @case (\"Bool\") {\r\n                                            @if (field.configuration.type == \"toggle\") {\r\n                                                <div class=\"-full h-full flex items-center justify-start\">\r\n                                                    <ion-toggle [checked]=\"item[field.index]\" [disabled]=\"true\"></ion-toggle>\r\n                                                </div>\r\n                                            }\r\n                                            @else {\r\n                                                <div class=\"-full h-full flex items-center justify-start\">\r\n                                                    <ion-checkbox [checked]=\"item[field.index]\" [disabled]=\"true\"></ion-checkbox>\r\n                                                </div>\r\n                                            }\r\n                                        }\r\n                                        @case (\"File\") {\r\n                                            <download-button [(ngModel)]=\"item[field.index]\" [configuration]=\"field.configuration\"></download-button>\r\n                                        }\r\n                                        @case (\"Select\") {\r\n                                            {{GetSelectLabel(item, field)}}\r\n                                        }\r\n                                        @default {\r\n                                            {{GetField(item, field)}} \r\n                                        }\r\n                                    }\r\n                                }\r\n                            </td>\r\n                        }\r\n                    }\r\n                </tr>\r\n\r\n                <ng-content select=\"[slot=item-end]\"></ng-content>\r\n            </tbody>\r\n        </table>\r\n    </div>\r\n    @if(!noPagination){\r\n        <div class=\"shrink-0 z-[100]\">\r\n            <default-pagination\r\n                [page]=\"page\"\r\n                (pageChange)=\"EmitPage($event)\"\r\n                [total]=\"total\"\r\n                [limit]=\"limit\"\r\n                [length]=\"items.length\"\r\n                [loading]=\"loading\"\r\n            ></default-pagination>\r\n        </div>\r\n    }\r\n</div>"]}
|
|
191
|
+
class DefaultTableRow {
|
|
192
|
+
constructor(item, id, lstColumns, acoesClass = '', acoesStyle = '') {
|
|
193
|
+
this.item = item;
|
|
194
|
+
this.id = id;
|
|
195
|
+
this.lstColumns = lstColumns;
|
|
196
|
+
this.acoesClass = acoesClass;
|
|
197
|
+
this.acoesStyle = acoesStyle;
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
class DefaultTableColumn {
|
|
201
|
+
constructor(value = null, tf) {
|
|
202
|
+
this.value = value;
|
|
203
|
+
this.tf = tf;
|
|
204
|
+
this.loading = false;
|
|
205
|
+
this.class = '';
|
|
206
|
+
this.style = '';
|
|
207
|
+
}
|
|
208
|
+
}
|
|
209
|
+
class AvailableTableField {
|
|
210
|
+
constructor(tf, ascending, descending) {
|
|
211
|
+
this.tf = tf;
|
|
212
|
+
this.ascending = ascending;
|
|
213
|
+
this.descending = descending;
|
|
214
|
+
}
|
|
215
|
+
}
|
|
216
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"default-table.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/default/default-table/default-table.component.ts","../../../../../../src/lib/components/default/default-table/default-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { formatNumber } from '@angular/common';\r\nimport { Component, computed, effect, Input, input, InputSignal, model, ModelSignal, OnInit, output, OutputEmitterRef, OutputRef, Signal, TemplateRef } from '@angular/core';\r\nimport { ActivatedRoute, Router } from '@angular/router';\r\n\r\nimport { InputDecimalConfiguration } from '../../inputs/input-decimal/input-decimal.configuration';\r\nimport { InputSelectConfiguration } from '../../inputs/input-select/input.select.configuration';\r\nimport { FormatTelefoneCelular } from '../../inputs/input-telefone/input-telefone.component';\r\nimport { StorageService } from '../../../services/web/storage.service';\r\nimport { FormatCpfCnpj } from '../../inputs/input-cpf-cnpj/input-cpf-cnpj.component';\r\nimport { HttpService } from '../../../services/web/http.service'\r\nimport { TableField } from '../../../classes/inputs/table-field';\r\nimport { Comparison, CompileLstTableField } from '../../../classes/comparison/comparison';\r\nimport { FormatCep } from '../../inputs/input-cep/input-cep.component';\r\nimport { InputType } from '../../inputs/input-type';\r\nimport { Utils } from '../../../services/utils.service';\r\n\r\ntype CSSStyleStringGenerator = (index: string, object: any) => string;\r\n\r\n@Component({\r\n  selector: 'default-table',\r\n  templateUrl: './default-table.component.html',\r\n  styleUrls: ['./default-table.component.scss'],\r\n})\r\nexport class DefaultTableComponent<Service extends HttpService, T = any> implements OnInit {\r\n\r\n  @Input() acoesTemplate: TemplateRef<any>;\r\n  /** Template de ações, deve ser um elemento ```<ng-template>``` */\r\n  // acoesTemplate: InputSignal<TemplateRef<any>> = input<TemplateRef<any>>();\r\n\r\n  /** Service a ser utilizado na listagem */\r\n  service: InputSignal<Service> = input<Service>();\r\n\r\n  total: ModelSignal<number> = model<number>(0);\r\n\r\n  /** Número de items máximo (usando two way data binding) */\r\n  limit: ModelSignal<number> = model<number>();\r\n\r\n  /** Valor da pagina, setado = 1 quando troca-se o valor de limite de paginas (usando two way data binding) */\r\n  page: ModelSignal<number> = model<number>(1);\r\n\r\n  /** Propriedade de ordenação (usando two way data binding) */\r\n  orderByProperty: ModelSignal<string | null> = model<string | null>(null);\r\n    \r\n  /** Propriedade de ordenação\r\n   * Se = true  Ordenará de menor ao maior \r\n   * Se = false Ordenará de maior ao menor (usando two way data binding) */\r\n  ascending: ModelSignal<boolean> = model<boolean>(true);\r\n\r\n  /** Filtros (usando two way data binding) */ \r\n  filter: ModelSignal<Comparison[]> = model<Comparison[]>([]);\r\n\r\n  /** Evento emitido quando um dos dados é ativado. Emite o id do dado */  \r\n  ativar : OutputEmitterRef<number> = output<number>();\r\n  refresh: OutputEmitterRef<void> = output<void>();\r\n\r\n\r\n  loading: ModelSignal<boolean> = model<boolean>(false);\r\n\r\n  /** Lista de dados a ser exibidos */\r\n  items: ModelSignal<T[]> = model<T[]>([]);\r\n\r\n  /** Lista de campos a ser exibidos */\r\n  lstTableFields: ModelSignal<TableField[]> = model<TableField[]>([]);\r\n  lstTableFieldsAvailable: Signal<AvailableTableField[]> = computed<AvailableTableField[]>(() => { \r\n    return this.lstTableFields().filter(p => !p.hidden).map(tf => {\r\n      return new AvailableTableField(\r\n        tf, \r\n        this.ascending() && this.orderByProperty() == tf.index, \r\n        !this.ascending() && this.orderByProperty() == tf.index\r\n      );\r\n    });\r\n  });\r\n\r\n  /** Remove os filtros no cabeçalho da tabela  */\r\n  noFilters: InputSignal<boolean> = input<boolean>(false);\r\n\r\n  /** Aplica classes de CSS na coluna de acirdo com o retorno da função passada como parametro  */\r\n  columnClass: InputSignal<CSSStyleStringGenerator | null> = input<CSSStyleStringGenerator | null>(null);\r\n\r\n  /** Aplica style de CSS na coluna de acirco com o retorno da função passada como parametro  */\r\n  columnStyle: InputSignal<CSSStyleStringGenerator | null> = input<CSSStyleStringGenerator | null>(null);\r\n\r\n  /** Remove a paginação da listagem */\r\n  noPagination: InputSignal<boolean> = input<boolean>(false);\r\n\r\n  /** Caminho de redirecionamento do item */\r\n  itemPath: InputSignal<string> = input<string>('view/:id');\r\n  itemClick: OutputEmitterRef<T> = output<T>();\r\n\r\n  InputType = InputType;\r\n\r\n  constructor(\r\n    public storageService : StorageService,\r\n    private activatedRoute: ActivatedRoute,\r\n    private router        : Router,\r\n  ) { \r\n    effect(() => {\r\n      for (const tf of this.lstTableFields().filter(p => p.type == InputType.Select)) {\r\n        (tf.configuration as InputSelectConfiguration).loader.Refresh().then(() => this.SetLstRows());\r\n      }\r\n      this.SetLstRows();\r\n    });\r\n  }\r\n\r\n  Redirect(field: TableField | undefined, item: T): void{\r\n    this.itemClick.emit(item);\r\n    if(!field){\r\n      return;\r\n    } else\r\n    if(field.index == 'ativo'){\r\n      return;\r\n    }else\r\n    if(field.type  == 'File'){\r\n      return;\r\n    }else\r\n    if(this.itemPath()){\r\n      const id = item['id']; \r\n      const path = this.itemPath().replace(\":id\", id.toString());\r\n      this.router.navigate([`./${path}`], { relativeTo: this.activatedRoute })\r\n    }\r\n  }\r\n\r\n  SetLstRows(){ \r\n    this.lstRows = this.items().map(item => {\r\n      return new DefaultTableRow<T>(\r\n        item, \r\n        item['id'],\r\n        this.GetColumns(item),\r\n        this.columnClass() ? this.columnClass()('acoes', item) : '',\r\n        this.columnStyle() ? this.columnClass()('acoes', item) : '',\r\n      );\r\n    });\r\n  }\r\n  \r\n  lstRows: DefaultTableRow<T>[] = []; \r\n\r\n  GetColumns(item: T): DefaultTableColumn[] {\r\n    return this.lstTableFields().filter(p => !p.hidden).map(tf => {\r\n      const value = item[tf.index];\r\n      const column = new DefaultTableColumn(value, tf);\r\n      column.class = this.columnClass() ? this.columnClass()(tf.index, item) : '';\r\n      column.style = this.columnStyle() ? this.columnStyle()(tf.index, item) : '';\r\n      \r\n      if(!value){ \r\n        column.label = '-' \r\n        return column;\r\n      }\r\n      \r\n      if(tf.type == InputType.Bool){\r\n        column.label = \"<bool>\"\r\n      } else\r\n      if(tf.type == InputType.Cep){\r\n        column.label = FormatCep(value);\r\n      } else\r\n      if(tf.type == InputType.Color){\r\n        column.label = value;\r\n      } else\r\n      if([InputType.Cpf, InputType.Cnpj, InputType.CpfCnpj].includes(tf.type)){\r\n        column.label = FormatCpfCnpj(value);\r\n      } else\r\n      if(tf.type == InputType.DateTime){\r\n        column.class += ' font-mono';\r\n        column.label = Utils.DateISOToDDMMYYYYHHMM(value);\r\n      } else\r\n      if(tf.type == InputType.Date){\r\n        column.class += ' font-mono';\r\n        column.label = Utils.DateISOToDDMMYYYYHHMM(value);\r\n      } else\r\n      if(tf.type == InputType.Time){\r\n        column.class += ' font-mono';\r\n        column.label = value;\r\n      } else\r\n      if([InputType.Decimal, InputType.Decimal, InputType.Currency].includes(tf.type)){\r\n        const configuration: InputDecimalConfiguration = tf.configuration;\r\n        column.label = [\r\n          configuration.prefix, \r\n          formatNumber(value as number, 'pt-BR', `1.${configuration.precision}-${configuration.precision}`),\r\n          configuration.sufix, \r\n        ].join(' ');\r\n      } else\r\n      if(tf.type == InputType.File){\r\n        column.label = '<file>';\r\n      } else\r\n      if(tf.type == InputType.Icon){\r\n        column.label = 'icon';\r\n      } else\r\n      if(tf.type == InputType.Select){\r\n        column.label = (tf.configuration as InputSelectConfiguration).loader.GetLabel(value);\r\n        column.loading = !(tf.configuration as InputSelectConfiguration).loader.isLoaded;\r\n      } else\r\n      if([InputType.String, InputType.TextArea].includes(tf.type)){\r\n        column.label = value\r\n      } else\r\n      if([InputType.Telefone, InputType.Celular, InputType.TelefoneCelular].includes(tf.type)){\r\n        column.label = FormatTelefoneCelular(value);\r\n      }\r\n\r\n      return column;\r\n    });\r\n  }\r\n\r\n  ngOnInit() { this.SetLstRows(); }\r\n\r\n  SwitchOrder(tf: TableField): void{\r\n    if(this.orderByProperty() != tf.index){\r\n      this.orderByProperty.set(tf.index);\r\n      this.ascending.set(true);\r\n    } else \r\n    if(this.ascending()){\r\n      this.ascending.set(false);\r\n    } else{ \r\n      this.orderByProperty.set(null); \r\n    }\r\n    this.refresh.emit();\r\n  }\r\n\r\n  ChangeFilter(): void{\r\n    this.filter.set(CompileLstTableField(this.lstTableFields()));\r\n    this.page.set(1);\r\n    this.refresh.emit();\r\n  }\r\n\r\n  Ativar(id: number): void{\r\n    this.ativar.emit(id);\r\n  }\r\n}\r\n\r\nclass DefaultTableRow<T>{\r\n  constructor(\r\n    public item: T,\r\n    public id: number | undefined,\r\n    public lstColumns: DefaultTableColumn[],\r\n    public acoesClass: string = '',\r\n    public acoesStyle: string = '',\r\n  ){}\r\n} \r\n\r\nclass DefaultTableColumn{\r\n  public label: string | null\r\n  public loading: boolean = false;\r\n  public class: string = '';\r\n  public style: string = '';\r\n  constructor(\r\n    public value: any = null,\r\n    public tf: TableField,\r\n  ){}\r\n}\r\n\r\nclass AvailableTableField{\r\n  constructor(\r\n    public tf: TableField,\r\n    public ascending: boolean,\r\n    public descending: boolean,\r\n  ){}\r\n}","<!-- <div class=\"size-full rounded-2xl flex flex-col overflow-hidden relative\">\r\n    <loading [type]=\"3\" [loading]=\"loading\"></loading>\r\n    <content-block text=\"Sem Dados\" [value]=\"!(items.length != 0 || loading)\"></content-block>\r\n\r\n    <div class=\"size-full shrink relative overflow-y-auto\">\r\n        <table>\r\n            <thead>\r\n                <tr>\r\n                    <th scope=\"col\" class=\"px-3 !h-10\" *ngIf=\"acoesTemplate\"> Ações </th>\r\n                        @for (field of lstTableFields; let i = $index; track i) {\r\n                            @if (!field.hidden) {\r\n                                <th scope=\"col\" class=\"p-2 px-3\" id=\"th-filter-select\">\r\n                                    <div class=\"flex items-center justify-start h-full\" style=\"white-space: var(--ion-table-filter-wrap);\"> \r\n                                        @if(!noFilters){\r\n                                            <th-filter class=\"!text-base\" style=\"text-transform: none !important\" *ngIf=\"(field.type != InputTypeFile) && !(field.filter && field.disabledChange()) && !noFilters\"\r\n                                                [field]=\"field\"\r\n                                                (change)=\"ChangeFilter()\"\r\n                                            ></th-filter>\r\n                                        }\r\n                                        <span>{{field.header}}</span>\r\n\r\n                                        <a *ngIf=\"!(!(field.type != InputTypeFile) && !(field.filter && field.disabledChange())) && !noFilters\" class=\"order-switch h-5 flex items-center justify-center px-1 ml-2 shrink-0 cursor-pointer rounded-2xl\" (click)=\"SwitchOrder(field)\" [ngClass]=\"{ 'ordering-asc' : orderByProperty == field.index && ascending, 'ordering-desc' : orderByProperty == field.index && !ascending}\">\r\n                                            <ion-icon id=\"up\"   name=\"arrow-up\"   class=\"-mt-1\"></ion-icon>\r\n                                            <ion-icon id=\"down\" name=\"arrow-down\" class=\"-ml-1 -mb-1\"></ion-icon>\r\n                                        </a>\r\n                                    </div>\r\n                                </th>\r\n                            }\r\n                        }\r\n                </tr>\r\n            </thead>\r\n            <tbody>\r\n                <tr [hidden]=\"loading\" *ngFor=\"let item of items\">\r\n                    @if(acoesTemplate){\r\n                        <td class=\"whitespace-nowrap py-1 px-3\" [style]=\"GetTdStyle('Acoes', item)\" >\r\n                            <ng-container *ngTemplateOutlet=\"acoesTemplate; context: { $implicit: item }\"></ng-container>\r\n                        </td>\r\n                    }\r\n\r\n                    @for (field of lstTableFields; track $index) {\r\n                        @if (!field.hidden) {\r\n                            <td class=\"px-3 py-2\" \r\n                                [ngClass]=\"GetTdClasses(field, item)\" \r\n                                [style]=\"GetTdStyle(field, item)\" \r\n                                (click)=\"Redirect(field, item)\"\r\n                                style=\"white-space: var(--ion-table-row-wrap);\"\r\n                            >\r\n                                @if (field.index == 'ativo') {\r\n                                    <div class=\"w-full h-full flex items-center justify-start\" [routerLink]=\"null\">\r\n                                        <ion-toggle [checked]=\"item[field.index]\" [disabled]=\"loading\" (ionChange)=\"Ativar(item.id)\" ></ion-toggle>\r\n                                    </div>\r\n                                } @else {\r\n                                    @switch (field.type) {\r\n                                        @case (\"Bool\") {\r\n                                            @if (field.configuration.type == \"toggle\") {\r\n                                                <div class=\"-full h-full flex items-center justify-start\">\r\n                                                    <ion-toggle [checked]=\"item[field.index]\" [disabled]=\"true\"></ion-toggle>\r\n                                                </div>\r\n                                            }\r\n                                            @else {\r\n                                                <div class=\"-full h-full flex items-center justify-start\">\r\n                                                    <ion-checkbox [checked]=\"item[field.index]\" [disabled]=\"true\"></ion-checkbox>\r\n                                                </div>\r\n                                            }\r\n                                        }\r\n                                        @case (\"File\") {\r\n                                            <download-button [(ngModel)]=\"item[field.index]\" [configuration]=\"field.configuration\"></download-button>\r\n                                        }\r\n                                        @case (\"Select\") {\r\n                                            {{GetSelectLabel(item, field)}}\r\n                                        }\r\n                                        @default {\r\n                                            {{GetField(item, field)}} \r\n                                        }\r\n                                    }\r\n                                }\r\n                            </td>\r\n                        }\r\n                    }\r\n                </tr>\r\n\r\n                <ng-content select=\"[slot=item-end]\"></ng-content>\r\n            </tbody>\r\n        </table>\r\n    </div>\r\n    @if(!noPagination){\r\n        <div class=\"shrink-0 z-[100]\">\r\n            <default-pagination\r\n                [page]=\"page\"\r\n                (pageChange)=\"EmitPage($event)\"\r\n                [total]=\"total\"\r\n                [limit]=\"limit\"\r\n                [length]=\"items.length\"\r\n                [loading]=\"loading\"\r\n            ></default-pagination>\r\n        </div>\r\n    }\r\n</div> -->\r\n\r\n<div class=\"size-full rounded-xl flex flex-col overflow-hidden relative\">\r\n    <loading [type]=\"3\" [loading]=\"loading()\"></loading>\r\n    <content-block text=\"Sem Dados\" [value]=\"!(items.length != 0 || loading)\"></content-block>\r\n\r\n     <div class=\"size-full shrink relative overflow-y-auto\">\r\n        <table>\r\n            <thead>\r\n                <tr>\r\n                    @if(acoesTemplate){\r\n\r\n                    }\r\n                    <th scope=\"col\" class=\"p-2\"> \r\n                        Ações \r\n                    </th>\r\n\r\n                    @for (tfa of lstTableFieldsAvailable(); track tfa.tf.index) {\r\n                        <th scope=\"col\" class=\"p-2\"> \r\n                            <div class=\"flex gap-2 items-center justify-start th\">\r\n                                @if(!noFilters()){\r\n                                    <th-filter class=\"!text-base\" style=\"text-transform: none !important\" \r\n                                    *ngIf=\"((tfa.tf.type != InputType.File || (tfa.tf.filter && tfa.tf.disabledChange())) && !noFilters())\"\r\n                                        [field]=\"tfa.tf\"\r\n                                        (change)=\"ChangeFilter()\"\r\n                                    ></th-filter>\r\n                                }\r\n\r\n                                {{tfa.tf.header}} \r\n\r\n                                @if((tfa.tf.type != InputType.File || (tfa.tf.filter && tfa.tf.disabledChange())) && !noFilters()){\r\n                                    <a [ngClass]=\"{ 'bg-light/10 !opacity-100': tfa.ascending || tfa.descending }\"\r\n                                        class=\"order h-4 w-5 relative cursor-pointer rounded-lg opacity-0 default-transition\" \r\n                                        (click)=\"SwitchOrder(tfa.tf)\"\r\n                                    >\r\n                                        <ion-icon \r\n                                            [class.text-primary]=\"tfa.ascending\"\r\n                                            class=\"absolute left-0 top-0\" \r\n                                            name=\"arrow-up\"\r\n                                        ></ion-icon> \r\n                                        <ion-icon \r\n                                            [class.text-primary]=\"tfa.descending\"\r\n                                            class=\"absolute right-0 bottom-0\" \r\n                                            name=\"arrow-down\"\r\n                                        ></ion-icon> \r\n                                    </a>\r\n                                }\r\n                            </div>\r\n                        </th>\r\n                    }\r\n                </tr>\r\n            </thead>\r\n            <tbody>\r\n                @for (row of lstRows; track row.id || $index) {\r\n                    <tr [hidden]=\"loading()\">\r\n                        @if(acoesTemplate){\r\n                            <td (click)=\"Redirect(undefined, row.item)\" class=\"whitespace-nowrap py-1 px-3 {{row.acoesClass}}\" [style]=\"row.acoesStyle\" >\r\n                                <ng-container *ngTemplateOutlet=\"acoesTemplate; context: { $implicit: row.item }\"></ng-container>\r\n                            </td>\r\n                        }\r\n\r\n                        @for (col of row.lstColumns; track col.tf.index) {\r\n                            <td class=\"{{col.class}} p-2 cursor-pointer\" (click)=\"Redirect(col.tf, row.item)\" [style]=\"'white-space: var(--ion-table-row-wrap);' + col.style\">\r\n                                @if(col.tf.index == 'ativo') {\r\n                                    <div class=\"size-full flex items-center justify-start\" [routerLink]=\"null\">\r\n                                        <ion-toggle [checked]=\"col.value\" [disabled]=\"loading()\" (ionChange)=\"Ativar(row.id)\" ></ion-toggle>\r\n                                    </div>\r\n                                }\r\n                                @else if (col.tf.type == InputType.Bool){\r\n                                    <div class=\"h-full flex items-center justify-start\">\r\n                                        @if(col.tf.configuration.type == 'toggle') {\r\n                                            <ion-toggle [checked]=\"col.value\" [disabled]=\"true\"></ion-toggle>\r\n                                        }\r\n                                        @else {\r\n                                            <ion-checkbox [checked]=\"col.value\" [disabled]=\"true\"></ion-checkbox>\r\n                                        }\r\n                                    </div>\r\n                                }\r\n                                @else if (col.tf.type == InputType.File) {\r\n                                    <download-button [(ngModel)]=\"col.value\" [configuration]=\"col.tf.configuration\"></download-button>\r\n                                }\r\n                                @else if (col.loading){\r\n                                    <ion-spinner name=\"dots\"></ion-spinner>\r\n                                } @else {\r\n                                    {{col.label}}\r\n                                }\r\n                            </td>\r\n                        }\r\n                    </tr>\r\n                    <ng-content select=\"[slot=item-end]\"></ng-content>\r\n                }\r\n            </tbody>\r\n        </table>\r\n     </div>\r\n     @if(!noPagination()){\r\n        <div class=\"shrink-0 z-[100]\">\r\n            <default-pagination\r\n                [page]=\"page()\"\r\n                (pageChange)=\"page.set($event); refresh.emit()\"\r\n                [total]=\"total()\"\r\n                [limit]=\"limit()\"\r\n                [length]=\"items().length\"\r\n                [loading]=\"loading()\"\r\n            ></default-pagination>\r\n        </div>\r\n    }\r\n\r\n    <!-- <div class=\"overflow-y-auto\">\r\n        @for (item of lstRows; track $index) {\r\n            <div class=\"border border-red-500 flex\">\r\n                {{$index}} - \r\n                @for (lbl of item.lstColumns; track $index) {\r\n                    ([{{lbl.label}}])\r\n                }\r\n            </div>\r\n        }\r\n    </div> -->\r\n</div>"]}
|