ngx-sp-infra 2.0.21 → 2.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +138 -138
- package/esm2022/lib/infra.module.mjs +6 -1
- package/esm2022/lib/models/icons/icon.model.mjs +2 -1
- package/esm2022/lib/widgets/content-container/content-container.component.mjs +11 -3
- package/esm2022/lib/widgets/field-contador-message/field-contador-message.component.mjs +1 -1
- package/esm2022/lib/widgets/input-trim/input-trim.component.mjs +34 -0
- package/esm2022/lib/widgets/lib-combobox/lib-combobox.component.mjs +1 -1
- package/esm2022/lib/widgets/lib-icons/lib-icons.component.mjs +5 -5
- package/esm2022/lib/widgets/loading-button/loading-button.component.mjs +5 -5
- package/esm2022/lib/widgets/nav-produtos/nav-produtos.component.mjs +27 -27
- package/esm2022/lib/widgets/table/table.component.mjs +79 -7
- package/esm2022/lib/widgets/tree/tree.component.mjs +1 -1
- package/esm2022/public-api.mjs +2 -1
- package/fesm2022/ngx-sp-infra.mjs +156 -44
- package/fesm2022/ngx-sp-infra.mjs.map +1 -1
- package/lib/infra.module.d.ts +39 -38
- package/lib/widgets/content-container/content-container.component.d.ts +3 -2
- package/lib/widgets/input-trim/input-trim.component.d.ts +11 -0
- package/lib/widgets/table/table.component.d.ts +26 -5
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
|
@@ -3,6 +3,7 @@ import * as i0 from "@angular/core";
|
|
|
3
3
|
import * as i1 from "@angular/common";
|
|
4
4
|
import * as i2 from "@angular/forms";
|
|
5
5
|
import * as i3 from "ngx-pagination";
|
|
6
|
+
import * as i4 from "../ordering/ordering.component";
|
|
6
7
|
/**
|
|
7
8
|
* Componente de Tabela Customizável
|
|
8
9
|
*
|
|
@@ -17,16 +18,38 @@ import * as i3 from "ngx-pagination";
|
|
|
17
18
|
* @styleUrl ./table.component.scss
|
|
18
19
|
*/
|
|
19
20
|
export class TableComponent {
|
|
21
|
+
/** Lista de registros a serem exibidos na tabela.
|
|
22
|
+
* @required */
|
|
23
|
+
get recordsList() { return this._recordsList; }
|
|
24
|
+
set recordsList(value) { this._recordsList = value; }
|
|
20
25
|
/** Informa um ID para a paginação da tabela específica. Deve ser utilizada em caso de múltiplas tabelas na mesma tela. */
|
|
21
26
|
get paginationID() { return this._paginationID; }
|
|
22
27
|
set paginationID(value) {
|
|
23
28
|
this._paginationID = value || 'libTablePagination';
|
|
24
29
|
}
|
|
30
|
+
/** Página atual da tabela. */
|
|
31
|
+
get page() { return this._currentPage; }
|
|
32
|
+
set page(value) { this._currentPage = value; }
|
|
33
|
+
/** Número de itens a serem exibidos por página. */
|
|
34
|
+
get itemsPerPage() { return this._currentItemsPerPage; }
|
|
35
|
+
set itemsPerPage(value) { this._currentItemsPerPage = value; }
|
|
36
|
+
get firstItemOfPage() {
|
|
37
|
+
return (this.page - 1) * this.itemsPerPage + 1;
|
|
38
|
+
}
|
|
39
|
+
get lastItemOfPage() {
|
|
40
|
+
return Math.min(this.page * this.itemsPerPage, this.recordsList?.length ?? 0);
|
|
41
|
+
}
|
|
42
|
+
// Exemplo de string com a contagem:
|
|
43
|
+
get itemsDisplayText() {
|
|
44
|
+
return `Exibindo ${this.countOptions ? this.firstItemOfPage + "-" + this.lastItemOfPage + " de" : ""} ${this.recordsList?.length ?? 0} registros`;
|
|
45
|
+
}
|
|
25
46
|
// #endregion PUBLIC
|
|
26
47
|
// #endregion ==========> PROPRIEDADES <==========
|
|
27
48
|
// #region ==========> INICIALIZAÇÃO <==========
|
|
28
49
|
constructor(cdr) {
|
|
29
50
|
this.cdr = cdr;
|
|
51
|
+
this._currentPage = 1;
|
|
52
|
+
this._currentItemsPerPage = 0;
|
|
30
53
|
// #endregion PRIVATE
|
|
31
54
|
// #region PUBLIC
|
|
32
55
|
/** Determina se a tabela deve usar paginação.
|
|
@@ -43,10 +66,13 @@ export class TableComponent {
|
|
|
43
66
|
this.itemsPerPageChange = new EventEmitter();
|
|
44
67
|
/** Evento emitido quando a página é alterada. */
|
|
45
68
|
this.pageChange = new EventEmitter();
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
69
|
+
//#region Ordering, Sorting ou apenas Ordenação
|
|
70
|
+
/** Método que faz a ordenação dos contratos na tela de listagem, em cada uma das células do cabeçalho da tabela, onde cada um
|
|
71
|
+
* dos elementos <th> representa uma coluna, de acordo com a lista de contratos que retorna do backend. */
|
|
72
|
+
// Objeto para armazenar a direção de ordenação de cada coluna
|
|
73
|
+
this.sortDirection = {};
|
|
74
|
+
// Coluna atualmente selecionada para ordenação
|
|
75
|
+
this.currentSortColumn = '';
|
|
50
76
|
}
|
|
51
77
|
/** Inicializa o componente e define o número inicial de itens por página. */
|
|
52
78
|
ngOnInit() {
|
|
@@ -88,12 +114,58 @@ export class TableComponent {
|
|
|
88
114
|
this.page = 1;
|
|
89
115
|
}
|
|
90
116
|
}
|
|
117
|
+
// Função chamada quando ocorre uma mudança na ordenação
|
|
118
|
+
onSortChange(event) {
|
|
119
|
+
const { direction, column } = event;
|
|
120
|
+
// Verifica se a coluna atualmente selecionada é a mesma da nova seleção
|
|
121
|
+
if (this.currentSortColumn === column) {
|
|
122
|
+
// Alterna entre 'asc' e 'desc' para a direção de ordenação da coluna
|
|
123
|
+
this.sortDirection[column] = this.sortDirection[column] === 'asc' ? 'asc' : 'desc';
|
|
124
|
+
}
|
|
125
|
+
else {
|
|
126
|
+
// Define a nova coluna e a direção de ordenação como 'asc'
|
|
127
|
+
this.currentSortColumn = column;
|
|
128
|
+
this.sortDirection = { [column]: 'asc' };
|
|
129
|
+
}
|
|
130
|
+
// Realiza a ordenação dos dados da tabela
|
|
131
|
+
this.sortData();
|
|
132
|
+
}
|
|
133
|
+
// Função de ordenação dos dados da tabela
|
|
134
|
+
sortData() {
|
|
135
|
+
if (this.recordsList) {
|
|
136
|
+
const gruposList = this.recordsList;
|
|
137
|
+
gruposList.sort((a, b) => {
|
|
138
|
+
const attribute = this.currentSortColumn;
|
|
139
|
+
const direction = this.sortDirection[attribute];
|
|
140
|
+
return this.compareProperties(a, b, attribute, direction);
|
|
141
|
+
});
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
// Compara os valores das propriedades entre dois objetos
|
|
145
|
+
compareProperties(a, b, attribute, direction) {
|
|
146
|
+
const propertyA = this.getProperty(a, attribute).toUpperCase();
|
|
147
|
+
const propertyB = this.getProperty(b, attribute).toUpperCase();
|
|
148
|
+
if (propertyA < propertyB) {
|
|
149
|
+
return direction === 'asc' ? -1 : 1;
|
|
150
|
+
}
|
|
151
|
+
if (propertyA > propertyB) {
|
|
152
|
+
return direction === 'asc' ? 1 : -1;
|
|
153
|
+
}
|
|
154
|
+
return 0;
|
|
155
|
+
}
|
|
156
|
+
// Obtém o valor de uma propriedade específica de um objeto
|
|
157
|
+
getProperty(obj, path) {
|
|
158
|
+
if (typeof path === 'string') {
|
|
159
|
+
path = path.split('.');
|
|
160
|
+
}
|
|
161
|
+
return path.reduce((value, property) => value ? value[property] : '', obj);
|
|
162
|
+
}
|
|
91
163
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TableComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
92
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: TableComponent, selector: "lib-table", inputs: { usePagination: "usePagination", recordsList: ["list", "recordsList"], countOptions: ["counts", "countOptions"], paginationPlacement: ["placement", "paginationPlacement"], headersList: ["headers", "headersList"], emptyListMessage: "emptyListMessage", showCounter: "showCounter", paginationID: "paginationID" }, outputs: { itemsPerPageChange: "itemsPerPageChange", pageChange: "pageChange" }, usesOnChanges: true, ngImport: i0, template: "@if (recordsList) {\n <div class=\"table-list w-100 position-relative\">\n <!-- Exibe o n\u00FAmero de itens mostrados e o total de registros -->\n <span *ngIf=\"showCounter\" class=\"ms-1\">
|
|
164
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: TableComponent, selector: "lib-table", inputs: { usePagination: "usePagination", recordsList: ["list", "recordsList"], countOptions: ["counts", "countOptions"], paginationPlacement: ["placement", "paginationPlacement"], headersList: ["headers", "headersList"], emptyListMessage: "emptyListMessage", showCounter: "showCounter", paginationID: "paginationID" }, outputs: { itemsPerPageChange: "itemsPerPageChange", pageChange: "pageChange" }, usesOnChanges: true, ngImport: i0, template: "@if (recordsList) {\r\n <div class=\"table-list w-100 position-relative\">\r\n <!-- Exibe o n\u00FAmero de itens mostrados e o total de registros -->\r\n <span *ngIf=\"showCounter\" class=\"ms-1\"> {{ itemsDisplayText }} </span>\r\n \r\n <!-- Container da tabela -->\r\n <div class=\"table-list overflow-hidden border-bottom-0 rounded-bottom rounded\">\r\n <table class=\"table table-hover border mb-0\">\r\n <thead>\r\n <tr>\r\n <!-- Itera sobre a lista de cabe\u00E7alhos para criar as colunas -->\r\n <th *ngFor=\"let header of headersList\" scope=\"col\"\r\n class=\"align-middle text-dark-grey {{ header.col > 0 ? 'col-'+header.col : 'col' }} {{ header.customClasses }}\">\r\n {{ header.name }}\r\n\r\n <app-ordering *ngIf=\"header.orderColumn\" [(sortDirection)]=\"sortDirection[header.orderColumn]\"\r\n (sortChange)=\"onSortChange({ direction: $event.direction, column: header.orderColumn })\"></app-ordering>\r\n </th>\r\n </tr>\r\n </thead>\r\n\r\n <tbody class=\"bg-light fade-in-row\">\r\n @if (recordsList.length > 0) {\r\n <!-- Conte\u00FAdo das linhas da tabela -->\r\n <ng-content select=\"[innerRows]\"></ng-content>\r\n }\r\n @else {\r\n <!-- Mensagem de aus\u00EAncia de registros -->\r\n <tr>\r\n <td colspan=\"12\" class=\"align-middle\">\r\n <span class=\"fw-light fst-italic text-center\"> {{ emptyListMessage ? emptyListMessage : \"Consulta n\u00E3o retornou registros...\" }} </span>\r\n </td>\r\n </tr>\r\n }\r\n </tbody>\r\n </table>\r\n\r\n <!-- #region PAGINA\u00C7\u00C3O -->\r\n <div *ngIf=\"usePagination && recordsList.length > 0\" class=\"d-flex mt-2\"\r\n [ngClass]=\"{\r\n 'justify-content-start': paginationPlacement == 'start',\r\n 'justify-content-center': paginationPlacement == 'center',\r\n 'justify-content-end': paginationPlacement == 'end',\r\n 'justify-content-between': paginationPlacement == 'between'\r\n }\">\r\n <div class=\"d-flex align-items-center\">\r\n <label class=\"me-2\" style=\"white-space: nowrap;\"> Itens por p\u00E1gina </label>\r\n <select class=\"form-select select-search\" (change)=\"onSelectChange($event)\">\r\n <option *ngFor=\"let count of countOptions; let i = index\" [value]=\"count\"\r\n [selected]=\"countOptions.length > 0 && i == 0\">{{ count }}</option>\r\n </select>\r\n </div>\r\n\r\n <!-- Controle de pagina\u00E7\u00E3o -->\r\n <pagination-controls\r\n [id]=\"paginationID\"\r\n class=\"sp-pagination mt-3\"\r\n (pageChange)=\"page = $event; pageChange.emit($event)\"\r\n previousLabel=\"\u00AB \" nextLabel=\" \u00BB\"\r\n [maxSize]=\"5\">\r\n </pagination-controls>\r\n </div>\r\n <!-- #endregion PAGINA\u00C7\u00C3O -->\r\n </div>\r\n </div>\r\n} @else {\r\n <!-- Loader enquanto os registros s\u00E3o carregados -->\r\n <div class=\"w-100 text-center\">\r\n <div class=\"spinner-border\" role=\"status\"> <span class=\"visually-hidden\">Carregando informa\u00E7\u00F5es...</span> </div>\r\n </div>\r\n}\r\n", styles: [".sp-pagination ::ng-deep .ngx-pagination .current{background:#3767b2;border-radius:.375rem}.sp-pagination ::ng-deep .ngx-pagination a:hover,.sp-pagination ::ng-deep .ngx-pagination button:hover{border-radius:.375rem}.sp-pagination ::ng-deep .ngx-pagination .pagination-previous a:before,.sp-pagination ::ng-deep .ngx-pagination .pagination-previous.disabled:before{content:\"\";display:inline-block;margin-right:.5rem}.sp-pagination ::ng-deep .ngx-pagination .pagination-next a:after,.sp-pagination ::ng-deep .ngx-pagination .pagination-next.disabled:after{content:\"\";display:inline-block;margin-left:.5rem}.text-dark-grey{color:#63676b!important}table{border-color:#c4c4c4}table thead{height:50px;font-size:1rem;background-color:#f9fafb!important}table thead>tr{background-color:#f9fafb!important}table thead>tr>th{background-color:#f9fafb!important}table tbody{font-size:.875rem}table tbody>tr{height:50px}table tbody>tr:hover{background-color:#cce5ff}table.table>tbody{border-top:none}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "component", type: i3.PaginationControlsComponent, selector: "pagination-controls", inputs: ["id", "maxSize", "directionLinks", "autoHide", "responsive", "previousLabel", "nextLabel", "screenReaderPaginationLabel", "screenReaderPageLabel", "screenReaderCurrentLabel"], outputs: ["pageChange", "pageBoundsCorrection"] }, { kind: "component", type: i4.OrderingComponent, selector: "app-ordering", inputs: ["isColumnClicked", "sortDirection", "sortAttributes"], outputs: ["sortDirectionChange", "sortChange"] }] }); }
|
|
93
165
|
}
|
|
94
166
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TableComponent, decorators: [{
|
|
95
167
|
type: Component,
|
|
96
|
-
args: [{ selector: 'lib-table', template: "@if (recordsList) {\n <div class=\"table-list w-100 position-relative\">\n <!-- Exibe o n\u00FAmero de itens mostrados e o total de registros -->\n <span *ngIf=\"showCounter\" class=\"ms-1\">
|
|
168
|
+
args: [{ selector: 'lib-table', template: "@if (recordsList) {\r\n <div class=\"table-list w-100 position-relative\">\r\n <!-- Exibe o n\u00FAmero de itens mostrados e o total de registros -->\r\n <span *ngIf=\"showCounter\" class=\"ms-1\"> {{ itemsDisplayText }} </span>\r\n \r\n <!-- Container da tabela -->\r\n <div class=\"table-list overflow-hidden border-bottom-0 rounded-bottom rounded\">\r\n <table class=\"table table-hover border mb-0\">\r\n <thead>\r\n <tr>\r\n <!-- Itera sobre a lista de cabe\u00E7alhos para criar as colunas -->\r\n <th *ngFor=\"let header of headersList\" scope=\"col\"\r\n class=\"align-middle text-dark-grey {{ header.col > 0 ? 'col-'+header.col : 'col' }} {{ header.customClasses }}\">\r\n {{ header.name }}\r\n\r\n <app-ordering *ngIf=\"header.orderColumn\" [(sortDirection)]=\"sortDirection[header.orderColumn]\"\r\n (sortChange)=\"onSortChange({ direction: $event.direction, column: header.orderColumn })\"></app-ordering>\r\n </th>\r\n </tr>\r\n </thead>\r\n\r\n <tbody class=\"bg-light fade-in-row\">\r\n @if (recordsList.length > 0) {\r\n <!-- Conte\u00FAdo das linhas da tabela -->\r\n <ng-content select=\"[innerRows]\"></ng-content>\r\n }\r\n @else {\r\n <!-- Mensagem de aus\u00EAncia de registros -->\r\n <tr>\r\n <td colspan=\"12\" class=\"align-middle\">\r\n <span class=\"fw-light fst-italic text-center\"> {{ emptyListMessage ? emptyListMessage : \"Consulta n\u00E3o retornou registros...\" }} </span>\r\n </td>\r\n </tr>\r\n }\r\n </tbody>\r\n </table>\r\n\r\n <!-- #region PAGINA\u00C7\u00C3O -->\r\n <div *ngIf=\"usePagination && recordsList.length > 0\" class=\"d-flex mt-2\"\r\n [ngClass]=\"{\r\n 'justify-content-start': paginationPlacement == 'start',\r\n 'justify-content-center': paginationPlacement == 'center',\r\n 'justify-content-end': paginationPlacement == 'end',\r\n 'justify-content-between': paginationPlacement == 'between'\r\n }\">\r\n <div class=\"d-flex align-items-center\">\r\n <label class=\"me-2\" style=\"white-space: nowrap;\"> Itens por p\u00E1gina </label>\r\n <select class=\"form-select select-search\" (change)=\"onSelectChange($event)\">\r\n <option *ngFor=\"let count of countOptions; let i = index\" [value]=\"count\"\r\n [selected]=\"countOptions.length > 0 && i == 0\">{{ count }}</option>\r\n </select>\r\n </div>\r\n\r\n <!-- Controle de pagina\u00E7\u00E3o -->\r\n <pagination-controls\r\n [id]=\"paginationID\"\r\n class=\"sp-pagination mt-3\"\r\n (pageChange)=\"page = $event; pageChange.emit($event)\"\r\n previousLabel=\"\u00AB \" nextLabel=\" \u00BB\"\r\n [maxSize]=\"5\">\r\n </pagination-controls>\r\n </div>\r\n <!-- #endregion PAGINA\u00C7\u00C3O -->\r\n </div>\r\n </div>\r\n} @else {\r\n <!-- Loader enquanto os registros s\u00E3o carregados -->\r\n <div class=\"w-100 text-center\">\r\n <div class=\"spinner-border\" role=\"status\"> <span class=\"visually-hidden\">Carregando informa\u00E7\u00F5es...</span> </div>\r\n </div>\r\n}\r\n", styles: [".sp-pagination ::ng-deep .ngx-pagination .current{background:#3767b2;border-radius:.375rem}.sp-pagination ::ng-deep .ngx-pagination a:hover,.sp-pagination ::ng-deep .ngx-pagination button:hover{border-radius:.375rem}.sp-pagination ::ng-deep .ngx-pagination .pagination-previous a:before,.sp-pagination ::ng-deep .ngx-pagination .pagination-previous.disabled:before{content:\"\";display:inline-block;margin-right:.5rem}.sp-pagination ::ng-deep .ngx-pagination .pagination-next a:after,.sp-pagination ::ng-deep .ngx-pagination .pagination-next.disabled:after{content:\"\";display:inline-block;margin-left:.5rem}.text-dark-grey{color:#63676b!important}table{border-color:#c4c4c4}table thead{height:50px;font-size:1rem;background-color:#f9fafb!important}table thead>tr{background-color:#f9fafb!important}table thead>tr>th{background-color:#f9fafb!important}table tbody{font-size:.875rem}table tbody>tr{height:50px}table tbody>tr:hover{background-color:#cce5ff}table.table>tbody{border-top:none}\n"] }]
|
|
97
169
|
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }], propDecorators: { usePagination: [{
|
|
98
170
|
type: Input
|
|
99
171
|
}], recordsList: [{
|
|
@@ -121,4 +193,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
121
193
|
}], pageChange: [{
|
|
122
194
|
type: Output
|
|
123
195
|
}] } });
|
|
124
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-sp-infra/src/lib/widgets/table/table.component.ts","../../../../../../projects/ngx-sp-infra/src/lib/widgets/table/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ChangeDetectorRef, Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges } from '@angular/core';\n\n/**\n * Componente de Tabela Customizável\n *\n * O `TableComponent` é um componente Angular projetado para exibir uma tabela customizável\n * com suporte a paginação. Ele permite a configuração de cabeçalhos de colunas, posicionamento\n * da paginação e opções de itens por página. O componente é flexível, utilizando classes Bootstrap\n * para ajustar o layout das colunas e emitindo eventos para que o componente pai possa reagir a\n * mudanças na página ou no número de itens exibidos.\n *\n * @selector lib-table\n * @templateUrl ./table.component.html\n * @styleUrl ./table.component.scss\n*/\n@Component({\n  selector: 'lib-table',\n  templateUrl: './table.component.html',\n  styleUrls: ['./table.component.scss']\n})\nexport class TableComponent implements OnInit, AfterViewInit, OnChanges {\n\n  // #region ==========> PROPRIEDADES <==========\n\n  // #region PRIVATE\n  private _paginationID: string;\n  // #endregion PRIVATE\n\n  // #region PUBLIC\n\n  /** Determina se a tabela deve usar paginação.\n   * @default true */\n  @Input() public usePagination: boolean = true;\n\n  /** Lista de registros a serem exibidos na tabela.\n   * @required */\n  @Input({ alias: 'list', required: true }) public recordsList: any[] | undefined;\n\n  /** Opções de contagem de itens por página disponíveis para o usuário.\n   * @required */\n  @Input('counts') public countOptions: number[];\n\n  /** Posicionamento dos controles de paginação.\n   * @default 'end' */\n  @Input('placement') public paginationPlacement: 'start' | 'center' | 'end' | 'between' = 'end';\n\n  /** Lista de cabeçalhos para as colunas da tabela, incluindo o nome, a largura da coluna e classes customizadas.\n   * @required */\n  @Input({ alias: 'headers', required: true }) public headersList: {\n    name: string,\n    col: number,\n    customClasses?: string\n  }[];\n\n  /** Mensagem customizada para lista vazia */\n  @Input('emptyListMessage') public emptyListMessage?: string;\n\n  /** Informa se o counter de registros deve aparecer ou não.\n   * @default true\n  */\n  @Input('showCounter') public showCounter: boolean = true;\n\n  /** Informa um ID para a paginação da tabela específica. Deve ser utilizada em caso de múltiplas tabelas na mesma tela. */\n  @Input()\n  public get paginationID(): string { return this._paginationID; }\n  public set paginationID(value: string) {\n    this._paginationID = value || 'libTablePagination';\n  }\n\n\n  /** Evento emitido quando o número de itens por página é alterado. */\n  @Output() public itemsPerPageChange: EventEmitter<number> = new EventEmitter<number>();\n\n  /** Evento emitido quando a página é alterada. */\n  @Output() public pageChange: EventEmitter<number> = new EventEmitter<number>();\n\n\n  /** Contador de registros (pode ser usado para futuras implementações de lógica interna). */\n  public counter: number = 0;\n\n  /** Página atual da tabela. */\n\tpublic page: number = 1;\n\n  /** Número de itens a serem exibidos por página. */\n\tpublic itemsPerPage: number;\n  // #endregion PUBLIC\n\n  // #endregion ==========> PROPRIEDADES <==========\n\n\n  // #region ==========> INICIALIZAÇÃO <==========\n  constructor(private cdr: ChangeDetectorRef) { }\n\n  /** Inicializa o componente e define o número inicial de itens por página. */\n  ngOnInit(): void {\n    if (this.recordsList) { this.itemsPerPage = this.countOptions ? this.countOptions[0] : this.recordsList.length }\n    else { this.itemsPerPage = this.countOptions[0] ?? 10 }\n  }\n\n  ngAfterViewInit(): void {\n    this.cdr.detectChanges();  // Forçar uma nova detecção após a renderização\n  }\n\n  /** Monitora as mudanças nas entradas do componente e realiza ajustes, como resetar a paginação ou validar o layout das colunas.\n   * @param changes Objeto que contém as mudanças nas entradas do componente. */\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['recordsList'].currentValue) {\n      this.resetPagination(this.recordsList ?? []);\n\n      let maxColumns = this.headersList.reduce((n, {col}) => n + col, 0);\n      if (maxColumns >= 13) {\n        throw new Error(\"A soma de largura (classe com prefixo 'col-') de todas as colunas não pode ser maior que 12.\");\n      }\n    }\n  }\n  // #endregion ==========> INICIALIZAÇÃO <==========\n\n\n  // #region ==========> UTILITÁRIOS <==========\n\n  /** Modifica a quantidade de itens a ser mostrada na lista.\n   * @param event parâmetro de evento que irá selecionar a nova quantidade. */\n  public onSelectChange(event: any) {\n    this.itemsPerPage = parseInt(event.target.value, 10);\n    this.page = 1;\n    this.itemsPerPageChange.emit(this.itemsPerPage);\n  }\n\n  /** Reseta a paginação da listagem com base no número atual de registros.\n   * @param list Lista de registros para resetar a paginação. */\n  public resetPagination(list: any[]): void {\n    const startIndex = (this.page - 1) * this.itemsPerPage;\n    if (list.length <= startIndex) {\n      this.page = 1;\n    }\n  }\n\n  // #endregion ==========> UTILITÁRIOS <==========\n\n}\n","@if (recordsList) {\n   <div class=\"table-list w-100 position-relative\">\n      <!-- Exibe o número de itens mostrados e o total de registros -->\n      <span *ngIf=\"showCounter\" class=\"ms-1\"> Exibindo {{ itemsPerPage <= recordsList.length ? itemsPerPage : recordsList.length }} de {{ recordsList.length }} registros </span>\n      \n      <!-- Container da tabela -->\n      <div class=\"table-list overflow-hidden border-bottom-0 rounded-bottom rounded\">\n         <table class=\"table table-hover border mb-0\">\n            <thead>\n               <tr>\n                  <!-- Itera sobre a lista de cabeçalhos para criar as colunas -->\n                  <th *ngFor=\"let header of headersList\" scope=\"col\"\n                     class=\"align-middle text-dark-grey {{ header.col > 0 ? 'col-'+header.col : 'col' }} {{ header.customClasses }}\">\n                     {{ header.name }}\n                  </th>\n               </tr>\n            </thead>\n\n            <tbody class=\"bg-light fade-in-row\">\n               @if (recordsList.length > 0) {\n                  <!-- Conteúdo das linhas da tabela -->\n                  <ng-content select=\"[innerRows]\"></ng-content>\n               }\n               @else {\n                  <!-- Mensagem de ausência de registros -->\n                  <tr>\n                     <td colspan=\"12\" class=\"align-middle\">\n                        <span class=\"fw-light fst-italic text-center\"> {{ emptyListMessage ? emptyListMessage : \"Consulta não retornou registros...\" }} </span>\n                     </td>\n                  </tr>\n               }\n            </tbody>\n         </table>\n\n         <!-- #region PAGINAÇÃO -->\n         <div *ngIf=\"usePagination && recordsList.length > 0\" class=\"d-flex mt-2\"\n            [ngClass]=\"{\n               'justify-content-start': paginationPlacement == 'start',\n               'justify-content-center': paginationPlacement == 'center',\n               'justify-content-end': paginationPlacement == 'end',\n               'justify-content-between': paginationPlacement == 'between'\n            }\">\n            <div class=\"d-flex align-items-center\">\n               <label class=\"me-2\" style=\"white-space: nowrap;\"> Itens por página </label>\n               <select class=\"form-select select-search\" (change)=\"onSelectChange($event)\">\n                  <option *ngFor=\"let count of countOptions; let i = index\" [value]=\"count\"\n                     [selected]=\"countOptions.length > 0 && i == 0\">{{ count }}</option>\n               </select>\n            </div>\n\n            <!-- Controle de paginação -->\n            <pagination-controls\n               [id]=\"paginationID\"\n               class=\"sp-pagination mt-3\"\n               (pageChange)=\"page = $event; pageChange.emit($event)\"\n               previousLabel=\"«&nbsp;&nbsp;&nbsp;\" nextLabel=\"&nbsp;&nbsp;&nbsp;»\"\n               [maxSize]=\"5\">\n            </pagination-controls>\n         </div>\n         <!-- #endregion PAGINAÇÃO -->\n      </div>\n   </div>\n} @else {\n   <!-- Loader enquanto os registros são carregados -->\n   <div class=\"w-100 text-center\">\n      <div class=\"spinner-border\" role=\"status\"> <span class=\"visually-hidden\">Carregando informações...</span> </div>\n   </div>\n}\n"]}
|
|
196
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-sp-infra/src/lib/widgets/table/table.component.ts","../../../../../../projects/ngx-sp-infra/src/lib/widgets/table/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ChangeDetectorRef, Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges } from '@angular/core';\r\n\r\n/**\r\n * Componente de Tabela Customizável\r\n *\r\n * O `TableComponent` é um componente Angular projetado para exibir uma tabela customizável\r\n * com suporte a paginação. Ele permite a configuração de cabeçalhos de colunas, posicionamento\r\n * da paginação e opções de itens por página. O componente é flexível, utilizando classes Bootstrap\r\n * para ajustar o layout das colunas e emitindo eventos para que o componente pai possa reagir a\r\n * mudanças na página ou no número de itens exibidos.\r\n *\r\n * @selector lib-table\r\n * @templateUrl ./table.component.html\r\n * @styleUrl ./table.component.scss\r\n*/\r\n@Component({\r\n  selector: 'lib-table',\r\n  templateUrl: './table.component.html',\r\n  styleUrls: ['./table.component.scss']\r\n})\r\nexport class TableComponent implements OnInit, AfterViewInit, OnChanges {\r\n\r\n  // #region ==========> PROPRIEDADES <==========\r\n\r\n  // #region PRIVATE\r\n  private _paginationID: string;\r\n  private _recordsList: any[] | undefined;\r\n\r\n  private _currentPage: number = 1;\r\n  private _currentItemsPerPage: number = 0;\r\n  // #endregion PRIVATE\r\n\r\n  // #region PUBLIC\r\n\r\n  /** Determina se a tabela deve usar paginação.\r\n   * @default true */\r\n  @Input() public usePagination: boolean = true;\r\n\r\n  \r\n  /** Lista de registros a serem exibidos na tabela.\r\n   * @required */\r\n  @Input({ alias: 'list', required: true })\r\n  public get recordsList(): any[] | undefined { return this._recordsList; }\r\n  public set recordsList(value: any[] | undefined) { this._recordsList = value; }\r\n\r\n\r\n  /** Opções de contagem de itens por página disponíveis para o usuário.\r\n   * @required */\r\n  @Input('counts') public countOptions: number[];\r\n\r\n\r\n  /** Posicionamento dos controles de paginação.\r\n   * @default 'end' */\r\n  @Input('placement') public paginationPlacement: 'start' | 'center' | 'end' | 'between' = 'end';\r\n\r\n\r\n  /** Lista de cabeçalhos para as colunas da tabela, incluindo o nome, a largura da coluna e classes customizadas.\r\n   * @required */\r\n  @Input({ alias: 'headers', required: true }) public headersList: {\r\n    name: string,\r\n    col: number,\r\n    customClasses?: string,\r\n    orderColumn?: string\r\n  }[];\r\n\r\n\r\n  /** Mensagem customizada para lista vazia */\r\n  @Input('emptyListMessage') public emptyListMessage?: string;\r\n\r\n\r\n  /** Informa se o counter de registros deve aparecer ou não.\r\n   * @default true\r\n  */\r\n  @Input('showCounter') public showCounter: boolean = true;\r\n\r\n\r\n  /** Informa um ID para a paginação da tabela específica. Deve ser utilizada em caso de múltiplas tabelas na mesma tela. */\r\n  @Input()\r\n  public get paginationID(): string { return this._paginationID; }\r\n  public set paginationID(value: string) {\r\n    this._paginationID = value || 'libTablePagination';\r\n  }\r\n\r\n\r\n  /** Evento emitido quando o número de itens por página é alterado. */\r\n  @Output() public itemsPerPageChange: EventEmitter<number> = new EventEmitter<number>();\r\n\r\n  /** Evento emitido quando a página é alterada. */\r\n  @Output() public pageChange: EventEmitter<number> = new EventEmitter<number>();\r\n\r\n  /** Página atual da tabela. */\r\n\tpublic get page(): number { return this._currentPage; }\r\n\tpublic set page(value: number) { this._currentPage = value; }\r\n\r\n  /** Número de itens a serem exibidos por página. */\r\n  public get itemsPerPage(): number { return this._currentItemsPerPage; }\r\n\tpublic set itemsPerPage(value: number) { this._currentItemsPerPage = value; }\r\n\r\n\r\n  public get firstItemOfPage(): number {\r\n    return (this.page - 1) * this.itemsPerPage + 1;\r\n  }\r\n  public get lastItemOfPage(): number {\r\n    return Math.min(this.page * this.itemsPerPage, this.recordsList?.length ?? 0);\r\n  }\r\n\r\n  // Exemplo de string com a contagem:\r\n  public get itemsDisplayText(): string {\r\n    return `Exibindo ${ this.countOptions ? this.firstItemOfPage+\"-\"+this.lastItemOfPage + \" de\" : \"\" } ${this.recordsList?.length ?? 0} registros`;\r\n  }\r\n  // #endregion PUBLIC\r\n\r\n  // #endregion ==========> PROPRIEDADES <==========\r\n\r\n\r\n  // #region ==========> INICIALIZAÇÃO <==========\r\n  constructor(private cdr: ChangeDetectorRef) { }\r\n\r\n  /** Inicializa o componente e define o número inicial de itens por página. */\r\n  ngOnInit(): void {\r\n    if (this.recordsList) { this.itemsPerPage = this.countOptions ? this.countOptions[0] : this.recordsList.length }\r\n    else { this.itemsPerPage = this.countOptions[0] ?? 10 }\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.cdr.detectChanges();  // Forçar uma nova detecção após a renderização\r\n  }\r\n\r\n  /** Monitora as mudanças nas entradas do componente e realiza ajustes, como resetar a paginação ou validar o layout das colunas.\r\n   * @param changes Objeto que contém as mudanças nas entradas do componente. */\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['recordsList'].currentValue) {\r\n      this.resetPagination(this.recordsList ?? []);\r\n\r\n      let maxColumns = this.headersList.reduce((n, {col}) => n + col, 0);\r\n      if (maxColumns >= 13) {\r\n        throw new Error(\"A soma de largura (classe com prefixo 'col-') de todas as colunas não pode ser maior que 12.\");\r\n      }\r\n    }\r\n  }\r\n  // #endregion ==========> INICIALIZAÇÃO <==========\r\n\r\n\r\n  // #region ==========> UTILITÁRIOS <==========\r\n\r\n  /** Modifica a quantidade de itens a ser mostrada na lista.\r\n   * @param event parâmetro de evento que irá selecionar a nova quantidade. */\r\n  public onSelectChange(event: any) {\r\n    this.itemsPerPage = parseInt(event.target.value, 10);\r\n    this.page = 1;\r\n    this.itemsPerPageChange.emit(this.itemsPerPage);\r\n  }\r\n\r\n  /** Reseta a paginação da listagem com base no número atual de registros.\r\n   * @param list Lista de registros para resetar a paginação. */\r\n  public resetPagination(list: any[]): void {\r\n    const startIndex = (this.page - 1) * this.itemsPerPage;\r\n    if (list.length <= startIndex) {\r\n      this.page = 1;\r\n    }\r\n  }\r\n\r\n\r\n\r\n\t//#region Ordering, Sorting ou apenas Ordenação\r\n\r\n\t/** Método que faz a ordenação dos contratos na tela de listagem, em cada uma das células do cabeçalho da tabela, onde cada um  \r\n\t *  dos elementos <th> representa uma coluna, de acordo com a lista de contratos que retorna do backend. */\r\n\t// Objeto para armazenar a direção de ordenação de cada coluna\r\n\tpublic sortDirection: { [key: string]: string } = {};\r\n\r\n\t// Coluna atualmente selecionada para ordenação\r\n\tpublic currentSortColumn: string = '';\r\n\r\n\t// Função chamada quando ocorre uma mudança na ordenação\r\n\tonSortChange(event: { direction: string, column: string }) {\r\n\t\tconst { direction, column } = event;\r\n\r\n\t\t// Verifica se a coluna atualmente selecionada é a mesma da nova seleção\r\n\t\tif (this.currentSortColumn === column) {\r\n\t\t\t// Alterna entre 'asc' e 'desc' para a direção de ordenação da coluna\r\n\t\t\tthis.sortDirection[column] = this.sortDirection[column] === 'asc' ? 'asc' : 'desc';\r\n\t\t} else {\r\n\t\t\t// Define a nova coluna e a direção de ordenação como 'asc'\r\n\t\t\tthis.currentSortColumn = column;\r\n\t\t\tthis.sortDirection = { [column]: 'asc' };\r\n\t\t}\r\n\r\n\t\t// Realiza a ordenação dos dados da tabela\r\n\t\tthis.sortData();\r\n\t}\r\n\r\n\t// Função de ordenação dos dados da tabela\r\n\tprivate sortData() {\r\n\r\n\t\tif (this.recordsList) {\r\n\t\t\tconst gruposList = this.recordsList;\r\n\r\n\t\t\tgruposList.sort((a, b) => {\r\n\t\t\t\tconst attribute = this.currentSortColumn;\r\n\t\t\t\tconst direction = this.sortDirection[attribute];\r\n\r\n\t\t\t\treturn this.compareProperties(a, b, attribute, direction);\r\n\t\t\t});\r\n\r\n\t\t}\r\n\r\n\t}\r\n\r\n\t// Compara os valores das propriedades entre dois objetos\r\n\tprivate compareProperties(a: any, b: any, attribute: string, direction: string): number {\r\n\t\tconst propertyA = this.getProperty(a, attribute).toUpperCase();\r\n\t\tconst propertyB = this.getProperty(b, attribute).toUpperCase();\r\n\r\n\t\tif (propertyA < propertyB) {\r\n\t\t\treturn direction === 'asc' ? -1 : 1;\r\n\t\t}\r\n\r\n\t\tif (propertyA > propertyB) {\r\n\t\t\treturn direction === 'asc' ? 1 : -1;\r\n\t\t}\r\n\r\n\t\treturn 0;\r\n\t}\r\n\r\n\t// Obtém o valor de uma propriedade específica de um objeto\r\n\tprivate getProperty(obj: any, path: string | string[]): string {\r\n\t\t\r\n\t\tif (typeof path === 'string') {\r\n\t\t\tpath = path.split('.');\r\n\t\t}\r\n\r\n\t\treturn path.reduce((value, property) => value ? value[property] : '', obj);\r\n\t}\r\n\t//#endregion Ordering, Sorting ou apenas Ordenação\r\n\r\n  // #endregion ==========> UTILITÁRIOS <==========\r\n\r\n}\r\n","@if (recordsList) {\r\n   <div class=\"table-list w-100 position-relative\">\r\n      <!-- Exibe o número de itens mostrados e o total de registros -->\r\n      <span *ngIf=\"showCounter\" class=\"ms-1\"> {{ itemsDisplayText }} </span>\r\n      \r\n      <!-- Container da tabela -->\r\n      <div class=\"table-list overflow-hidden border-bottom-0 rounded-bottom rounded\">\r\n         <table class=\"table table-hover border mb-0\">\r\n            <thead>\r\n               <tr>\r\n                  <!-- Itera sobre a lista de cabeçalhos para criar as colunas -->\r\n                  <th *ngFor=\"let header of headersList\" scope=\"col\"\r\n                     class=\"align-middle text-dark-grey {{ header.col > 0 ? 'col-'+header.col : 'col' }} {{ header.customClasses }}\">\r\n                     {{ header.name }}\r\n\r\n                     <app-ordering *ngIf=\"header.orderColumn\" [(sortDirection)]=\"sortDirection[header.orderColumn]\"\r\n                        (sortChange)=\"onSortChange({ direction: $event.direction, column: header.orderColumn })\"></app-ordering>\r\n                  </th>\r\n               </tr>\r\n            </thead>\r\n\r\n            <tbody class=\"bg-light fade-in-row\">\r\n               @if (recordsList.length > 0) {\r\n                  <!-- Conteúdo das linhas da tabela -->\r\n                  <ng-content select=\"[innerRows]\"></ng-content>\r\n               }\r\n               @else {\r\n                  <!-- Mensagem de ausência de registros -->\r\n                  <tr>\r\n                     <td colspan=\"12\" class=\"align-middle\">\r\n                        <span class=\"fw-light fst-italic text-center\"> {{ emptyListMessage ? emptyListMessage : \"Consulta não retornou registros...\" }} </span>\r\n                     </td>\r\n                  </tr>\r\n               }\r\n            </tbody>\r\n         </table>\r\n\r\n         <!-- #region PAGINAÇÃO -->\r\n         <div *ngIf=\"usePagination && recordsList.length > 0\" class=\"d-flex mt-2\"\r\n            [ngClass]=\"{\r\n               'justify-content-start': paginationPlacement == 'start',\r\n               'justify-content-center': paginationPlacement == 'center',\r\n               'justify-content-end': paginationPlacement == 'end',\r\n               'justify-content-between': paginationPlacement == 'between'\r\n            }\">\r\n            <div class=\"d-flex align-items-center\">\r\n               <label class=\"me-2\" style=\"white-space: nowrap;\"> Itens por página </label>\r\n               <select class=\"form-select select-search\" (change)=\"onSelectChange($event)\">\r\n                  <option *ngFor=\"let count of countOptions; let i = index\" [value]=\"count\"\r\n                     [selected]=\"countOptions.length > 0 && i == 0\">{{ count }}</option>\r\n               </select>\r\n            </div>\r\n\r\n            <!-- Controle de paginação -->\r\n            <pagination-controls\r\n               [id]=\"paginationID\"\r\n               class=\"sp-pagination mt-3\"\r\n               (pageChange)=\"page = $event; pageChange.emit($event)\"\r\n               previousLabel=\"«&nbsp;&nbsp;&nbsp;\" nextLabel=\"&nbsp;&nbsp;&nbsp;»\"\r\n               [maxSize]=\"5\">\r\n            </pagination-controls>\r\n         </div>\r\n         <!-- #endregion PAGINAÇÃO -->\r\n      </div>\r\n   </div>\r\n} @else {\r\n   <!-- Loader enquanto os registros são carregados -->\r\n   <div class=\"w-100 text-center\">\r\n      <div class=\"spinner-border\" role=\"status\"> <span class=\"visually-hidden\">Carregando informações...</span> </div>\r\n   </div>\r\n}\r\n"]}
|
|
@@ -105,4 +105,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
105
105
|
}], onEvent: [{
|
|
106
106
|
type: Output
|
|
107
107
|
}] } });
|
|
108
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-sp-infra/src/lib/widgets/tree/tree.component.ts","../../../../../../projects/ngx-sp-infra/src/lib/widgets/tree/tree.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from \"@angular/core\";\nimport { TreeItem } from \"./models/tree-item\";\n\n@Component({\n  selector: \"app-tree\",\n  templateUrl: \"./tree.component.html\",\n  styleUrls: [\"./tree.component.scss\"]\n})\nexport class TreeComponent implements OnInit {\n  constructor() {}\n\n  ngOnInit(): void {}\n\n  // #region ==========> PROPERTIES <==========\n\n  // #region PRIVATE\n  private _openAll: boolean = false;\n  private _items: TreeItem[] | any[] = [];\n  // #endregino PRIVATE\n\n  // #region PUBLIC\n  @Input()\n  public get items(): TreeItem[] | any[] { return this._items; }\n  public set items(value: TreeItem[] | any[]) { this._items = value; }\n\n  /** Responsável por abrir ou fechar todas as opções sendo exibidas na lista\n   * @default false */\n  @Input()\n  public get openAll(): boolean { return this._openAll; }\n  public set openAll(value: boolean) {\n    this._openAll = value;\n\n    this.items.forEach(elem => {\n      elem.expanded = value;\n      elem.aplicClass = value;\n    });\n  }\n\n  @Input() public checkbox: boolean = false;\n  @Input() public filter: boolean = false;\n\n\n  @Output() public onSelect: EventEmitter<boolean> = new EventEmitter();\n  @Output() public onEvent: EventEmitter<boolean> = new EventEmitter();\n\n\n  public checked = (item: TreeItem) => item.is_selected == true;\n  public search: string = \"\";\n  // #endregion PUBLIC\n\n  // #endregion ==========> PROPERTIES <==========\n\n  // #region ==========> PUBLIC METHODS <==========\n  public onExpand(item: TreeItem): void {\n    if (item.expanded) {\n      item.expanded = !item.expanded;\n      return;\n    } else {\n      if (item.children) {\n        if (item.children.length > 0) {\n          item.expanded = true;\n        } else {\n          item.expanded = false;\n        }\n      }\n    }\n  }\n\n  public onCheck(items: TreeItem[], item: TreeItem): void {\n    if (item.has_children) {\n      item.children.forEach((firstNode) => {\n        if (firstNode.is_selected != item.is_selected) {\n          firstNode.is_selected = !firstNode.is_selected;\n        }\n        if (firstNode.has_children) {\n          firstNode.children.forEach((secondNode) => {\n            if (secondNode.is_selected != firstNode.is_selected) {\n              secondNode.is_selected = !secondNode.is_selected;\n            }\n          });\n        }\n      });\n    }\n    if (this.indeterminateCheck(items)) {\n      this.onSelect.emit(true);\n    } else if (!this.indeterminateCheck(items)) {\n      this.onSelect.emit(false);\n    }\n  }\n\n  public onCheckEvent(items: TreeItem[]) {\n    if (this.indeterminateCheck(items)) {\n      this.onEvent.emit(true);\n    } else {\n      this.onEvent.emit(false);\n    }\n  }\n  // #endregion ==========> PUBLIC METHODS <==========\n\n  // #region ==========> PRIVATE METHODS <==========\n\n  private indeterminateCheck(list: TreeItem[]): boolean {\n    return list.some(this.checked);\n  }\n\n  // private allCheck(list: TreeItem[]): boolean {\n  //   return list.every(this.checked);\n  // }\n  // #endregion ==========> PRIVATE METHODS <==========\n}\n","<!-- FILTER -->\n<ng-template [ngIf]=\"filter\">\n  <!-- <app-search-filters></app-search-filters> -->\n\n  <div class=\"input-group glb-search-input my-3\">\n    <span class=\"input-group-text search px-2 glb-bg-color-white\">\n      <app-svg-storage svgName=\"search\" svgColor=\"gray\" svgSize=\"medium-small\"\n        class=\"d-flex align-items-center\"></app-svg-storage>\n    </span>\n    <input type=\"text\" class=\"form-control border-left-none ps-0\" [(ngModel)]=\"search\">\n  </div>\n  \n</ng-template>\n<!-- TREE -->\n<ul class=\"tree-view\">\n  <ng-container *ngFor=\"let item of items | TreeFilter : search; index as i\">\n    <div class=\"container py-1\" [class]=\"!item.has_children ? 'children' : null \">\n      <app-svg-storage\n        class=\"chevron\"\n        *ngIf=\"item.has_children\"\n        [class]=\"item.aplicClass ? 'rotate' : null\"\n        (click)=\"\n          onExpand(item);\n          item.aplicClass ? (item.aplicClass = false) : (item.aplicClass = true)\n        \"\n        svgSize=\"medium-small\"\n        svgName=\"chevron-right\"\n      ></app-svg-storage>\n      <!-- CHECKBOX -->\n      <ng-template [ngIf]=\"checkbox\">\n        <input\n          type=\"checkbox\"\n          class=\"form-check-input m-0 position-relative\"\n          [checked]=\"onCheckEvent(items)\"\n          (change)=\"onCheck(items, item)\"\n          [(ngModel)]=\"item.is_selected\"\n        />\n      </ng-template>\n      <label class=\"label mb-0 ms-2\">{{ item.label }}</label>\n    </div>\n    <!-- NODES -->\n    <ul *ngIf=\"item.expanded\">\n      <app-tree\n        (onSelect)=\"item.is_selected = $event\"\n        (onEvent)=\"item.is_selected = $event\"\n        [items]=\"item.children\"\n        [checkbox]=\"checkbox\"\n      ></app-tree>\n    </ul>\n  </ng-container>\n</ul>"]}
|
|
108
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-sp-infra/src/lib/widgets/tree/tree.component.ts","../../../../../../projects/ngx-sp-infra/src/lib/widgets/tree/tree.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from \"@angular/core\";\r\nimport { TreeItem } from \"./models/tree-item\";\r\n\r\n@Component({\r\n  selector: \"app-tree\",\r\n  templateUrl: \"./tree.component.html\",\r\n  styleUrls: [\"./tree.component.scss\"]\r\n})\r\nexport class TreeComponent implements OnInit {\r\n  constructor() {}\r\n\r\n  ngOnInit(): void {}\r\n\r\n  // #region ==========> PROPERTIES <==========\r\n\r\n  // #region PRIVATE\r\n  private _openAll: boolean = false;\r\n  private _items: TreeItem[] | any[] = [];\r\n  // #endregino PRIVATE\r\n\r\n  // #region PUBLIC\r\n  @Input()\r\n  public get items(): TreeItem[] | any[] { return this._items; }\r\n  public set items(value: TreeItem[] | any[]) { this._items = value; }\r\n\r\n  /** Responsável por abrir ou fechar todas as opções sendo exibidas na lista\r\n   * @default false */\r\n  @Input()\r\n  public get openAll(): boolean { return this._openAll; }\r\n  public set openAll(value: boolean) {\r\n    this._openAll = value;\r\n\r\n    this.items.forEach(elem => {\r\n      elem.expanded = value;\r\n      elem.aplicClass = value;\r\n    });\r\n  }\r\n\r\n  @Input() public checkbox: boolean = false;\r\n  @Input() public filter: boolean = false;\r\n\r\n\r\n  @Output() public onSelect: EventEmitter<boolean> = new EventEmitter();\r\n  @Output() public onEvent: EventEmitter<boolean> = new EventEmitter();\r\n\r\n\r\n  public checked = (item: TreeItem) => item.is_selected == true;\r\n  public search: string = \"\";\r\n  // #endregion PUBLIC\r\n\r\n  // #endregion ==========> PROPERTIES <==========\r\n\r\n  // #region ==========> PUBLIC METHODS <==========\r\n  public onExpand(item: TreeItem): void {\r\n    if (item.expanded) {\r\n      item.expanded = !item.expanded;\r\n      return;\r\n    } else {\r\n      if (item.children) {\r\n        if (item.children.length > 0) {\r\n          item.expanded = true;\r\n        } else {\r\n          item.expanded = false;\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  public onCheck(items: TreeItem[], item: TreeItem): void {\r\n    if (item.has_children) {\r\n      item.children.forEach((firstNode) => {\r\n        if (firstNode.is_selected != item.is_selected) {\r\n          firstNode.is_selected = !firstNode.is_selected;\r\n        }\r\n        if (firstNode.has_children) {\r\n          firstNode.children.forEach((secondNode) => {\r\n            if (secondNode.is_selected != firstNode.is_selected) {\r\n              secondNode.is_selected = !secondNode.is_selected;\r\n            }\r\n          });\r\n        }\r\n      });\r\n    }\r\n    if (this.indeterminateCheck(items)) {\r\n      this.onSelect.emit(true);\r\n    } else if (!this.indeterminateCheck(items)) {\r\n      this.onSelect.emit(false);\r\n    }\r\n  }\r\n\r\n  public onCheckEvent(items: TreeItem[]) {\r\n    if (this.indeterminateCheck(items)) {\r\n      this.onEvent.emit(true);\r\n    } else {\r\n      this.onEvent.emit(false);\r\n    }\r\n  }\r\n  // #endregion ==========> PUBLIC METHODS <==========\r\n\r\n  // #region ==========> PRIVATE METHODS <==========\r\n\r\n  private indeterminateCheck(list: TreeItem[]): boolean {\r\n    return list.some(this.checked);\r\n  }\r\n\r\n  // private allCheck(list: TreeItem[]): boolean {\r\n  //   return list.every(this.checked);\r\n  // }\r\n  // #endregion ==========> PRIVATE METHODS <==========\r\n}\r\n","<!-- FILTER -->\n<ng-template [ngIf]=\"filter\">\n  <!-- <app-search-filters></app-search-filters> -->\n\n  <div class=\"input-group glb-search-input my-3\">\n    <span class=\"input-group-text search px-2 glb-bg-color-white\">\n      <app-svg-storage svgName=\"search\" svgColor=\"gray\" svgSize=\"medium-small\"\n        class=\"d-flex align-items-center\"></app-svg-storage>\n    </span>\n    <input type=\"text\" class=\"form-control border-left-none ps-0\" [(ngModel)]=\"search\">\n  </div>\n  \n</ng-template>\n<!-- TREE -->\n<ul class=\"tree-view\">\n  <ng-container *ngFor=\"let item of items | TreeFilter : search; index as i\">\n    <div class=\"container py-1\" [class]=\"!item.has_children ? 'children' : null \">\n      <app-svg-storage\n        class=\"chevron\"\n        *ngIf=\"item.has_children\"\n        [class]=\"item.aplicClass ? 'rotate' : null\"\n        (click)=\"\n          onExpand(item);\n          item.aplicClass ? (item.aplicClass = false) : (item.aplicClass = true)\n        \"\n        svgSize=\"medium-small\"\n        svgName=\"chevron-right\"\n      ></app-svg-storage>\n      <!-- CHECKBOX -->\n      <ng-template [ngIf]=\"checkbox\">\n        <input\n          type=\"checkbox\"\n          class=\"form-check-input m-0 position-relative\"\n          [checked]=\"onCheckEvent(items)\"\n          (change)=\"onCheck(items, item)\"\n          [(ngModel)]=\"item.is_selected\"\n        />\n      </ng-template>\n      <label class=\"label mb-0 ms-2\">{{ item.label }}</label>\n    </div>\n    <!-- NODES -->\n    <ul *ngIf=\"item.expanded\">\n      <app-tree\n        (onSelect)=\"item.is_selected = $event\"\n        (onEvent)=\"item.is_selected = $event\"\n        [items]=\"item.children\"\n        [checkbox]=\"checkbox\"\n      ></app-tree>\n    </ul>\n  </ng-container>\n</ul>"]}
|
package/esm2022/public-api.mjs
CHANGED
|
@@ -68,4 +68,5 @@ export * from './lib/widgets/content-container/content-container.component';
|
|
|
68
68
|
export * from './lib/widgets/table/table.component';
|
|
69
69
|
export * from './lib/widgets/spinner/spinner.component';
|
|
70
70
|
export * from './lib/widgets/nav-produtos/nav-produtos.component';
|
|
71
|
-
|
|
71
|
+
export * from './lib/widgets/input-trim/input-trim.component';
|
|
72
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL25neC1zcC1pbmZyYS9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWM7QUFDZCxjQUFjLG9CQUFvQixDQUFDO0FBRW5DLGNBQWM7QUFDZCxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMseUNBQXlDLENBQUM7QUFDeEQsY0FBYyxxREFBcUQsQ0FBQztBQUNwRSxjQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyw0QkFBNEIsQ0FBQztBQUUzQyxhQUFhO0FBQ2IsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYyxtQ0FBbUMsQ0FBQztBQUNsRCxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYyw0Q0FBNEMsQ0FBQztBQUMzRCxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMsd0NBQXdDLENBQUM7QUFFdkQsWUFBWTtBQUNaLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsOEJBQThCLENBQUM7QUFFN0MsaUJBQWlCO0FBQ2pCLGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYywyQ0FBMkMsQ0FBQztBQUMxRCxjQUFjLHVFQUF1RSxDQUFDO0FBQ3RGLGNBQWMsd0NBQXdDLENBQUM7QUFFdkQsWUFBWTtBQUNaLGNBQWMsMENBQTBDLENBQUM7QUFDekQsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsbUJBQW1CLENBQUM7QUFFbEMsZUFBZTtBQUNmLGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYyxrQ0FBa0MsQ0FBQztBQUVqRCxpQkFBaUI7QUFDakIsY0FBYywrQ0FBK0MsQ0FBQztBQUM5RCxjQUFjLHFDQUFxQyxDQUFDO0FBRXBELGNBQWM7QUFDZCxjQUFjLHNFQUFzRSxDQUFDO0FBQ3JGLGNBQWMsZ0ZBQWdGLENBQUM7QUFDL0YsY0FBYyxtRUFBbUUsQ0FBQztBQUNsRixjQUFjLG9EQUFvRCxDQUFDO0FBQ25FLGNBQWMsMkNBQTJDLENBQUM7QUFDMUQsY0FBYyxpRUFBaUUsQ0FBQztBQUNoRixjQUFjLGlFQUFpRSxDQUFDO0FBQ2hGLGNBQWMseUNBQXlDLENBQUM7QUFDeEQsY0FBYyx1REFBdUQsQ0FBQztBQUN0RSxjQUFjLDJDQUEyQyxDQUFDO0FBQzFELGNBQWMsaURBQWlELENBQUM7QUFDaEUsY0FBYyxtQ0FBbUMsQ0FBQztBQUNsRCxjQUFjLG9DQUFvQyxDQUFDO0FBQ25ELGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYywyQ0FBMkMsQ0FBQztBQUUxRCxjQUFjLHlEQUF5RCxDQUFDO0FBQ3hFLGNBQWMsbURBQW1ELENBQUM7QUFFbEUsY0FBYyxxREFBcUQsQ0FBQztBQUNwRSxjQUFjLDZDQUE2QyxDQUFDO0FBQzVELGNBQWMsNkRBQTZELENBQUM7QUFFNUUsY0FBYyxxQ0FBcUMsQ0FBQztBQUNwRCxjQUFjLHlDQUF5QyxDQUFDO0FBQ3hELGNBQWMsbURBQW1ELENBQUM7QUFDbEUsY0FBYywrQ0FBK0MsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXHJcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBpbmZyYVxyXG4gKi9cclxuXHJcbi8qKiBNb2R1bGVzICovXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2luZnJhLm1vZHVsZSc7XHJcblxyXG4vKiogTWVzc2FnZSAqL1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9tZXNzYWdlL2FsZXJ0L2FsZXJ0LmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL21lc3NhZ2UvY29uZmlybS9jb25maXJtLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL21lc3NhZ2UvY29uZmlybS1tb2RhbC9jb25maXJtLW1vZGFsLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL21lc3NhZ2Uvc2F2ZS9zYXZlLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL21lc3NhZ2UvbWVzc2FnZS5zZXJ2aWNlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbWVzc2FnZS9tZXNzYWdlLWVudW0nO1xyXG5cclxuLyoqIE1vZGVscyAqL1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2RlbHMvRG93bmxvYWRBcnF1aXZvcyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZGVscy9lbWFpbC1tb2RlbCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZGVscy9pZXJyb3InO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2RlbHMvaXBhZ2luYXRpb24nO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2RlbHMvcmVwb3J0LWZpbGUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2RlbHMvcmV0LWVycm9yJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kZWxzL3JldC1mZWVkYmFjay1tZXNzYWdlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kZWxzL3JldC1yZXBvcnQtZmlsZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZGVscy9jb21ib2JveC9yZWNvcmQtY29tYm9ib3gnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2RlbHMvY29tYm9ib3gvcmV0LXJlY29yZHMtY29tYm9ib3gnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2RlbHMvaWNvbnMvaWNvbi5tb2RlbCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZGVscy9mb3Jtcy9jdXN0b20tZm9ybS1jb250cm9sJztcclxuXHJcbi8qKiBQaXBlcyAqL1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9waXBlcy9jcGYtY25wai5waXBlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvcGlwZXMvY3VycmVuY3kucGlwZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3BpcGVzL3RvLXVybC5waXBlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvcGlwZXMvdGV4dC1maWx0ZXIucGlwZSc7XHJcblxyXG4vKiogRGlyZWN0aXZlcyAqL1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kaXJlY3RpdmVzL3JlcXVpcmVkLmRpcmVjdGl2ZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RpcmVjdGl2ZXMvY29weS1jbGlwYm9hcmQuZGlyZWN0aXZlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvd2lkZ2V0cy9maWVsZC1jb250YWRvci1tZXNzYWdlL2ZpZWxkLWNvbnRhZG9yLW1lc3NhZ2UuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvZGlyZWN0aXZlcy9sb2FkaW5nLWJ0bi5kaXJlY3RpdmUnO1xyXG5cclxuLyoqIFV0aWxzICovXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3V0aWxzL2NoZWNrLXVybC1hbmQtbWV0aG9kLnNlcnZpY2UnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi91dGlscy9mb3JtLXV0aWxzJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvdXRpbHMvc2V0dGluZ3Muc2VydmljZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3V0aWxzL3V0aWxzJztcclxuXHJcbi8qKiBTZXJ2aWNlcyAqL1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9zZXJ2aWNlL21vZGFsLXV0aWxzLnNlcnZpY2UnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9zZXJ2aWNlL2lwLXNlcnZpY2Uuc2VydmljZSc7XHJcblxyXG4vKiogVmFsaWRhdG9ycyAqL1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi92YWxpZGF0b3JzL2NwZi1jbnBqLnZhbGlkYXRvci5kaXJlY3RpdmUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi92YWxpZGF0b3JzL2NwZi1jbnBqLnZhbGlkYXRvcic7XHJcblxyXG4vKiogV2lkZ2V0cyAqL1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi93aWRnZXRzL2JyZWFkY3J1bWIvaW5mcmEtYnJlYWRjcnVtYi9pbmZyYS1icmVhZGNydW1iLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3dpZGdldHMvYnJlYWRjcnVtYi9pbmZyYS1icmVhZGNydW1iLWl0ZW0vaW5mcmEtYnJlYWRjcnVtYi1pdGVtLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3dpZGdldHMvYnJlYWRjcnVtYi9wb3J0YWxyaC1icmVhZGNydW1iL2JyZWFkY3J1bWIuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvd2lkZ2V0cy9jbGljay1vdXRzaWRlL2NsaWNrb3V0c2lkZS5kaXJlY3RpdmUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi93aWRnZXRzL2NvbWJvYm94L2NvbWJvYm94LmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3dpZGdldHMvZmllbGQtY29udHJvbC1lcnJvci9maWVsZC1jb250cm9sLWVycm9yLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3dpZGdldHMvZmllbGQtZXJyb3ItbWVzc2FnZS9maWVsZC1lcnJvci1tZXNzYWdlLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3dpZGdldHMvbG9hZGluZy9sb2FkaW5nLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3dpZGdldHMvbG9hZGluZy1idXR0b24vbG9hZGluZy1idXR0b24uY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvd2lkZ2V0cy9vcmRlcmluZy9vcmRlcmluZy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi93aWRnZXRzL3N2Zy1zdG9yYWdlL3N2Zy1zdG9yYWdlLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3dpZGdldHMvdHJlZS90cmVlLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3dpZGdldHMvdHJlZS9tb2RlbHMvcmV0LXRyZWUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi93aWRnZXRzL3RyZWUvbW9kZWxzL3RyZWUtaXRlbSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3dpZGdldHMvdHJlZS9waXBlcy9zZWFyY2gtdHJlZS5waXBlJztcclxuXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3dpZGdldHMvc2VhcmNoLWNvbWJvYm94L3NlYXJjaC1jb21ib2JveC5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi93aWRnZXRzL2xpYi1jb21ib2JveC9saWItY29tYm9ib3guY29tcG9uZW50JztcclxuXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3dpZGdldHMvc2ltcGxlLWhlYWRlci9zaW1wbGUtaGVhZGVyLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3dpZGdldHMvbGliLWljb25zL2xpYi1pY29ucy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi93aWRnZXRzL2NvbnRlbnQtY29udGFpbmVyL2NvbnRlbnQtY29udGFpbmVyLmNvbXBvbmVudCc7XHJcblxyXG5leHBvcnQgKiBmcm9tICcuL2xpYi93aWRnZXRzL3RhYmxlL3RhYmxlLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3dpZGdldHMvc3Bpbm5lci9zcGlubmVyLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3dpZGdldHMvbmF2LXByb2R1dG9zL25hdi1wcm9kdXRvcy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi93aWRnZXRzL2lucHV0LXRyaW0vaW5wdXQtdHJpbS5jb21wb25lbnQnO1xyXG4iXX0=
|