lib-portal-angular 0.0.36 → 0.0.38

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.
Files changed (26) hide show
  1. package/esm2022/lib/components/button/button.component.mjs +31 -15
  2. package/esm2022/lib/components/components.module.mjs +8 -3
  3. package/esm2022/lib/components/confirmation/confirmation.component.mjs +7 -4
  4. package/esm2022/lib/components/confirmation/confirmation.service.mjs +16 -7
  5. package/esm2022/lib/components/custom-pagination/custom-pagination.component.mjs +7 -1
  6. package/esm2022/lib/components/imput/input.component.mjs +34 -29
  7. package/esm2022/lib/components/search-input/search-input.component.mjs +122 -0
  8. package/esm2022/lib/components/tables/data-paginate.service.mjs +37 -0
  9. package/esm2022/lib/components/tables/data-table.component.mjs +81 -45
  10. package/esm2022/lib/lib-portal-angular.module.mjs +6 -3
  11. package/esm2022/lib/service/auth-service.service.mjs +34 -0
  12. package/esm2022/public-api.mjs +3 -1
  13. package/fesm2022/lib-portal-angular.mjs +355 -97
  14. package/fesm2022/lib-portal-angular.mjs.map +1 -1
  15. package/lib/components/button/button.component.d.ts +9 -5
  16. package/lib/components/components.module.d.ts +5 -4
  17. package/lib/components/confirmation/confirmation.component.d.ts +3 -1
  18. package/lib/components/confirmation/confirmation.service.d.ts +4 -1
  19. package/lib/components/custom-pagination/custom-pagination.component.d.ts +4 -2
  20. package/lib/components/imput/input.component.d.ts +8 -7
  21. package/lib/components/search-input/search-input.component.d.ts +44 -0
  22. package/lib/components/tables/data-paginate.service.d.ts +21 -0
  23. package/lib/components/tables/data-table.component.d.ts +22 -14
  24. package/lib/service/auth-service.service.d.ts +9 -0
  25. package/package.json +1 -1
  26. package/public-api.d.ts +2 -0
@@ -1,14 +1,17 @@
1
1
  import * as i0 from '@angular/core';
2
- import { Component, Input, EventEmitter, ChangeDetectionStrategy, Output, HostListener, forwardRef, ViewChild, Directive, NgModule, createComponent, Injectable } from '@angular/core';
2
+ import { Component, Input, EventEmitter, ChangeDetectionStrategy, Output, HostListener, Injectable, forwardRef, ViewChild, Directive, NgModule, createComponent } from '@angular/core';
3
3
  import * as i1 from '@angular/common';
4
4
  import { CommonModule } from '@angular/common';
5
- import * as i2 from '@angular/forms';
5
+ import * as i3 from '@angular/forms';
6
6
  import { NG_VALUE_ACCESSOR, FormsModule, ReactiveFormsModule } from '@angular/forms';
7
7
  import hljs from 'highlight.js';
8
8
  import * as i1$1 from '@ng-bootstrap/ng-bootstrap';
9
- import { of, Subject } from 'rxjs';
10
- import * as i3 from '@ng-select/ng-select';
9
+ import { Subject, of, Subscription, Observable } from 'rxjs';
10
+ import * as i3$1 from '@ng-select/ng-select';
11
11
  import { NgSelectModule } from '@ng-select/ng-select';
12
+ import { debounceTime, takeUntil, map } from 'rxjs/operators';
13
+ import * as i1$2 from '@angular/common/http';
14
+ import { HttpParams } from '@angular/common/http';
12
15
 
13
16
  class AlertComponent {
14
17
  constructor() {
@@ -250,8 +253,41 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
250
253
  args: ['mouseup']
251
254
  }] } });
252
255
 
253
- class ButtonComponent {
256
+ class AuthService {
254
257
  constructor() {
258
+ this.userRoles = [];
259
+ this.loadUserRoles();
260
+ }
261
+ loadUserRoles() {
262
+ const storedUser = localStorage.getItem('user');
263
+ if (!storedUser) {
264
+ throw new Error('User not found in localStorage');
265
+ }
266
+ const { role } = JSON.parse(storedUser);
267
+ if (!role || !Array.isArray(role)) {
268
+ throw new Error('Roles not found or invalid in localStorage');
269
+ }
270
+ this.userRoles = role.flatMap((roleArray) => roleArray.map(role => role.toString()));
271
+ }
272
+ hasPermission(requiredPermissions) {
273
+ if (this.userRoles.length === 0) {
274
+ throw new Error('No roles found for the user');
275
+ }
276
+ return requiredPermissions.every(permission => this.userRoles.includes(permission));
277
+ }
278
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AuthService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
279
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AuthService, providedIn: 'root' }); }
280
+ }
281
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AuthService, decorators: [{
282
+ type: Injectable,
283
+ args: [{
284
+ providedIn: 'root'
285
+ }]
286
+ }], ctorParameters: function () { return []; } });
287
+
288
+ class ButtonComponent {
289
+ constructor(authService) {
290
+ this.authService = authService;
255
291
  this.type = 'button';
256
292
  this.label = 'Submit';
257
293
  this.btnClass = ButtonClasses.Primary;
@@ -271,11 +307,13 @@ class ButtonComponent {
271
307
  this.marginLeft = 0;
272
308
  this.marginRight = 0;
273
309
  this.permissions = [];
274
- this.permissionChecker = null;
275
310
  this.clickEvent = new EventEmitter();
276
311
  this.isHovered = false;
277
312
  this.isActive = false;
278
313
  }
314
+ ngOnInit() {
315
+ // O componente não precisa capturar erros do serviço, apenas chama o método de verificação
316
+ }
279
317
  onMouseEnter() {
280
318
  this.isHovered = true;
281
319
  }
@@ -292,7 +330,10 @@ class ButtonComponent {
292
330
  onClick(event) {
293
331
  this.clickEvent.emit(event);
294
332
  }
295
- getDynamicStyles() {
333
+ get dynamicStyles() {
334
+ return this.calculateDynamicStyles();
335
+ }
336
+ calculateDynamicStyles() {
296
337
  let backgroundColor = '';
297
338
  let textColor = '#fff'; // Default text color
298
339
  let borderColor = '';
@@ -347,18 +388,29 @@ class ButtonComponent {
347
388
  };
348
389
  }
349
390
  hasPermission() {
350
- if (!this.permissionChecker || this.permissions.length === 0) {
391
+ if (!this.permissions || this.permissions.length === 0) {
392
+ return true;
393
+ }
394
+ try {
395
+ return this.authService.hasPermission(this.permissions);
396
+ }
397
+ catch (error) {
398
+ if (error instanceof Error) {
399
+ console.error('Permission error:', error.message);
400
+ }
401
+ else {
402
+ console.error('Unknown error occurred during permission check');
403
+ }
351
404
  return true;
352
405
  }
353
- return this.permissionChecker(this.permissions);
354
406
  }
355
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
356
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ButtonComponent, selector: "sim-app-button", inputs: { type: "type", label: "label", btnClass: "btnClass", fontSize: "fontSize", disabled: "disabled", autofocus: "autofocus", form: "form", formaction: "formaction", formenctype: "formenctype", formmethod: "formmethod", formnovalidate: "formnovalidate", formtarget: "formtarget", name: "name", value: "value", marginTop: "marginTop", marginBottom: "marginBottom", marginLeft: "marginLeft", marginRight: "marginRight", permissions: "permissions", permissionChecker: "permissionChecker" }, outputs: { clickEvent: "clickEvent" }, host: { listeners: { "mouseenter": "onMouseEnter()", "mouseleave": "onMouseLeave()", "mousedown": "onMouseDown()", "mouseup": "onMouseUp()" } }, ngImport: i0, template: `
407
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ButtonComponent, deps: [{ token: AuthService }], target: i0.ɵɵFactoryTarget.Component }); }
408
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ButtonComponent, selector: "sim-app-button", inputs: { type: "type", label: "label", btnClass: "btnClass", fontSize: "fontSize", disabled: "disabled", autofocus: "autofocus", form: "form", formaction: "formaction", formenctype: "formenctype", formmethod: "formmethod", formnovalidate: "formnovalidate", formtarget: "formtarget", name: "name", value: "value", marginTop: "marginTop", marginBottom: "marginBottom", marginLeft: "marginLeft", marginRight: "marginRight", permissions: "permissions" }, outputs: { clickEvent: "clickEvent" }, host: { listeners: { "mouseenter": "onMouseEnter()", "mouseleave": "onMouseLeave()", "mousedown": "onMouseDown()", "mouseup": "onMouseUp()" } }, ngImport: i0, template: `
357
409
  <ng-container *ngIf="hasPermission()">
358
410
  <button [type]="type"
359
411
  class="btn"
360
412
  [ngClass]="btnClass"
361
- [ngStyle]="getDynamicStyles()"
413
+ [ngStyle]="dynamicStyles"
362
414
  (click)="onClick($event)"
363
415
  [disabled]="disabled"
364
416
  [attr.autofocus]="autofocus ? true : null"
@@ -382,7 +434,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
382
434
  <button [type]="type"
383
435
  class="btn"
384
436
  [ngClass]="btnClass"
385
- [ngStyle]="getDynamicStyles()"
437
+ [ngStyle]="dynamicStyles"
386
438
  (click)="onClick($event)"
387
439
  [disabled]="disabled"
388
440
  [attr.autofocus]="autofocus ? true : null"
@@ -398,7 +450,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
398
450
  </button>
399
451
  </ng-container>
400
452
  `, changeDetection: ChangeDetectionStrategy.OnPush, styles: [".btn{padding:.5rem 1rem;border-radius:.25rem;transition:background-color .3s,border-color .3s,filter .3s;font-family:Inter,sans-serif;font-size:16px;font-weight:600;line-height:24px;letter-spacing:.005em;text-align:left}\n"] }]
401
- }], propDecorators: { type: [{
453
+ }], ctorParameters: function () { return [{ type: AuthService }]; }, propDecorators: { type: [{
402
454
  type: Input
403
455
  }], label: [{
404
456
  type: Input
@@ -436,8 +488,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
436
488
  type: Input
437
489
  }], permissions: [{
438
490
  type: Input
439
- }], permissionChecker: [{
440
- type: Input
441
491
  }], clickEvent: [{
442
492
  type: Output
443
493
  }], onMouseEnter: [{
@@ -676,12 +726,15 @@ class ConfirmationComponent {
676
726
  cancel() {
677
727
  this.activeModal.dismiss('cancel');
678
728
  }
729
+ ngOnDestroy() {
730
+ // Clear any subscriptions if there were any
731
+ }
679
732
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ConfirmationComponent, deps: [{ token: i1$1.NgbActiveModal }], target: i0.ɵɵFactoryTarget.Component }); }
680
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ConfirmationComponent, selector: "app-confirmation", inputs: { title: "title", message: "message", confirmButtonText: "confirmButtonText", cancelButtonText: "cancelButtonText" }, ngImport: i0, template: "<div class=\"modal-header\">\n <h5 class=\"modal-title\" id=\"confirmationModalLabel\">{{ title }}</h5>\n</div>\n<div class=\"modal-body\">\n <p>{{ message }}</p>\n</div>\n<div class=\"modal-footer\">\n <button type=\"button\" class=\"btn btn-secondary\" (click)=\"cancel()\">{{ cancelButtonText }}</button>\n <button type=\"button\" class=\"btn btn-primary\" (click)=\"confirm()\" appAutofocus>{{ confirmButtonText }}</button>\n</div>\n", styles: ["@charset \"UTF-8\";.modal-header{background-color:#00444c}.modal-title{font-family:Inter,sans-serif;color:#fff}.modal-body{text-align:center}.modal-body p{color:#666;font-family:Inter,sans-serif;font-size:1.5rem}.modal-footer{background-color:#e9eaeb}.btn-primary{background-color:#00444c;border-color:#00444c;font-family:Inter,sans-serif;transition:opacity .3s,transform .1s}.btn-primary:hover{opacity:.8}.btn-primary:active{transform:scale(.98);background-color:#00444c;border-color:#00444c}.btn-secondary{background-color:#f44336;border-color:#f44336;font-family:Inter,sans-serif;transition:opacity .3s,transform .1s}.btn-secondary:hover{opacity:.8}.btn-secondary:active{transform:scale(.98);background-color:#f44336;border-color:#f44336}\n"], dependencies: [{ kind: "directive", type: AutofocusDirective, selector: "[appAutofocus]" }] }); }
733
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ConfirmationComponent, selector: "app-confirmation", inputs: { title: "title", message: "message", confirmButtonText: "confirmButtonText", cancelButtonText: "cancelButtonText" }, ngImport: i0, template: "<div class=\"modal-header\">\n <h5 class=\"modal-title\" id=\"confirmationModalLabel\">{{ title }}</h5>\n</div>\n<div class=\"modal-body\">\n <p>{{ message }}</p>\n</div>\n<div class=\"modal-footer\">\n <button type=\"button\" class=\"btn btn-secondary\" (click)=\"cancel()\">{{ cancelButtonText }}</button>\n <button type=\"button\" class=\"btn btn-primary\" (click)=\"confirm()\" appAutofocus>{{ confirmButtonText }}</button>\n</div>\n", styles: ["@charset \"UTF-8\";.modal-header{background-color:#00444c}.modal-title{font-family:Inter,sans-serif;color:#fff}.modal-body{text-align:center}.modal-body p{color:#666;font-family:Inter,sans-serif;font-size:1.5rem}.modal-footer{background-color:#e9eaeb}.btn-primary{background-color:#00444c;border-color:#00444c;font-family:Inter,sans-serif;transition:opacity .3s,transform .1s}.btn-primary:hover{opacity:.8}.btn-primary:active{transform:scale(.98);background-color:#00444c;border-color:#00444c}.btn-secondary{background-color:#f44336;border-color:#f44336;font-family:Inter,sans-serif;transition:opacity .3s,transform .1s}.btn-secondary:hover{opacity:.8}.btn-secondary:active{transform:scale(.98);background-color:#f44336;border-color:#f44336}\n"], dependencies: [{ kind: "directive", type: AutofocusDirective, selector: "[appAutofocus]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
681
734
  }
682
735
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ConfirmationComponent, decorators: [{
683
736
  type: Component,
684
- args: [{ selector: 'app-confirmation', template: "<div class=\"modal-header\">\n <h5 class=\"modal-title\" id=\"confirmationModalLabel\">{{ title }}</h5>\n</div>\n<div class=\"modal-body\">\n <p>{{ message }}</p>\n</div>\n<div class=\"modal-footer\">\n <button type=\"button\" class=\"btn btn-secondary\" (click)=\"cancel()\">{{ cancelButtonText }}</button>\n <button type=\"button\" class=\"btn btn-primary\" (click)=\"confirm()\" appAutofocus>{{ confirmButtonText }}</button>\n</div>\n", styles: ["@charset \"UTF-8\";.modal-header{background-color:#00444c}.modal-title{font-family:Inter,sans-serif;color:#fff}.modal-body{text-align:center}.modal-body p{color:#666;font-family:Inter,sans-serif;font-size:1.5rem}.modal-footer{background-color:#e9eaeb}.btn-primary{background-color:#00444c;border-color:#00444c;font-family:Inter,sans-serif;transition:opacity .3s,transform .1s}.btn-primary:hover{opacity:.8}.btn-primary:active{transform:scale(.98);background-color:#00444c;border-color:#00444c}.btn-secondary{background-color:#f44336;border-color:#f44336;font-family:Inter,sans-serif;transition:opacity .3s,transform .1s}.btn-secondary:hover{opacity:.8}.btn-secondary:active{transform:scale(.98);background-color:#f44336;border-color:#f44336}\n"] }]
737
+ args: [{ selector: 'app-confirmation', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"modal-header\">\n <h5 class=\"modal-title\" id=\"confirmationModalLabel\">{{ title }}</h5>\n</div>\n<div class=\"modal-body\">\n <p>{{ message }}</p>\n</div>\n<div class=\"modal-footer\">\n <button type=\"button\" class=\"btn btn-secondary\" (click)=\"cancel()\">{{ cancelButtonText }}</button>\n <button type=\"button\" class=\"btn btn-primary\" (click)=\"confirm()\" appAutofocus>{{ confirmButtonText }}</button>\n</div>\n", styles: ["@charset \"UTF-8\";.modal-header{background-color:#00444c}.modal-title{font-family:Inter,sans-serif;color:#fff}.modal-body{text-align:center}.modal-body p{color:#666;font-family:Inter,sans-serif;font-size:1.5rem}.modal-footer{background-color:#e9eaeb}.btn-primary{background-color:#00444c;border-color:#00444c;font-family:Inter,sans-serif;transition:opacity .3s,transform .1s}.btn-primary:hover{opacity:.8}.btn-primary:active{transform:scale(.98);background-color:#00444c;border-color:#00444c}.btn-secondary{background-color:#f44336;border-color:#f44336;font-family:Inter,sans-serif;transition:opacity .3s,transform .1s}.btn-secondary:hover{opacity:.8}.btn-secondary:active{transform:scale(.98);background-color:#f44336;border-color:#f44336}\n"] }]
685
738
  }], ctorParameters: function () { return [{ type: i1$1.NgbActiveModal }]; }, propDecorators: { title: [{
686
739
  type: Input
687
740
  }], message: [{
@@ -702,6 +755,7 @@ class CustomPaginationComponent {
702
755
  this.ofText = 'of'; // Texto para "of"
703
756
  this.showPageInfo = true; // Mostrar ou esconder a informação da página
704
757
  this.pageChange = new EventEmitter();
758
+ this.destroy$ = new Subject();
705
759
  }
706
760
  get totalPages() {
707
761
  return Math.ceil(this.totalItems / this.itemsPerPage);
@@ -726,6 +780,10 @@ class CustomPaginationComponent {
726
780
  }
727
781
  return pages;
728
782
  }
783
+ ngOnDestroy() {
784
+ this.destroy$.next();
785
+ this.destroy$.complete();
786
+ }
729
787
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CustomPaginationComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
730
788
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CustomPaginationComponent, selector: "custom-pagination", inputs: { totalItems: "totalItems", itemsPerPage: "itemsPerPage", currentPage: "currentPage", maxSize: "maxSize", pageText: "pageText", ofText: "ofText", showPageInfo: "showPageInfo" }, outputs: { pageChange: "pageChange" }, ngImport: i0, template: "<nav *ngIf=\"totalPages > 0\">\n <ul class=\"pagination\">\n <li class=\"page-item\" [class.disabled]=\"currentPage === 1\">\n <a class=\"page-link\" (click)=\"changePage(1)\">&laquo;&laquo;</a>\n </li>\n <li class=\"page-item\" [class.disabled]=\"currentPage === 1\">\n <a class=\"page-link\" (click)=\"changePage(currentPage - 1)\">&laquo;</a>\n </li>\n <li class=\"page-item\" *ngFor=\"let page of pages\" [class.active]=\"page === currentPage\">\n <a class=\"page-link\" (click)=\"changePage(page)\">{{ page }}</a>\n </li>\n <li class=\"page-item\" [class.disabled]=\"currentPage === totalPages\">\n <a class=\"page-link\" (click)=\"changePage(currentPage + 1)\">&raquo;</a>\n </li>\n <li class=\"page-item\" [class.disabled]=\"currentPage === totalPages\">\n <a class=\"page-link\" (click)=\"changePage(totalPages)\">&raquo;&raquo;</a>\n </li>\n </ul>\n <div class=\"page-info\" *ngIf=\"showPageInfo\" style=\"font-size: 0.8rem;\">\n {{ pageText }} {{ currentPage }} {{ ofText }} {{ totalPages }}\n </div>\n</nav>\n", styles: [".pagination{display:flex;list-style:none;padding:0;margin:1rem 0;justify-content:center;align-items:center}.page-item{margin:0 .25rem}.page-item.disabled .page-link{cursor:not-allowed;opacity:.5}.page-item.active .page-link{background-color:#00444c;color:#fff}.page-item .page-link{padding:.5rem .75rem;border:1px solid #dee2e6;border-radius:.25rem;text-decoration:none;color:#00444c;cursor:pointer;transition:background-color .2s}.page-item .page-link:hover{background-color:#2ca58d}.page-info{margin-left:1rem;font-size:1rem;color:#00444c;font-weight:700}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
731
789
  }
@@ -820,7 +878,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
820
878
  }] } });
821
879
 
822
880
  class InputComponent {
823
- constructor() {
881
+ constructor(authService) {
882
+ this.authService = authService;
824
883
  this.label = 'Default Label';
825
884
  this.placeholder = '';
826
885
  this.id = 'inputId';
@@ -838,7 +897,6 @@ class InputComponent {
838
897
  this.marginRight = 0;
839
898
  this.labelFontWeight = 400;
840
899
  this.permissions = [];
841
- this.permissionChecker = null;
842
900
  this.inputEvent = new EventEmitter();
843
901
  this.changeEvent = new EventEmitter();
844
902
  this.focusEvent = new EventEmitter();
@@ -849,6 +907,7 @@ class InputComponent {
849
907
  this.onChangeCallback = () => { };
850
908
  this.onTouchedCallback = () => { };
851
909
  this.value = '';
910
+ this.subscriptions = [];
852
911
  }
853
912
  onInput(event) {
854
913
  const inputElement = event.target;
@@ -866,15 +925,6 @@ class InputComponent {
866
925
  this.onTouchedCallback();
867
926
  this.blurEvent.emit(event);
868
927
  }
869
- onKeyup(event) {
870
- this.keyupEvent.emit(event);
871
- }
872
- onKeydown(event) {
873
- this.keydownEvent.emit(event);
874
- }
875
- onKeypress(event) {
876
- this.keypressEvent.emit(event);
877
- }
878
928
  writeValue(value) {
879
929
  this.value = value;
880
930
  }
@@ -888,10 +938,21 @@ class InputComponent {
888
938
  this.disabled = isDisabled;
889
939
  }
890
940
  hasPermission() {
891
- if (!this.permissionChecker || this.permissions.length === 0) {
941
+ if (this.permissions.length === 0) {
942
+ return true;
943
+ }
944
+ try {
945
+ return this.authService.hasPermission(this.permissions);
946
+ }
947
+ catch (error) {
948
+ if (error instanceof Error) {
949
+ console.error('Permission error:', error.message);
950
+ }
951
+ else {
952
+ console.error('Unknown error occurred during permission check');
953
+ }
892
954
  return true;
893
955
  }
894
- return this.permissionChecker(this.permissions);
895
956
  }
896
957
  getLabelStyles() {
897
958
  return {
@@ -908,8 +969,11 @@ class InputComponent {
908
969
  'text-align': 'left'
909
970
  };
910
971
  }
911
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: InputComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
912
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: InputComponent, selector: "sim-app-input", inputs: { label: "label", placeholder: "placeholder", id: "id", type: "type", disabled: "disabled", readonly: "readonly", maxlength: "maxlength", minlength: "minlength", required: "required", pattern: "pattern", autofocus: "autofocus", marginTop: "marginTop", marginBottom: "marginBottom", marginLeft: "marginLeft", marginRight: "marginRight", labelFontWeight: "labelFontWeight", permissions: "permissions", permissionChecker: "permissionChecker" }, outputs: { inputEvent: "inputEvent", changeEvent: "changeEvent", focusEvent: "focusEvent", blurEvent: "blurEvent", keyupEvent: "keyupEvent", keydownEvent: "keydownEvent", keypressEvent: "keypressEvent" }, providers: [
972
+ ngOnDestroy() {
973
+ this.subscriptions.forEach(sub => sub.unsubscribe());
974
+ }
975
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: InputComponent, deps: [{ token: AuthService }], target: i0.ɵɵFactoryTarget.Component }); }
976
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: InputComponent, selector: "sim-app-input", inputs: { label: "label", placeholder: "placeholder", id: "id", type: "type", disabled: "disabled", readonly: "readonly", maxlength: "maxlength", minlength: "minlength", required: "required", pattern: "pattern", autofocus: "autofocus", marginTop: "marginTop", marginBottom: "marginBottom", marginLeft: "marginLeft", marginRight: "marginRight", labelFontWeight: "labelFontWeight", permissions: "permissions" }, outputs: { inputEvent: "inputEvent", changeEvent: "changeEvent", focusEvent: "focusEvent", blurEvent: "blurEvent", keyupEvent: "keyupEvent", keydownEvent: "keydownEvent", keypressEvent: "keypressEvent" }, providers: [
913
977
  {
914
978
  provide: NG_VALUE_ACCESSOR,
915
979
  useExisting: forwardRef(() => InputComponent),
@@ -932,9 +996,9 @@ class InputComponent {
932
996
  (change)="onChange($event)"
933
997
  (focus)="onFocus($event)"
934
998
  (blur)="onBlur($event)"
935
- (keyup)="onKeyup($event)"
936
- (keydown)="onKeydown($event)"
937
- (keypress)="onKeypress($event)"
999
+ (keyup)="keyupEvent.emit($event)"
1000
+ (keydown)="keydownEvent.emit($event)"
1001
+ (keypress)="keypressEvent.emit($event)"
938
1002
  [disabled]="disabled"
939
1003
  [readonly]="readonly"
940
1004
  [attr.maxlength]="maxlength"
@@ -943,7 +1007,7 @@ class InputComponent {
943
1007
  [attr.pattern]="pattern"
944
1008
  [autofocus]="autofocus">
945
1009
  </div>
946
- `, isInline: true, styles: [".form-group{font-family:Inter;font-size:1rem;font-weight:700}.form-check-input{font-family:Inter;color:#333;font-size:.9rem}.form-check-label{width:623px;height:19px;top:1608px;left:133px;gap:0px;opacity:0px;font-family:Inter;font-size:16px;line-height:19.36px;text-align:left}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
1010
+ `, isInline: true, styles: [".form-group{font-family:Inter;font-size:1rem;font-weight:700}.form-check-input{font-family:Inter;color:#333;font-size:.9rem}.form-check-label{width:623px;height:19px;top:1608px;left:133px;gap:0px;opacity:0px;font-family:Inter;font-size:16px;line-height:19.36px;text-align:left}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
947
1011
  }
948
1012
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: InputComponent, decorators: [{
949
1013
  type: Component,
@@ -964,9 +1028,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
964
1028
  (change)="onChange($event)"
965
1029
  (focus)="onFocus($event)"
966
1030
  (blur)="onBlur($event)"
967
- (keyup)="onKeyup($event)"
968
- (keydown)="onKeydown($event)"
969
- (keypress)="onKeypress($event)"
1031
+ (keyup)="keyupEvent.emit($event)"
1032
+ (keydown)="keydownEvent.emit($event)"
1033
+ (keypress)="keypressEvent.emit($event)"
970
1034
  [disabled]="disabled"
971
1035
  [readonly]="readonly"
972
1036
  [attr.maxlength]="maxlength"
@@ -982,7 +1046,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
982
1046
  multi: true
983
1047
  }
984
1048
  ], changeDetection: ChangeDetectionStrategy.OnPush, styles: [".form-group{font-family:Inter;font-size:1rem;font-weight:700}.form-check-input{font-family:Inter;color:#333;font-size:.9rem}.form-check-label{width:623px;height:19px;top:1608px;left:133px;gap:0px;opacity:0px;font-family:Inter;font-size:16px;line-height:19.36px;text-align:left}\n"] }]
985
- }], propDecorators: { label: [{
1049
+ }], ctorParameters: function () { return [{ type: AuthService }]; }, propDecorators: { label: [{
986
1050
  type: Input
987
1051
  }], placeholder: [{
988
1052
  type: Input
@@ -1016,8 +1080,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
1016
1080
  type: Input
1017
1081
  }], permissions: [{
1018
1082
  type: Input
1019
- }], permissionChecker: [{
1020
- type: Input
1021
1083
  }], inputEvent: [{
1022
1084
  type: Output
1023
1085
  }], changeEvent: [{
@@ -1111,7 +1173,7 @@ class MultiSelectComponent {
1111
1173
  </ng-template>
1112
1174
  </ng-select>
1113
1175
  </div>
1114
- `, isInline: true, styles: [".form-group{font-family:Arial,sans-serif;font-size:1rem}.form-label{font-weight:700}\n"], dependencies: [{ kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.NgSelectComponent, selector: "ng-select", inputs: ["bindLabel", "bindValue", "markFirst", "placeholder", "notFoundText", "typeToSearchText", "addTagText", "loadingText", "clearAllText", "appearance", "dropdownPosition", "appendTo", "loading", "closeOnSelect", "hideSelected", "selectOnTab", "openOnEnter", "maxSelectedItems", "groupBy", "groupValue", "bufferAmount", "virtualScroll", "selectableGroup", "selectableGroupAsModel", "searchFn", "trackByFn", "clearOnBackspace", "labelForId", "inputAttrs", "tabIndex", "readonly", "searchWhileComposing", "minTermLength", "editableSearchTerm", "keyDownFn", "typeahead", "multiple", "addTag", "searchable", "clearable", "isOpen", "items", "compareWith", "clearSearchOnAdd", "deselectOnClick"], outputs: ["blur", "focus", "change", "open", "close", "search", "clear", "add", "remove", "scroll", "scrollToEnd"] }, { kind: "directive", type: i3.NgOptionTemplateDirective, selector: "[ng-option-tmp]" }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
1176
+ `, isInline: true, styles: [".form-group{font-family:Arial,sans-serif;font-size:1rem}.form-label{font-weight:700}\n"], dependencies: [{ kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3$1.NgSelectComponent, selector: "ng-select", inputs: ["bindLabel", "bindValue", "markFirst", "placeholder", "notFoundText", "typeToSearchText", "addTagText", "loadingText", "clearAllText", "appearance", "dropdownPosition", "appendTo", "loading", "closeOnSelect", "hideSelected", "selectOnTab", "openOnEnter", "maxSelectedItems", "groupBy", "groupValue", "bufferAmount", "virtualScroll", "selectableGroup", "selectableGroupAsModel", "searchFn", "trackByFn", "clearOnBackspace", "labelForId", "inputAttrs", "tabIndex", "readonly", "searchWhileComposing", "minTermLength", "editableSearchTerm", "keyDownFn", "typeahead", "multiple", "addTag", "searchable", "clearable", "isOpen", "items", "compareWith", "clearSearchOnAdd", "deselectOnClick"], outputs: ["blur", "focus", "change", "open", "close", "search", "clear", "add", "remove", "scroll", "scrollToEnd"] }, { kind: "directive", type: i3$1.NgOptionTemplateDirective, selector: "[ng-option-tmp]" }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
1115
1177
  }
1116
1178
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: MultiSelectComponent, decorators: [{
1117
1179
  type: Component,
@@ -1284,6 +1346,122 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
1284
1346
  type: Output
1285
1347
  }] } });
1286
1348
 
1349
+ class SearchInputComponent {
1350
+ constructor() {
1351
+ this.id = '';
1352
+ this.label = 'Search';
1353
+ this.type = 'text';
1354
+ this.placeholder = 'Type to search...';
1355
+ this.value = '';
1356
+ this.disabled = false;
1357
+ this.readonly = false;
1358
+ this.autofocus = false;
1359
+ this.maxlength = null;
1360
+ this.minlength = null;
1361
+ this.required = false;
1362
+ this.pattern = null;
1363
+ this.debounceTime = 700; // Valor padrão
1364
+ this.search = new EventEmitter();
1365
+ this.inputChange = new EventEmitter();
1366
+ this.change = new EventEmitter();
1367
+ this.focus = new EventEmitter();
1368
+ this.blur = new EventEmitter();
1369
+ this.keyup = new EventEmitter();
1370
+ this.keydown = new EventEmitter();
1371
+ this.keypress = new EventEmitter();
1372
+ this.searchSubject = new Subject();
1373
+ this.searchSubscription = new Subscription();
1374
+ }
1375
+ ngOnInit() {
1376
+ this.searchSubscription = this.searchSubject.pipe(debounceTime(this.debounceTime)).subscribe((searchText) => {
1377
+ this.search.emit(searchText);
1378
+ });
1379
+ }
1380
+ onInput(event) {
1381
+ const inputElement = event.target;
1382
+ const value = inputElement.value;
1383
+ this.value = value;
1384
+ this.inputChange.emit(value); // Emite o valor de input imediatamente
1385
+ this.searchSubject.next(value);
1386
+ }
1387
+ onChange(event) {
1388
+ this.change.emit(event);
1389
+ }
1390
+ onFocus(event) {
1391
+ this.focus.emit(event);
1392
+ }
1393
+ onBlur(event) {
1394
+ this.blur.emit(event);
1395
+ }
1396
+ onKeyup(event) {
1397
+ this.keyup.emit(event);
1398
+ }
1399
+ onKeydown(event) {
1400
+ this.keydown.emit(event);
1401
+ }
1402
+ onKeypress(event) {
1403
+ this.keypress.emit(event);
1404
+ }
1405
+ ngOnDestroy() {
1406
+ this.searchSubscription.unsubscribe();
1407
+ }
1408
+ getLabelStyles() {
1409
+ return {
1410
+ fontFamily: 'Inter',
1411
+ fontSize: '16px',
1412
+ lineHeight: '19.36px',
1413
+ };
1414
+ }
1415
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SearchInputComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
1416
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: SearchInputComponent, selector: "sim-search-input", inputs: { id: "id", label: "label", type: "type", placeholder: "placeholder", value: "value", disabled: "disabled", readonly: "readonly", autofocus: "autofocus", maxlength: "maxlength", minlength: "minlength", required: "required", pattern: "pattern", debounceTime: "debounceTime" }, outputs: { search: "search", inputChange: "inputChange", change: "change", focus: "focus", blur: "blur", keyup: "keyup", keydown: "keydown", keypress: "keypress" }, ngImport: i0, template: "<div class=\"form-group\">\n <label [for]=\"id\" [ngStyle]=\"getLabelStyles()\">{{ label }}</label>\n <input [type]=\"type\"\n class=\"form-control custom-input\"\n [id]=\"id\"\n [placeholder]=\"placeholder\"\n [(ngModel)]=\"value\"\n (input)=\"onInput($event)\"\n (change)=\"onChange($event)\"\n (focus)=\"onFocus($event)\"\n (blur)=\"onBlur($event)\"\n (keyup)=\"onKeyup($event)\"\n (keydown)=\"onKeydown($event)\"\n (keypress)=\"onKeypress($event)\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n [attr.maxlength]=\"maxlength\"\n [attr.minlength]=\"minlength\"\n [required]=\"required\"\n [attr.pattern]=\"pattern\"\n [autofocus]=\"autofocus\">\n</div>\n", styles: [".form-group{font-family:Inter;font-size:1rem;font-weight:700}.custom-input{font-family:Inter;color:#333;font-size:.9rem}label{font-family:Inter;font-size:16px;line-height:19.36px;text-align:left}\n"], dependencies: [{ kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] }); }
1417
+ }
1418
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SearchInputComponent, decorators: [{
1419
+ type: Component,
1420
+ args: [{ selector: 'sim-search-input', template: "<div class=\"form-group\">\n <label [for]=\"id\" [ngStyle]=\"getLabelStyles()\">{{ label }}</label>\n <input [type]=\"type\"\n class=\"form-control custom-input\"\n [id]=\"id\"\n [placeholder]=\"placeholder\"\n [(ngModel)]=\"value\"\n (input)=\"onInput($event)\"\n (change)=\"onChange($event)\"\n (focus)=\"onFocus($event)\"\n (blur)=\"onBlur($event)\"\n (keyup)=\"onKeyup($event)\"\n (keydown)=\"onKeydown($event)\"\n (keypress)=\"onKeypress($event)\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n [attr.maxlength]=\"maxlength\"\n [attr.minlength]=\"minlength\"\n [required]=\"required\"\n [attr.pattern]=\"pattern\"\n [autofocus]=\"autofocus\">\n</div>\n", styles: [".form-group{font-family:Inter;font-size:1rem;font-weight:700}.custom-input{font-family:Inter;color:#333;font-size:.9rem}label{font-family:Inter;font-size:16px;line-height:19.36px;text-align:left}\n"] }]
1421
+ }], ctorParameters: function () { return []; }, propDecorators: { id: [{
1422
+ type: Input
1423
+ }], label: [{
1424
+ type: Input
1425
+ }], type: [{
1426
+ type: Input
1427
+ }], placeholder: [{
1428
+ type: Input
1429
+ }], value: [{
1430
+ type: Input
1431
+ }], disabled: [{
1432
+ type: Input
1433
+ }], readonly: [{
1434
+ type: Input
1435
+ }], autofocus: [{
1436
+ type: Input
1437
+ }], maxlength: [{
1438
+ type: Input
1439
+ }], minlength: [{
1440
+ type: Input
1441
+ }], required: [{
1442
+ type: Input
1443
+ }], pattern: [{
1444
+ type: Input
1445
+ }], debounceTime: [{
1446
+ type: Input
1447
+ }], search: [{
1448
+ type: Output
1449
+ }], inputChange: [{
1450
+ type: Output
1451
+ }], change: [{
1452
+ type: Output
1453
+ }], focus: [{
1454
+ type: Output
1455
+ }], blur: [{
1456
+ type: Output
1457
+ }], keyup: [{
1458
+ type: Output
1459
+ }], keydown: [{
1460
+ type: Output
1461
+ }], keypress: [{
1462
+ type: Output
1463
+ }] } });
1464
+
1287
1465
  class SelectComponent {
1288
1466
  constructor() {
1289
1467
  this.label = 'Default Label';
@@ -1339,7 +1517,7 @@ class SelectComponent {
1339
1517
  <option *ngFor="let option of options" [value]="option.value">{{ option.label }}</option>
1340
1518
  </select>
1341
1519
  </div>
1342
- `, isInline: true, styles: [".form-group{margin-bottom:1rem}.form-label{font-family:Arial,sans-serif;color:#333;font-size:1rem;font-weight:700}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i2.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
1520
+ `, isInline: true, styles: [".form-group{margin-bottom:1rem}.form-label{font-family:Arial,sans-serif;color:#333;font-size:1rem;font-weight:700}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i3.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i3.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
1343
1521
  }
1344
1522
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SelectComponent, decorators: [{
1345
1523
  type: Component,
@@ -1387,10 +1565,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
1387
1565
  }] } });
1388
1566
 
1389
1567
  class DataTableComponent {
1390
- constructor(cdr) {
1568
+ constructor(cdr, authService) {
1391
1569
  this.cdr = cdr;
1570
+ this.authService = authService;
1392
1571
  this.columns = [];
1393
- this.data = [];
1572
+ this.hiddenColumns = [];
1394
1573
  this.itemsPerPageOptions = [5, 10, 15, 20];
1395
1574
  this.defaultItemsPerPage = 10;
1396
1575
  this.itemsPerPageLabel = 'Items per page:';
@@ -1404,15 +1583,15 @@ class DataTableComponent {
1404
1583
  this.tableFontColor = '#000';
1405
1584
  this.tableFontSize = '14px';
1406
1585
  this.fetchDataFunction = () => {
1407
- return Promise.reject('Implement the fetchDataFunction to fetch paginated data from the back-end.');
1408
- }; // Função de busca de dados
1586
+ return new Observable(subscriber => subscriber.error('Implement the fetchDataFunction to fetch paginated data from the back-end.'));
1587
+ };
1409
1588
  this.editPermissions = [];
1410
1589
  this.deletePermissions = [];
1411
1590
  this.viewPermissions = [];
1412
- this.userPermissions = [];
1413
- this.showPageInfo = true; // Controle de exibição da informação da página
1414
- this.pageText = 'Page'; // Texto para "Page"
1415
- this.ofText = 'of'; // Texto para "of"
1591
+ this.showPageInfo = true;
1592
+ this.pageText = 'Page';
1593
+ this.ofText = 'of';
1594
+ this.filterDescription = ''; // Novo input para filterDescription
1416
1595
  this.sortChange = new EventEmitter();
1417
1596
  this.pageChange = new EventEmitter();
1418
1597
  this.itemsPerPageChange = new EventEmitter();
@@ -1420,8 +1599,11 @@ class DataTableComponent {
1420
1599
  this.onDeleteTable = new EventEmitter();
1421
1600
  this.onViewTable = new EventEmitter();
1422
1601
  this.currentPage = 1;
1602
+ this.sortColumn = '';
1603
+ this.sortDirection = 'asc';
1423
1604
  this.pagedData = [];
1424
1605
  this.isLoading = false;
1606
+ this.destroy$ = new Subject();
1425
1607
  this.labelStyle = {
1426
1608
  'font-family': 'Inter, Arial, sans-serif',
1427
1609
  'font-size': '14px',
@@ -1430,75 +1612,104 @@ class DataTableComponent {
1430
1612
  }
1431
1613
  ngOnInit() {
1432
1614
  this.fetchData();
1433
- this.setDefaultPermissions();
1434
1615
  }
1435
1616
  ngOnChanges(changes) {
1436
- if (changes['totalItems'] || changes['defaultItemsPerPage'] || changes['currentPage'] || changes['data']) {
1617
+ if (changes['totalItems'] || changes['defaultItemsPerPage'] || changes['currentPage'] || changes['fetchDataFunction'] || changes['filterDescription']) {
1437
1618
  this.fetchData();
1438
1619
  }
1439
1620
  }
1440
- setDefaultPermissions() {
1441
- if (!this.userPermissions || this.userPermissions.length === 0) {
1442
- this.userPermissions = ['edit', 'delete', 'view'];
1443
- }
1621
+ ngOnDestroy() {
1622
+ this.destroy$.next();
1623
+ this.destroy$.complete();
1444
1624
  }
1445
- async fetchData() {
1625
+ fetchData() {
1446
1626
  if (this.fetchDataFunction) {
1447
1627
  this.isLoading = true;
1448
- try {
1449
- const data = await this.fetchDataFunction(this.currentPage, this.defaultItemsPerPage);
1450
- this.pagedData = data.items;
1451
- this.totalItems = data.totalItems;
1452
- }
1453
- finally {
1454
- this.isLoading = false;
1455
- this.cdr.markForCheck(); // Força a detecção de mudanças
1456
- }
1628
+ const params = {
1629
+ filterDescription: this.filterDescription,
1630
+ pageNumber: this.currentPage,
1631
+ pageSize: this.defaultItemsPerPage,
1632
+ sortColumn: this.sortColumn,
1633
+ sortDirection: this.sortDirection
1634
+ };
1635
+ this.fetchDataFunction(params).pipe(takeUntil(this.destroy$)).subscribe({
1636
+ next: (result) => {
1637
+ this.pagedData = result.items;
1638
+ this.totalItems = result.totalItems;
1639
+ this.isLoading = false;
1640
+ this.cdr.markForCheck();
1641
+ },
1642
+ error: (error) => {
1643
+ console.error('Error fetching data:', error);
1644
+ this.isLoading = false;
1645
+ }
1646
+ });
1457
1647
  }
1458
1648
  }
1459
1649
  onSort(column) {
1460
- this.sortChange.emit(column);
1650
+ this.sortColumn = column;
1651
+ this.sortDirection = this.sortDirection === 'asc' ? 'desc' : 'asc';
1652
+ this.sortChange.emit({ column, direction: this.sortDirection });
1653
+ this.fetchData();
1461
1654
  }
1462
1655
  onPageChange(page) {
1463
1656
  this.currentPage = page;
1464
1657
  this.pageChange.emit(page);
1465
1658
  this.fetchData();
1466
1659
  }
1467
- onItemsPerPageChange(event) {
1468
- const itemsPerPage = parseInt(event, 10);
1469
- this.defaultItemsPerPage = itemsPerPage;
1660
+ onItemsPerPageChange() {
1470
1661
  this.currentPage = 1;
1471
- this.itemsPerPageChange.emit(itemsPerPage);
1662
+ this.itemsPerPageChange.emit(this.defaultItemsPerPage);
1472
1663
  this.fetchData();
1473
1664
  }
1474
1665
  handleAction(action, item, index) {
1475
1666
  switch (action) {
1476
1667
  case 'edit':
1477
- this.onEditTable.emit({ item, index });
1668
+ if (this.hasPermission(this.editPermissions)) {
1669
+ this.onEditTable.emit({ item, index });
1670
+ }
1478
1671
  break;
1479
1672
  case 'delete':
1480
- this.onDeleteTable.emit({ item, index });
1673
+ if (this.hasPermission(this.deletePermissions)) {
1674
+ this.onDeleteTable.emit({ item, index });
1675
+ }
1481
1676
  break;
1482
1677
  case 'view':
1483
- this.onViewTable.emit({ item, index });
1678
+ if (this.hasPermission(this.viewPermissions)) {
1679
+ this.onViewTable.emit({ item, index });
1680
+ }
1484
1681
  break;
1485
1682
  }
1486
1683
  }
1487
1684
  hasPermission(requiredPermissions) {
1488
- if (!this.userPermissions || this.userPermissions.length === 0) {
1685
+ if (!requiredPermissions || requiredPermissions.length === 0) {
1686
+ return true;
1687
+ }
1688
+ try {
1689
+ return this.authService.hasPermission(requiredPermissions);
1690
+ }
1691
+ catch (error) {
1692
+ if (error instanceof Error) {
1693
+ console.error('Permission error:', error.message);
1694
+ }
1695
+ else {
1696
+ console.error('Unknown error occurred during permission check');
1697
+ }
1489
1698
  return true;
1490
1699
  }
1491
- return requiredPermissions.every(permission => this.userPermissions.includes(permission));
1492
1700
  }
1493
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DataTableComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
1494
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DataTableComponent, selector: "sim-data-table", inputs: { columns: "columns", data: "data", itemsPerPageOptions: "itemsPerPageOptions", defaultItemsPerPage: "defaultItemsPerPage", itemsPerPageLabel: "itemsPerPageLabel", marginTop: "marginTop", marginBottom: "marginBottom", marginLeft: "marginLeft", marginRight: "marginRight", showActionColumn: "showActionColumn", actionColumnLabel: "actionColumnLabel", totalItems: "totalItems", tableFontColor: "tableFontColor", tableFontSize: "tableFontSize", fetchDataFunction: "fetchDataFunction", editPermissions: "editPermissions", deletePermissions: "deletePermissions", viewPermissions: "viewPermissions", userPermissions: "userPermissions", showPageInfo: "showPageInfo", pageText: "pageText", ofText: "ofText" }, outputs: { sortChange: "sortChange", pageChange: "pageChange", itemsPerPageChange: "itemsPerPageChange", onEditTable: "onEditTable", onDeleteTable: "onDeleteTable", onViewTable: "onViewTable" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"form-group\" [ngStyle]=\"{\n 'margin-top': marginTop + 'rem',\n 'margin-bottom': marginBottom + 'rem',\n 'margin-left': marginLeft + 'rem',\n 'margin-right': marginRight + 'rem'\n}\" style=\"text-align: right;\">\n <label for=\"itemsPerPageSelect\" style=\"margin-right: 0.5rem; margin-bottom: 0.7rem;\" [ngStyle]=\"labelStyle\">{{ itemsPerPageLabel }}</label>\n <select\n id=\"itemsPerPageSelect\"\n class=\"form-control form-control-sm d-inline-block w-auto\"\n [(ngModel)]=\"defaultItemsPerPage\"\n (ngModelChange)=\"onItemsPerPageChange($event)\">\n <option *ngFor=\"let option of itemsPerPageOptions\" [value]=\"option\">{{ option }}</option>\n </select>\n</div>\n\n<div class=\"table-responsive\">\n <table class=\"table table-hover\" [ngStyle]=\"{ 'color': tableFontColor, 'font-size': tableFontSize }\">\n <thead>\n <tr>\n <ng-container *ngFor=\"let column of columns\">\n <th *ngIf=\"hasPermission(column.permissions || [])\" (click)=\"onSort(column.prop)\">\n {{ column.label }}\n </th>\n </ng-container>\n <th *ngIf=\"showActionColumn\">{{ actionColumnLabel }}</th>\n </tr>\n </thead>\n <tbody>\n <tr *ngFor=\"let item of pagedData; let i = index\">\n <ng-container *ngFor=\"let column of columns\">\n <td *ngIf=\"hasPermission(column.permissions || [])\">\n {{ item[column.prop] }}\n </td>\n </ng-container>\n <td *ngIf=\"showActionColumn\">\n <div class=\"d-flex justify-content-center\">\n <div *ngIf=\"hasPermission(editPermissions)\" (click)=\"handleAction('edit', item, i)\" class=\"btn-icon edit mx-1\"></div>\n <div *ngIf=\"hasPermission(deletePermissions)\" (click)=\"handleAction('delete', item, i)\" class=\"btn-icon delete mx-1\"></div>\n <div *ngIf=\"hasPermission(viewPermissions)\" (click)=\"handleAction('view', item, i)\" class=\"btn-icon view mx-1\"></div>\n </div>\n </td>\n </tr>\n </tbody>\n </table>\n</div>\n\n<div class=\"text-center pagination-controls\">\n <custom-pagination\n [totalItems]=\"totalItems\"\n [itemsPerPage]=\"defaultItemsPerPage\"\n [currentPage]=\"currentPage\"\n [showPageInfo]=\"showPageInfo\"\n [pageText]=\"pageText\"\n [ofText]=\"ofText\"\n (pageChange)=\"onPageChange($event)\">\n </custom-pagination>\n</div>\n", styles: ["@charset \"UTF-8\";@import\"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap\";:host{font-family:Inter,Arial,sans-serif}.label-style{font-family:Inter,Arial,sans-serif;font-size:14px;color:#000}.table{font-family:Inter,Arial,sans-serif;color:var(--table-font-color, #000);font-size:var(--table-font-size, 14px);border-collapse:separate;border-spacing:0;border-radius:8px;overflow:hidden;border:.13rem solid #00444C}.table thead th{background-color:#00444c;color:#fff;padding:10px;border-bottom:1rem solid rgba(0,68,76,.8);border-right:1rem solid rgba(0,68,76,.8);border-radius:0}.table thead th:last-child{border-right:none}.table tbody td{padding:10px;border-bottom:.1rem solid rgba(0,68,76,.8);border-right:.1rem solid rgba(0,68,76,.8)}.table tbody tr:last-child td{border-bottom:none}.table tbody td:last-child{border-right:none}.table thead th:first-child{border-top-left-radius:0}.table thead th:last-child{border-top-right-radius:0}.table tbody tr:last-child td:first-child{border-bottom-left-radius:8px}.table tbody tr:last-child td:last-child{border-bottom-right-radius:8px}.btn-icon{width:24px;height:24px;background-size:cover;display:inline-block;cursor:pointer;margin-right:16px}.btn-icon.edit{background-image:url()}.btn-icon.delete{background-image:url(\")}\n"], dependencies: [{ 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: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i2.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: CustomPaginationComponent, selector: "custom-pagination", inputs: ["totalItems", "itemsPerPage", "currentPage", "maxSize", "pageText", "ofText", "showPageInfo"], outputs: ["pageChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
1701
+ isColumnHidden(columnProp) {
1702
+ return this.hiddenColumns.includes(columnProp);
1703
+ }
1704
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DataTableComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: AuthService }], target: i0.ɵɵFactoryTarget.Component }); }
1705
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DataTableComponent, selector: "sim-data-table", inputs: { columns: "columns", hiddenColumns: "hiddenColumns", itemsPerPageOptions: "itemsPerPageOptions", defaultItemsPerPage: "defaultItemsPerPage", itemsPerPageLabel: "itemsPerPageLabel", marginTop: "marginTop", marginBottom: "marginBottom", marginLeft: "marginLeft", marginRight: "marginRight", showActionColumn: "showActionColumn", actionColumnLabel: "actionColumnLabel", totalItems: "totalItems", tableFontColor: "tableFontColor", tableFontSize: "tableFontSize", fetchDataFunction: "fetchDataFunction", editPermissions: "editPermissions", deletePermissions: "deletePermissions", viewPermissions: "viewPermissions", showPageInfo: "showPageInfo", pageText: "pageText", ofText: "ofText", filterDescription: "filterDescription" }, outputs: { sortChange: "sortChange", pageChange: "pageChange", itemsPerPageChange: "itemsPerPageChange", onEditTable: "onEditTable", onDeleteTable: "onDeleteTable", onViewTable: "onViewTable" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"form-group\" [ngStyle]=\"{\n 'margin-top': marginTop + 'rem',\n 'margin-bottom': marginBottom + 'rem',\n 'margin-left': marginLeft + 'rem',\n 'margin-right': marginRight + 'rem'\n}\" style=\"text-align: right;\">\n <label for=\"itemsPerPageSelect\" style=\"margin-right: 0.5rem; margin-bottom: 0.7rem;\" [ngStyle]=\"labelStyle\">{{ itemsPerPageLabel }}</label>\n <select\n id=\"itemsPerPageSelect\"\n class=\"form-control form-control-sm d-inline-block w-auto\"\n [(ngModel)]=\"defaultItemsPerPage\"\n (ngModelChange)=\"onItemsPerPageChange()\">\n <option *ngFor=\"let option of itemsPerPageOptions\" [value]=\"option\">{{ option }}</option>\n </select>\n</div>\n\n<div class=\"table-responsive\">\n <table class=\"table table-hover\" [ngStyle]=\"{ 'color': tableFontColor, 'font-size': tableFontSize }\">\n <thead>\n <tr>\n <ng-container *ngFor=\"let column of columns\">\n <th *ngIf=\"!isColumnHidden(column.prop)\" (click)=\"onSort(column.prop)\">\n {{ column.label }}\n </th>\n </ng-container>\n <th *ngIf=\"showActionColumn\">{{ actionColumnLabel }}</th>\n </tr>\n </thead>\n <tbody>\n <tr *ngFor=\"let item of pagedData; let i = index\">\n <ng-container *ngFor=\"let column of columns\">\n <td *ngIf=\"!isColumnHidden(column.prop)\">\n {{ item[column.prop] }}\n </td>\n </ng-container>\n <td *ngIf=\"showActionColumn\">\n <div class=\"d-flex justify-content-center\">\n <div *ngIf=\"hasPermission(editPermissions) && onEditTable.observers.length > 0\" (click)=\"handleAction('edit', item, i)\" class=\"btn-icon edit mx-1\"></div>\n <div *ngIf=\"hasPermission(deletePermissions) && onDeleteTable.observers.length > 0\" (click)=\"handleAction('delete', item, i)\" class=\"btn-icon delete mx-1\"></div>\n <div *ngIf=\"hasPermission(viewPermissions) && onViewTable.observers.length > 0\" (click)=\"handleAction('view', item, i)\" class=\"btn-icon view mx-1\"></div>\n </div>\n </td>\n </tr>\n </tbody>\n </table>\n</div>\n\n<div class=\"text-center pagination-controls\">\n <custom-pagination\n [totalItems]=\"totalItems\"\n [itemsPerPage]=\"defaultItemsPerPage\"\n [currentPage]=\"currentPage\"\n [showPageInfo]=\"showPageInfo\"\n [pageText]=\"pageText\"\n [ofText]=\"ofText\"\n (pageChange)=\"onPageChange($event)\">\n </custom-pagination>\n</div>\n", styles: ["@charset \"UTF-8\";@import\"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap\";:host{font-family:Inter,Arial,sans-serif}.label-style{font-family:Inter,Arial,sans-serif;font-size:14px;color:#000}.table{font-family:Inter,Arial,sans-serif;color:var(--table-font-color, #000);font-size:var(--table-font-size, 14px);border-collapse:separate;border-spacing:0;border-radius:8px;overflow:hidden;border:.13rem solid #00444C}.table thead th{background-color:#00444c;color:#fff;padding:10px;border-bottom:1rem solid rgba(0,68,76,.8);border-right:1rem solid rgba(0,68,76,.8);border-radius:0}.table thead th:last-child{border-right:none}.table tbody td{padding:10px;border-bottom:.1rem solid rgba(0,68,76,.8);border-right:.1rem solid rgba(0,68,76,.8)}.table tbody tr:last-child td{border-bottom:none}.table tbody td:last-child{border-right:none}.table thead th:first-child{border-top-left-radius:0}.table thead th:last-child{border-top-right-radius:0}.table tbody tr:last-child td:first-child{border-bottom-left-radius:8px}.table tbody tr:last-child td:last-child{border-bottom-right-radius:8px}.btn-icon{width:24px;height:24px;background-size:cover;display:inline-block;cursor:pointer;margin-right:16px}.btn-icon.edit{background-image:url()}.btn-icon.delete{background-image:url(\")}\n"], dependencies: [{ 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: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i3.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i3.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i3.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: CustomPaginationComponent, selector: "custom-pagination", inputs: ["totalItems", "itemsPerPage", "currentPage", "maxSize", "pageText", "ofText", "showPageInfo"], outputs: ["pageChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
1495
1706
  }
1496
1707
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DataTableComponent, decorators: [{
1497
1708
  type: Component,
1498
- args: [{ selector: 'sim-data-table', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"form-group\" [ngStyle]=\"{\n 'margin-top': marginTop + 'rem',\n 'margin-bottom': marginBottom + 'rem',\n 'margin-left': marginLeft + 'rem',\n 'margin-right': marginRight + 'rem'\n}\" style=\"text-align: right;\">\n <label for=\"itemsPerPageSelect\" style=\"margin-right: 0.5rem; margin-bottom: 0.7rem;\" [ngStyle]=\"labelStyle\">{{ itemsPerPageLabel }}</label>\n <select\n id=\"itemsPerPageSelect\"\n class=\"form-control form-control-sm d-inline-block w-auto\"\n [(ngModel)]=\"defaultItemsPerPage\"\n (ngModelChange)=\"onItemsPerPageChange($event)\">\n <option *ngFor=\"let option of itemsPerPageOptions\" [value]=\"option\">{{ option }}</option>\n </select>\n</div>\n\n<div class=\"table-responsive\">\n <table class=\"table table-hover\" [ngStyle]=\"{ 'color': tableFontColor, 'font-size': tableFontSize }\">\n <thead>\n <tr>\n <ng-container *ngFor=\"let column of columns\">\n <th *ngIf=\"hasPermission(column.permissions || [])\" (click)=\"onSort(column.prop)\">\n {{ column.label }}\n </th>\n </ng-container>\n <th *ngIf=\"showActionColumn\">{{ actionColumnLabel }}</th>\n </tr>\n </thead>\n <tbody>\n <tr *ngFor=\"let item of pagedData; let i = index\">\n <ng-container *ngFor=\"let column of columns\">\n <td *ngIf=\"hasPermission(column.permissions || [])\">\n {{ item[column.prop] }}\n </td>\n </ng-container>\n <td *ngIf=\"showActionColumn\">\n <div class=\"d-flex justify-content-center\">\n <div *ngIf=\"hasPermission(editPermissions)\" (click)=\"handleAction('edit', item, i)\" class=\"btn-icon edit mx-1\"></div>\n <div *ngIf=\"hasPermission(deletePermissions)\" (click)=\"handleAction('delete', item, i)\" class=\"btn-icon delete mx-1\"></div>\n <div *ngIf=\"hasPermission(viewPermissions)\" (click)=\"handleAction('view', item, i)\" class=\"btn-icon view mx-1\"></div>\n </div>\n </td>\n </tr>\n </tbody>\n </table>\n</div>\n\n<div class=\"text-center pagination-controls\">\n <custom-pagination\n [totalItems]=\"totalItems\"\n [itemsPerPage]=\"defaultItemsPerPage\"\n [currentPage]=\"currentPage\"\n [showPageInfo]=\"showPageInfo\"\n [pageText]=\"pageText\"\n [ofText]=\"ofText\"\n (pageChange)=\"onPageChange($event)\">\n </custom-pagination>\n</div>\n", styles: ["@charset \"UTF-8\";@import\"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap\";:host{font-family:Inter,Arial,sans-serif}.label-style{font-family:Inter,Arial,sans-serif;font-size:14px;color:#000}.table{font-family:Inter,Arial,sans-serif;color:var(--table-font-color, #000);font-size:var(--table-font-size, 14px);border-collapse:separate;border-spacing:0;border-radius:8px;overflow:hidden;border:.13rem solid #00444C}.table thead th{background-color:#00444c;color:#fff;padding:10px;border-bottom:1rem solid rgba(0,68,76,.8);border-right:1rem solid rgba(0,68,76,.8);border-radius:0}.table thead th:last-child{border-right:none}.table tbody td{padding:10px;border-bottom:.1rem solid rgba(0,68,76,.8);border-right:.1rem solid rgba(0,68,76,.8)}.table tbody tr:last-child td{border-bottom:none}.table tbody td:last-child{border-right:none}.table thead th:first-child{border-top-left-radius:0}.table thead th:last-child{border-top-right-radius:0}.table tbody tr:last-child td:first-child{border-bottom-left-radius:8px}.table tbody tr:last-child td:last-child{border-bottom-right-radius:8px}.btn-icon{width:24px;height:24px;background-size:cover;display:inline-block;cursor:pointer;margin-right:16px}.btn-icon.edit{background-image:url()}.btn-icon.delete{background-image:url(\")}\n"] }]
1499
- }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { columns: [{
1709
+ args: [{ selector: 'sim-data-table', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"form-group\" [ngStyle]=\"{\n 'margin-top': marginTop + 'rem',\n 'margin-bottom': marginBottom + 'rem',\n 'margin-left': marginLeft + 'rem',\n 'margin-right': marginRight + 'rem'\n}\" style=\"text-align: right;\">\n <label for=\"itemsPerPageSelect\" style=\"margin-right: 0.5rem; margin-bottom: 0.7rem;\" [ngStyle]=\"labelStyle\">{{ itemsPerPageLabel }}</label>\n <select\n id=\"itemsPerPageSelect\"\n class=\"form-control form-control-sm d-inline-block w-auto\"\n [(ngModel)]=\"defaultItemsPerPage\"\n (ngModelChange)=\"onItemsPerPageChange()\">\n <option *ngFor=\"let option of itemsPerPageOptions\" [value]=\"option\">{{ option }}</option>\n </select>\n</div>\n\n<div class=\"table-responsive\">\n <table class=\"table table-hover\" [ngStyle]=\"{ 'color': tableFontColor, 'font-size': tableFontSize }\">\n <thead>\n <tr>\n <ng-container *ngFor=\"let column of columns\">\n <th *ngIf=\"!isColumnHidden(column.prop)\" (click)=\"onSort(column.prop)\">\n {{ column.label }}\n </th>\n </ng-container>\n <th *ngIf=\"showActionColumn\">{{ actionColumnLabel }}</th>\n </tr>\n </thead>\n <tbody>\n <tr *ngFor=\"let item of pagedData; let i = index\">\n <ng-container *ngFor=\"let column of columns\">\n <td *ngIf=\"!isColumnHidden(column.prop)\">\n {{ item[column.prop] }}\n </td>\n </ng-container>\n <td *ngIf=\"showActionColumn\">\n <div class=\"d-flex justify-content-center\">\n <div *ngIf=\"hasPermission(editPermissions) && onEditTable.observers.length > 0\" (click)=\"handleAction('edit', item, i)\" class=\"btn-icon edit mx-1\"></div>\n <div *ngIf=\"hasPermission(deletePermissions) && onDeleteTable.observers.length > 0\" (click)=\"handleAction('delete', item, i)\" class=\"btn-icon delete mx-1\"></div>\n <div *ngIf=\"hasPermission(viewPermissions) && onViewTable.observers.length > 0\" (click)=\"handleAction('view', item, i)\" class=\"btn-icon view mx-1\"></div>\n </div>\n </td>\n </tr>\n </tbody>\n </table>\n</div>\n\n<div class=\"text-center pagination-controls\">\n <custom-pagination\n [totalItems]=\"totalItems\"\n [itemsPerPage]=\"defaultItemsPerPage\"\n [currentPage]=\"currentPage\"\n [showPageInfo]=\"showPageInfo\"\n [pageText]=\"pageText\"\n [ofText]=\"ofText\"\n (pageChange)=\"onPageChange($event)\">\n </custom-pagination>\n</div>\n", styles: ["@charset \"UTF-8\";@import\"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap\";:host{font-family:Inter,Arial,sans-serif}.label-style{font-family:Inter,Arial,sans-serif;font-size:14px;color:#000}.table{font-family:Inter,Arial,sans-serif;color:var(--table-font-color, #000);font-size:var(--table-font-size, 14px);border-collapse:separate;border-spacing:0;border-radius:8px;overflow:hidden;border:.13rem solid #00444C}.table thead th{background-color:#00444c;color:#fff;padding:10px;border-bottom:1rem solid rgba(0,68,76,.8);border-right:1rem solid rgba(0,68,76,.8);border-radius:0}.table thead th:last-child{border-right:none}.table tbody td{padding:10px;border-bottom:.1rem solid rgba(0,68,76,.8);border-right:.1rem solid rgba(0,68,76,.8)}.table tbody tr:last-child td{border-bottom:none}.table tbody td:last-child{border-right:none}.table thead th:first-child{border-top-left-radius:0}.table thead th:last-child{border-top-right-radius:0}.table tbody tr:last-child td:first-child{border-bottom-left-radius:8px}.table tbody tr:last-child td:last-child{border-bottom-right-radius:8px}.btn-icon{width:24px;height:24px;background-size:cover;display:inline-block;cursor:pointer;margin-right:16px}.btn-icon.edit{background-image:url()}.btn-icon.delete{background-image:url(\")}\n"] }]
1710
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: AuthService }]; }, propDecorators: { columns: [{
1500
1711
  type: Input
1501
- }], data: [{
1712
+ }], hiddenColumns: [{
1502
1713
  type: Input
1503
1714
  }], itemsPerPageOptions: [{
1504
1715
  type: Input
@@ -1532,14 +1743,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
1532
1743
  type: Input
1533
1744
  }], viewPermissions: [{
1534
1745
  type: Input
1535
- }], userPermissions: [{
1536
- type: Input
1537
1746
  }], showPageInfo: [{
1538
1747
  type: Input
1539
1748
  }], pageText: [{
1540
1749
  type: Input
1541
1750
  }], ofText: [{
1542
1751
  type: Input
1752
+ }], filterDescription: [{
1753
+ type: Input
1543
1754
  }], sortChange: [{
1544
1755
  type: Output
1545
1756
  }], pageChange: [{
@@ -1812,7 +2023,8 @@ class ComponentsModule {
1812
2023
  ConfirmationComponent,
1813
2024
  AutofocusDirective,
1814
2025
  CustomPaginationComponent,
1815
- TreeNodeComponent], imports: [CommonModule,
2026
+ TreeNodeComponent,
2027
+ SearchInputComponent], imports: [CommonModule,
1816
2028
  FormsModule,
1817
2029
  ReactiveFormsModule,
1818
2030
  NgSelectModule], exports: [ButtonComponent,
@@ -1833,7 +2045,8 @@ class ComponentsModule {
1833
2045
  AlertComponent,
1834
2046
  ConfirmationComponent,
1835
2047
  CustomPaginationComponent,
1836
- TreeNodeComponent] }); }
2048
+ TreeNodeComponent,
2049
+ SearchInputComponent] }); }
1837
2050
  static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ComponentsModule, imports: [CommonModule,
1838
2051
  FormsModule,
1839
2052
  ReactiveFormsModule,
@@ -1862,6 +2075,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
1862
2075
  AutofocusDirective,
1863
2076
  CustomPaginationComponent,
1864
2077
  TreeNodeComponent,
2078
+ SearchInputComponent,
1865
2079
  ],
1866
2080
  imports: [
1867
2081
  CommonModule,
@@ -1889,6 +2103,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
1889
2103
  ConfirmationComponent,
1890
2104
  CustomPaginationComponent,
1891
2105
  TreeNodeComponent,
2106
+ SearchInputComponent,
1892
2107
  ],
1893
2108
  }]
1894
2109
  }] });
@@ -1923,19 +2138,28 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
1923
2138
  class ConfirmationService {
1924
2139
  constructor(modalService) {
1925
2140
  this.modalService = modalService;
2141
+ this.modalRef = null;
1926
2142
  }
1927
2143
  confirm(title, message, confirmButtonText = 'Sim', cancelButtonText = 'Não') {
1928
- const modalRef = this.modalService.open(ConfirmationComponent, { backdrop: 'static', keyboard: false });
1929
- modalRef.componentInstance.title = title;
1930
- modalRef.componentInstance.message = message;
1931
- modalRef.componentInstance.confirmButtonText = confirmButtonText;
1932
- modalRef.componentInstance.cancelButtonText = cancelButtonText;
1933
- return modalRef.result.then((result) => {
2144
+ this.modalRef = this.modalService.open(ConfirmationComponent, { backdrop: 'static', keyboard: false });
2145
+ this.modalRef.componentInstance.title = title;
2146
+ this.modalRef.componentInstance.message = message;
2147
+ this.modalRef.componentInstance.confirmButtonText = confirmButtonText;
2148
+ this.modalRef.componentInstance.cancelButtonText = cancelButtonText;
2149
+ return this.modalRef.result.then((result) => {
1934
2150
  return result === 'confirm';
1935
2151
  }, () => {
1936
2152
  return false;
2153
+ }).finally(() => {
2154
+ this.modalRef = null; // Clear the reference after the modal is closed
1937
2155
  });
1938
2156
  }
2157
+ ngOnDestroy() {
2158
+ if (this.modalRef) {
2159
+ this.modalRef.dismiss();
2160
+ this.modalRef = null;
2161
+ }
2162
+ }
1939
2163
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ConfirmationService, deps: [{ token: i1$1.NgbModal }], target: i0.ɵɵFactoryTarget.Injectable }); }
1940
2164
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ConfirmationService, providedIn: 'root' }); }
1941
2165
  }
@@ -1946,12 +2170,45 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
1946
2170
  }]
1947
2171
  }], ctorParameters: function () { return [{ type: i1$1.NgbModal }]; } });
1948
2172
 
2173
+ class DataPaginateService {
2174
+ constructor(http) {
2175
+ this.http = http;
2176
+ }
2177
+ fetchData(url, params) {
2178
+ let httpParams = new HttpParams()
2179
+ .set('page', params.pageNumber.toString())
2180
+ .set('limit', params.pageSize.toString())
2181
+ .set('sort', params.sortColumn)
2182
+ .set('order', params.sortDirection);
2183
+ if (params.filterDescription) {
2184
+ httpParams = httpParams.set('description', params.filterDescription);
2185
+ }
2186
+ return this.http.get(url, { params: httpParams }).pipe(map(response => {
2187
+ const items = response.data || [];
2188
+ const totalItems = response.meta.total || 0;
2189
+ return {
2190
+ items,
2191
+ totalItems
2192
+ };
2193
+ }));
2194
+ }
2195
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DataPaginateService, deps: [{ token: i1$2.HttpClient }], target: i0.ɵɵFactoryTarget.Injectable }); }
2196
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DataPaginateService, providedIn: 'root' }); }
2197
+ }
2198
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DataPaginateService, decorators: [{
2199
+ type: Injectable,
2200
+ args: [{
2201
+ providedIn: 'root'
2202
+ }]
2203
+ }], ctorParameters: function () { return [{ type: i1$2.HttpClient }]; } });
2204
+
1949
2205
  class LibPortalAngularModule {
1950
2206
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: LibPortalAngularModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
1951
2207
  static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: LibPortalAngularModule, imports: [ComponentsModule], exports: [ComponentsModule] }); }
1952
2208
  static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: LibPortalAngularModule, providers: [
1953
2209
  NotificationService,
1954
- ConfirmationService
2210
+ ConfirmationService,
2211
+ DataPaginateService,
1955
2212
  ], imports: [ComponentsModule, ComponentsModule] }); }
1956
2213
  }
1957
2214
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: LibPortalAngularModule, decorators: [{
@@ -1965,7 +2222,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
1965
2222
  ],
1966
2223
  providers: [
1967
2224
  NotificationService,
1968
- ConfirmationService
2225
+ ConfirmationService,
2226
+ DataPaginateService,
1969
2227
  ],
1970
2228
  }]
1971
2229
  }] });
@@ -1982,5 +2240,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
1982
2240
  * Generated bundle index. Do not edit.
1983
2241
  */
1984
2242
 
1985
- export { AlertComponent, BadgeComponent, ButtonClasses, ButtonComponent, CardComponent, CheckboxComponent, CodeHighlightComponent, ComponentsModule, ConfirmationComponent, ConfirmationService, CustomPaginationComponent, DataTableComponent, FormComponent, InputComponent, LibPortalAngularModule, MultiSelectComponent, NotificationService, RadioComponent, SelectComponent, TextareaComponent, TreeNodeComponent };
2243
+ export { AlertComponent, BadgeComponent, ButtonClasses, ButtonComponent, CardComponent, CheckboxComponent, CodeHighlightComponent, ComponentsModule, ConfirmationComponent, ConfirmationService, CustomPaginationComponent, DataPaginateService, DataTableComponent, FormComponent, InputComponent, LibPortalAngularModule, MultiSelectComponent, NotificationService, RadioComponent, SearchInputComponent, SelectComponent, TextareaComponent, TreeNodeComponent };
1986
2244
  //# sourceMappingURL=lib-portal-angular.mjs.map