lib-portal-angular 0.0.101 → 0.0.102
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.
@@ -5,7 +5,7 @@ import { ButtonClasses } from "../../enum/ButtonClassesEnum"; // Importando o en
|
|
5
5
|
import * as i0 from "@angular/core";
|
6
6
|
import * as i1 from "../../service/auth-service.service";
|
7
7
|
import * as i2 from "../../service/refresh-service.service";
|
8
|
-
import * as i3 from "
|
8
|
+
import * as i3 from "../confirmation/confirmation.service";
|
9
9
|
import * as i4 from "@angular/common";
|
10
10
|
import * as i5 from "@angular/forms";
|
11
11
|
import * as i6 from "lucide-angular";
|
@@ -328,4 +328,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
328
328
|
}], filterFieldChange: [{
|
329
329
|
type: Output
|
330
330
|
}] } });
|
331
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table.component.js","sourceRoot":"","sources":["../../../../../../projects/lib-portal-angular/src/lib/components/tables/data-table.component.ts","../../../../../../projects/lib-portal-angular/src/lib/components/tables/data-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  TemplateRef,\n} from \"@angular/core\"\nimport { ConfirmationService } from \"projects/lib-portal-angular/src/public-api\"\nimport { Observable, Subject } from \"rxjs\"\nimport { takeUntil } from \"rxjs/operators\"\nimport { ButtonClasses } from \"../../enum/ButtonClassesEnum\"; // Importando o enum\nimport { AuthService } from \"../../service/auth-service.service\"\nimport { RefreshService } from \"../../service/refresh-service.service\"\nimport { IDataIndexPaginate, IPaginateResult } from \"./data-paginate.service\"\n\n@Component({\n  selector: \"argenta-list-data-table\",\n  templateUrl: \"./data-table.component.html\",\n  styleUrls: [\"./data-table.component.scss\"],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DataTableComponent implements OnInit, OnDestroy {\n  @Input() columns: {\n    label: string;\n    prop: string;\n    type?: \"string\" | \"image\";\n    isSearchSelected?: boolean;\n  }[] = [];\n  @Input() hiddenColumns: string[] = [];\n  @Input() defaultItemsPerPage: number = 10;\n  @Input() itemsPerPageLabel: string = \"Items per page:\";\n  @Input() showActionColumn: boolean = false;\n  @Input() actionColumnLabel: string = \"Actions\";\n  @Input() totalItems: number = 0;\n\n  @Input() fetchDataFunction: (\n    params: IDataIndexPaginate\n  ) => Observable<IPaginateResult<any>> = () => {\n    return new Observable((subscriber) =>\n      subscriber.error(\n        \"Implement the fetchDataFunction to fetch paginated data from the back-end.\"\n      )\n    );\n  };\n\n  @Input() editPermissions: string[] = [];\n  @Input() deletePermissions: string[] = [];\n  @Input() inativoPermissions: string[] = [];\n  @Input() viewPermissions: string[] = [];\n  @Input() inativoTexts: {\n    inactivate: string;\n    activate: string;\n    modalTitle: string;\n    modalText: string;\n  } = {\n    inactivate: \"Desativar\",\n    activate: \"Ativar\",\n    modalTitle: \"Alterar status\",\n    modalText: \"Você deseja realmente alterar o status?\",\n  };\n  @Input() showPageInfo: boolean = true;\n  @Input() pageText: string = \"Page\";\n  @Input() ofText: string = \"of\";\n  @Input() filterDescription: string = \"\";\n  @Input() buttonLabel: string = \"\";\n  @Input() pagedData: any[] = [];\n  @Input() initialFilterField: string | null = null;\n  @Input() buttonList?: TemplateRef<any>[] = [];\n  @Input() status: boolean = false;\n\n  @Output() statusChange: EventEmitter<any> = new EventEmitter();\n  @Output() sortChange: EventEmitter<any> = new EventEmitter();\n  @Output() pageChange: EventEmitter<number> = new EventEmitter();\n  @Output() itemsPerPageChange: EventEmitter<number> = new EventEmitter();\n  @Output() onEditTable: EventEmitter<any> = new EventEmitter();\n  @Output() onDeleteTable: EventEmitter<any> = new EventEmitter();\n  @Output() onInativoTable: EventEmitter<any> = new EventEmitter();\n  @Output() onViewTable: EventEmitter<any> = new EventEmitter();\n  @Output() onButtonClick: EventEmitter<void> = new EventEmitter();\n  @Output() filterFieldChange: EventEmitter<string> = new EventEmitter();\n\n  itemsPerPageOptions: number[] = [5, 10, 15, 25];\n  currentPage: number = 1;\n  sortColumn: string = \"\";\n  sortDirection: \"asc\" | \"desc\" = \"asc\";\n  selectedSearchField: string = \"\";\n  isLoading = false;\n  private destroy$ = new Subject<void>();\n  private isInitialized = false; // Flag para evitar chamadas duplas\n  ButtonClasses = ButtonClasses;\n\n  labelStyle = {\n    \"font-family\": \"Inter, Arial, sans-serif\",\n    \"font-size\": \"14px\",\n    color: \"#000\",\n  };\n\n  constructor(\n    private cdr: ChangeDetectorRef,\n    private authService: AuthService,\n    private refreshService: RefreshService,\n    private confirmationService: ConfirmationService\n  ) {}\n\n  ngOnInit() {\n    if (this.initialFilterField) {\n      // Se o usuário definir o initialFilterField, ele será usado como o campo inicial\n      this.selectedSearchField = this.initialFilterField;\n      this.sortColumn = this.initialFilterField;\n      this.sortDirection = \"asc\";\n\n      this.columns = this.columns.map((column) => ({\n        ...column,\n        isSearchSelected: column.prop === this.initialFilterField,\n      }));\n    } else if (this.columns.length > 0) {\n      // Caso contrário, usa a primeira coluna como padrão\n      this.selectedSearchField = this.columns[0].prop;\n      this.sortColumn = this.columns[0].prop;\n      this.sortDirection = \"asc\";\n\n      this.columns = this.columns.map((column) => ({\n        ...column,\n        isSearchSelected: column.prop === this.selectedSearchField,\n      }));\n    }\n\n    //this.fetchData();\n    this.refreshService.refresh$\n      .pipe(takeUntil(this.destroy$))\n      .subscribe(() => {\n        if (this.isInitialized) {\n          this.refreshData();\n        }\n      });\n\n    this.isInitialized = true;\n  }\n\n  // ngOnChanges(changes: SimpleChanges) {\n  //   if (\n  //     changes[\"totalItems\"] ||\n  //     changes[\"defaultItemsPerPage\"] ||\n  //     changes[\"currentPage\"] ||\n  //     changes[\"fetchDataFunction\"] ||\n  //     changes[\"filterDescription\"]\n  //   ) {\n  //     this.fetchData();\n  //   }\n  // }\n\n  ngOnDestroy() {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  protected getNestedProperty(obj: any, path: string): any {\n    return path.split(\".\").reduce((acc, part) => acc && acc[part], obj);\n  }\n\n  fetchData() {\n    if (this.fetchDataFunction) {\n      this.isLoading = true;\n      const params: IDataIndexPaginate = {\n        filterDescription: this.filterDescription,\n        filterField: this.selectedSearchField,\n        pageNumber: this.currentPage ?? 1,\n        pageSize: this.defaultItemsPerPage ?? 10,\n        sortColumn: this.sortColumn,\n        sortDirection: this.sortDirection,\n      };\n\n      this.fetchDataFunction(params)\n        .pipe(takeUntil(this.destroy$))\n        .subscribe({\n          next: (result) => {\n            this.pagedData = result.items;\n            this.totalItems = result.totalItems;\n            this.isLoading = false;\n            this.cdr.markForCheck();\n          },\n          error: (error) => {\n            console.error(\"Error fetching data:\", error);\n            this.isLoading = false;\n          },\n        });\n    }\n  }\n\n  refreshData() {\n    this.fetchData();\n  }\n\n  onPageChange(page: number) {\n    this.currentPage = page;\n    this.pageChange.emit(page);\n    this.fetchData();\n  }\n\n  onItemsPerPageChange() {\n    this.currentPage = 1;\n    this.itemsPerPageChange.emit(this.defaultItemsPerPage);\n    this.fetchData();\n  }\n\n  onSelectSearchField(columnProp: string) {\n    if (this.sortColumn === columnProp) {\n      this.sortDirection = this.sortDirection === \"asc\" ? \"desc\" : \"asc\";\n    } else {\n      this.sortDirection = \"asc\";\n    }\n\n    this.selectedSearchField = columnProp;\n    this.sortColumn = columnProp;\n\n    this.columns = this.columns.map((column) => ({\n      ...column,\n      isSearchSelected: column.prop === columnProp,\n    }));\n\n    this.filterFieldChange.emit(this.selectedSearchField);\n\n    if (this.fetchDataFunction) {\n      this.fetchDataFunction({\n        filterDescription: this.filterDescription,\n        filterField: this.selectedSearchField,\n        pageNumber: this.currentPage,\n        pageSize: this.defaultItemsPerPage,\n        sortColumn: this.sortColumn,\n        sortDirection: this.sortDirection,\n      }).subscribe({\n        next: (result) => {\n          this.pagedData = result.items;\n          this.totalItems = result.totalItems;\n          this.cdr.markForCheck();\n        },\n        error: (error) => {\n          console.error(\"Erro ao buscar dados:\", error);\n        },\n      });\n    }\n  }\n\n  handleAction(action: string, item: any, index: number) {\n    switch (action) {\n      case \"edit\":\n        if (this.hasPermission(this.editPermissions)) {\n          this.onEditTable.emit({ item, index });\n        }\n        break;\n      case \"delete\":\n        if (this.hasPermission(this.deletePermissions)) {\n          this.onDeleteTable.emit({ item, index });\n        }\n        break;\n      case \"view\":\n        if (this.hasPermission(this.viewPermissions)) {\n          this.onViewTable.emit({ item, index });\n        }\n        break;\n      case \"inativar\":\n        if (this.hasPermission(this.inativoPermissions)) {\n          this.confirmationService\n            .confirm(this.inativoTexts.modalTitle, this.inativoTexts.modalText)\n            .then((confirmed: boolean) => {\n              if (confirmed) {\n                item.status = !item.status;\n                console.log({ status: item.status, item: item })\n                this.statusChange.emit({ status: item.status, item: item });\n              } else {\n                return;\n              }\n            });\n        }\n        break;\n    }\n  }\n\n  hasPermission(requiredPermissions: string[]): boolean {\n    if (!requiredPermissions || requiredPermissions.length === 0) {\n      return true;\n    }\n\n    try {\n      return this.authService.hasPermission(requiredPermissions);\n    } catch (error: unknown) {\n      if (error instanceof Error) {\n        console.error(\"Permission error:\", error.message);\n      } else {\n        console.error(\"Unknown error occurred during permission check\");\n      }\n      return true;\n    }\n  }\n\n  isColumnHidden(columnProp: string): boolean {\n    return this.hiddenColumns.includes(columnProp);\n  }\n\n  onSearch(searchText: string) {\n    this.filterDescription = searchText;\n    this.currentPage = 1; // Resetar para a primeira página\n    this.fetchData();\n  }\n\n  onNewButtonClick() {\n    this.onButtonClick.emit(); // Emitindo o evento\n  }\n}\n","<div class=\"data-table-header\" style=\"margin-top: 2.5rem\">\n  <div class=\"left-section\">\n    <div class=\"form-group\">\n      <label for=\"itemsPerPageSelect\" class=\"items-per-page-label\">{{\n        itemsPerPageLabel\n      }}</label>\n      <select\n        id=\"itemsPerPageSelect\"\n        class=\"form-control form-control-sm d-inline-block w-auto custom-select\"\n        [(ngModel)]=\"defaultItemsPerPage\"\n        (ngModelChange)=\"onItemsPerPageChange()\"\n      >\n        <option *ngFor=\"let option of itemsPerPageOptions\" [value]=\"option\">\n          {{ option }}\n        </option>\n      </select>\n    </div>\n  </div>\n  <div class=\"right-section\">\n    <div *ngIf=\"buttonList && buttonList.length > 0\" class=\"ng-button-row\">\n      <ng-container *ngFor=\"let buttonTemplate of buttonList\">\n        <ng-container\n          *ngTemplateOutlet=\"buttonTemplate\"\n          class=\"ng-button\"\n        ></ng-container>\n      </ng-container>\n    </div>\n    <button\n      *ngIf=\"buttonLabel && buttonLabel.length > 0\"\n      class=\"custom-button\"\n      (click)=\"onNewButtonClick()\"\n    >\n      <lucide-icon name=\"plus\" [size]=\"28\" [strokeWidth]=\"1.75\"></lucide-icon>\n      {{ buttonLabel }}\n    </button>\n  </div>\n</div>\n\n<div class=\"search-input-container\">\n  <argenta-search-input\n    id=\"search\"\n    label=\"\"\n    placeholder=\"Buscar\"\n    [(ngModel)]=\"filterDescription\"\n    (search)=\"onSearch($event)\"\n  ></argenta-search-input>\n</div>\n\n<div class=\"table-responsive\" style=\"margin-top: 1rem\">\n  <table class=\"table table-hover\">\n    <thead>\n      <tr>\n        <ng-container *ngFor=\"let column of columns\">\n          <th\n            *ngIf=\"!isColumnHidden(column.prop)\"\n            (click)=\"onSelectSearchField(column.prop)\"\n          >\n            {{ column.label }}\n            <span>\n              <i-lucide\n                name=\"arrow-up\"\n                [size]=\"14\"\n                [class.selected]=\"\n                  column.isSearchSelected && sortDirection === 'asc'\n                \"\n              ></i-lucide>\n              <i-lucide\n                name=\"arrow-down\"\n                [size]=\"14\"\n                [class.selected]=\"\n                  column.isSearchSelected && sortDirection === 'desc'\n                \"\n              ></i-lucide>\n            </span>\n          </th>\n        </ng-container>\n        <th\n          *ngIf=\"showActionColumn\"\n          class=\"text-end\"\n          style=\"padding-right: 6.3rem\"\n        >\n          {{ actionColumnLabel }}\n        </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)\" [ngSwitch]=\"column.type\">\n            <!-- Default case (when type is undefined or not matched) -->\n            <span *ngSwitchDefault>\n              {{ getNestedProperty(item, column.prop) }}\n            </span>\n\n            <!-- String case -->\n            <span *ngSwitchCase=\"'string'\">\n              {{ getNestedProperty(item, column.prop) }}\n            </span>\n\n            <!-- Image case -->\n            <img\n              *ngSwitchCase=\"'image'\"\n              [src]=\"getNestedProperty(item, column.prop)\"\n              alt=\"Image\"\n              width=\"50\"\n              height=\"50\"\n            />\n          </td>\n        </ng-container>\n        <td *ngIf=\"showActionColumn\" class=\"text-end\">\n          <div class=\"d-flex justify-content-end\">\n            <div\n              *ngIf=\"\n                hasPermission(editPermissions) &&\n                onEditTable.observers.length > 0\n              \"\n              (click)=\"handleAction('edit', item, i)\"\n              class=\"clickable-icon\"\n              style=\"margin-right: 1.5rem\"\n            >\n              <lucide-icon\n                name=\"square-pen\"\n                [size]=\"20\"\n                color=\"#2CA58D\"\n                [strokeWidth]=\"1.75\"\n              ></lucide-icon>\n            </div>\n            <div\n              *ngIf=\"\n                hasPermission(inativoPermissions) &&\n                onInativoTable.observers.length > 0\n              \"\n              (click)=\"handleAction('inativar', item, i)\"\n              class=\"clickable-icon\"\n              style=\"margin-right: 1.5rem\"\n            >\n              <button\n                [ngClass]=\"\n                  item.status\n                    ? 'btn btn-danger small-rounded-btn'\n                    : 'btn btn-success small-rounded-btn'\n                \"\n              >\n                {{\n                  item.status ? inativoTexts.inactivate : inativoTexts.activate\n                }}\n              </button>\n            </div>\n            <div\n              *ngIf=\"\n                hasPermission(viewPermissions) &&\n                onViewTable.observers.length > 0\n              \"\n              (click)=\"handleAction('view', item, i)\"\n              class=\"clickable-icon\"\n              style=\"margin-right: 1.5rem\"\n            >\n              <lucide-icon\n                name=\"user-round\"\n                [size]=\"20\"\n                color=\"#2CA58D\"\n                [strokeWidth]=\"1.75\"\n              ></lucide-icon>\n            </div>\n            <div\n              *ngIf=\"\n                hasPermission(deletePermissions) &&\n                onDeleteTable.observers.length > 0\n              \"\n              (click)=\"handleAction('delete', item, i)\"\n              class=\"clickable-icon\"\n              style=\"margin-right: 1.5rem\"\n            >\n              <i-lucide\n                name=\"trash-2\"\n                [size]=\"20\"\n                color=\"#F26E6E\"\n                [strokeWidth]=\"1.75\"\n              ></i-lucide>\n            </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    (pageChange)=\"onPageChange($event)\"\n  >\n  </custom-pagination>\n</div>\n"]}
|
331
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table.component.js","sourceRoot":"","sources":["../../../../../../projects/lib-portal-angular/src/lib/components/tables/data-table.component.ts","../../../../../../projects/lib-portal-angular/src/lib/components/tables/data-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  TemplateRef,\n} from \"@angular/core\"\nimport { Observable, Subject } from \"rxjs\"\nimport { takeUntil } from \"rxjs/operators\"\nimport { ButtonClasses } from \"../../enum/ButtonClassesEnum\"; // Importando o enum\nimport { AuthService } from \"../../service/auth-service.service\"\nimport { RefreshService } from \"../../service/refresh-service.service\"\nimport { ConfirmationService } from \"../confirmation/confirmation.service\"\nimport { IDataIndexPaginate, IPaginateResult } from \"./data-paginate.service\"\n\n@Component({\n  selector: \"argenta-list-data-table\",\n  templateUrl: \"./data-table.component.html\",\n  styleUrls: [\"./data-table.component.scss\"],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DataTableComponent implements OnInit, OnDestroy {\n  @Input() columns: {\n    label: string;\n    prop: string;\n    type?: \"string\" | \"image\";\n    isSearchSelected?: boolean;\n  }[] = [];\n  @Input() hiddenColumns: string[] = [];\n  @Input() defaultItemsPerPage: number = 10;\n  @Input() itemsPerPageLabel: string = \"Items per page:\";\n  @Input() showActionColumn: boolean = false;\n  @Input() actionColumnLabel: string = \"Actions\";\n  @Input() totalItems: number = 0;\n\n  @Input() fetchDataFunction: (\n    params: IDataIndexPaginate\n  ) => Observable<IPaginateResult<any>> = () => {\n    return new Observable((subscriber) =>\n      subscriber.error(\n        \"Implement the fetchDataFunction to fetch paginated data from the back-end.\"\n      )\n    );\n  };\n\n  @Input() editPermissions: string[] = [];\n  @Input() deletePermissions: string[] = [];\n  @Input() inativoPermissions: string[] = [];\n  @Input() viewPermissions: string[] = [];\n  @Input() inativoTexts: {\n    inactivate: string;\n    activate: string;\n    modalTitle: string;\n    modalText: string;\n  } = {\n    inactivate: \"Desativar\",\n    activate: \"Ativar\",\n    modalTitle: \"Alterar status\",\n    modalText: \"Você deseja realmente alterar o status?\",\n  };\n  @Input() showPageInfo: boolean = true;\n  @Input() pageText: string = \"Page\";\n  @Input() ofText: string = \"of\";\n  @Input() filterDescription: string = \"\";\n  @Input() buttonLabel: string = \"\";\n  @Input() pagedData: any[] = [];\n  @Input() initialFilterField: string | null = null;\n  @Input() buttonList?: TemplateRef<any>[] = [];\n  @Input() status: boolean = false;\n\n  @Output() statusChange: EventEmitter<any> = new EventEmitter();\n  @Output() sortChange: EventEmitter<any> = new EventEmitter();\n  @Output() pageChange: EventEmitter<number> = new EventEmitter();\n  @Output() itemsPerPageChange: EventEmitter<number> = new EventEmitter();\n  @Output() onEditTable: EventEmitter<any> = new EventEmitter();\n  @Output() onDeleteTable: EventEmitter<any> = new EventEmitter();\n  @Output() onInativoTable: EventEmitter<any> = new EventEmitter();\n  @Output() onViewTable: EventEmitter<any> = new EventEmitter();\n  @Output() onButtonClick: EventEmitter<void> = new EventEmitter();\n  @Output() filterFieldChange: EventEmitter<string> = new EventEmitter();\n\n  itemsPerPageOptions: number[] = [5, 10, 15, 25];\n  currentPage: number = 1;\n  sortColumn: string = \"\";\n  sortDirection: \"asc\" | \"desc\" = \"asc\";\n  selectedSearchField: string = \"\";\n  isLoading = false;\n  private destroy$ = new Subject<void>();\n  private isInitialized = false; // Flag para evitar chamadas duplas\n  ButtonClasses = ButtonClasses;\n\n  labelStyle = {\n    \"font-family\": \"Inter, Arial, sans-serif\",\n    \"font-size\": \"14px\",\n    color: \"#000\",\n  };\n\n  constructor(\n    private cdr: ChangeDetectorRef,\n    private authService: AuthService,\n    private refreshService: RefreshService,\n    private confirmationService: ConfirmationService\n  ) {}\n\n  ngOnInit() {\n    if (this.initialFilterField) {\n      // Se o usuário definir o initialFilterField, ele será usado como o campo inicial\n      this.selectedSearchField = this.initialFilterField;\n      this.sortColumn = this.initialFilterField;\n      this.sortDirection = \"asc\";\n\n      this.columns = this.columns.map((column) => ({\n        ...column,\n        isSearchSelected: column.prop === this.initialFilterField,\n      }));\n    } else if (this.columns.length > 0) {\n      // Caso contrário, usa a primeira coluna como padrão\n      this.selectedSearchField = this.columns[0].prop;\n      this.sortColumn = this.columns[0].prop;\n      this.sortDirection = \"asc\";\n\n      this.columns = this.columns.map((column) => ({\n        ...column,\n        isSearchSelected: column.prop === this.selectedSearchField,\n      }));\n    }\n\n    //this.fetchData();\n    this.refreshService.refresh$\n      .pipe(takeUntil(this.destroy$))\n      .subscribe(() => {\n        if (this.isInitialized) {\n          this.refreshData();\n        }\n      });\n\n    this.isInitialized = true;\n  }\n\n  // ngOnChanges(changes: SimpleChanges) {\n  //   if (\n  //     changes[\"totalItems\"] ||\n  //     changes[\"defaultItemsPerPage\"] ||\n  //     changes[\"currentPage\"] ||\n  //     changes[\"fetchDataFunction\"] ||\n  //     changes[\"filterDescription\"]\n  //   ) {\n  //     this.fetchData();\n  //   }\n  // }\n\n  ngOnDestroy() {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  protected getNestedProperty(obj: any, path: string): any {\n    return path.split(\".\").reduce((acc, part) => acc && acc[part], obj);\n  }\n\n  fetchData() {\n    if (this.fetchDataFunction) {\n      this.isLoading = true;\n      const params: IDataIndexPaginate = {\n        filterDescription: this.filterDescription,\n        filterField: this.selectedSearchField,\n        pageNumber: this.currentPage ?? 1,\n        pageSize: this.defaultItemsPerPage ?? 10,\n        sortColumn: this.sortColumn,\n        sortDirection: this.sortDirection,\n      };\n\n      this.fetchDataFunction(params)\n        .pipe(takeUntil(this.destroy$))\n        .subscribe({\n          next: (result) => {\n            this.pagedData = result.items;\n            this.totalItems = result.totalItems;\n            this.isLoading = false;\n            this.cdr.markForCheck();\n          },\n          error: (error) => {\n            console.error(\"Error fetching data:\", error);\n            this.isLoading = false;\n          },\n        });\n    }\n  }\n\n  refreshData() {\n    this.fetchData();\n  }\n\n  onPageChange(page: number) {\n    this.currentPage = page;\n    this.pageChange.emit(page);\n    this.fetchData();\n  }\n\n  onItemsPerPageChange() {\n    this.currentPage = 1;\n    this.itemsPerPageChange.emit(this.defaultItemsPerPage);\n    this.fetchData();\n  }\n\n  onSelectSearchField(columnProp: string) {\n    if (this.sortColumn === columnProp) {\n      this.sortDirection = this.sortDirection === \"asc\" ? \"desc\" : \"asc\";\n    } else {\n      this.sortDirection = \"asc\";\n    }\n\n    this.selectedSearchField = columnProp;\n    this.sortColumn = columnProp;\n\n    this.columns = this.columns.map((column) => ({\n      ...column,\n      isSearchSelected: column.prop === columnProp,\n    }));\n\n    this.filterFieldChange.emit(this.selectedSearchField);\n\n    if (this.fetchDataFunction) {\n      this.fetchDataFunction({\n        filterDescription: this.filterDescription,\n        filterField: this.selectedSearchField,\n        pageNumber: this.currentPage,\n        pageSize: this.defaultItemsPerPage,\n        sortColumn: this.sortColumn,\n        sortDirection: this.sortDirection,\n      }).subscribe({\n        next: (result) => {\n          this.pagedData = result.items;\n          this.totalItems = result.totalItems;\n          this.cdr.markForCheck();\n        },\n        error: (error) => {\n          console.error(\"Erro ao buscar dados:\", error);\n        },\n      });\n    }\n  }\n\n  handleAction(action: string, item: any, index: number) {\n    switch (action) {\n      case \"edit\":\n        if (this.hasPermission(this.editPermissions)) {\n          this.onEditTable.emit({ item, index });\n        }\n        break;\n      case \"delete\":\n        if (this.hasPermission(this.deletePermissions)) {\n          this.onDeleteTable.emit({ item, index });\n        }\n        break;\n      case \"view\":\n        if (this.hasPermission(this.viewPermissions)) {\n          this.onViewTable.emit({ item, index });\n        }\n        break;\n      case \"inativar\":\n        if (this.hasPermission(this.inativoPermissions)) {\n          this.confirmationService\n            .confirm(this.inativoTexts.modalTitle, this.inativoTexts.modalText)\n            .then((confirmed: boolean) => {\n              if (confirmed) {\n                item.status = !item.status;\n                console.log({ status: item.status, item: item })\n                this.statusChange.emit({ status: item.status, item: item });\n              } else {\n                return;\n              }\n            });\n        }\n        break;\n    }\n  }\n\n  hasPermission(requiredPermissions: string[]): boolean {\n    if (!requiredPermissions || requiredPermissions.length === 0) {\n      return true;\n    }\n\n    try {\n      return this.authService.hasPermission(requiredPermissions);\n    } catch (error: unknown) {\n      if (error instanceof Error) {\n        console.error(\"Permission error:\", error.message);\n      } else {\n        console.error(\"Unknown error occurred during permission check\");\n      }\n      return true;\n    }\n  }\n\n  isColumnHidden(columnProp: string): boolean {\n    return this.hiddenColumns.includes(columnProp);\n  }\n\n  onSearch(searchText: string) {\n    this.filterDescription = searchText;\n    this.currentPage = 1; // Resetar para a primeira página\n    this.fetchData();\n  }\n\n  onNewButtonClick() {\n    this.onButtonClick.emit(); // Emitindo o evento\n  }\n}\n","<div class=\"data-table-header\" style=\"margin-top: 2.5rem\">\n  <div class=\"left-section\">\n    <div class=\"form-group\">\n      <label for=\"itemsPerPageSelect\" class=\"items-per-page-label\">{{\n        itemsPerPageLabel\n      }}</label>\n      <select\n        id=\"itemsPerPageSelect\"\n        class=\"form-control form-control-sm d-inline-block w-auto custom-select\"\n        [(ngModel)]=\"defaultItemsPerPage\"\n        (ngModelChange)=\"onItemsPerPageChange()\"\n      >\n        <option *ngFor=\"let option of itemsPerPageOptions\" [value]=\"option\">\n          {{ option }}\n        </option>\n      </select>\n    </div>\n  </div>\n  <div class=\"right-section\">\n    <div *ngIf=\"buttonList && buttonList.length > 0\" class=\"ng-button-row\">\n      <ng-container *ngFor=\"let buttonTemplate of buttonList\">\n        <ng-container\n          *ngTemplateOutlet=\"buttonTemplate\"\n          class=\"ng-button\"\n        ></ng-container>\n      </ng-container>\n    </div>\n    <button\n      *ngIf=\"buttonLabel && buttonLabel.length > 0\"\n      class=\"custom-button\"\n      (click)=\"onNewButtonClick()\"\n    >\n      <lucide-icon name=\"plus\" [size]=\"28\" [strokeWidth]=\"1.75\"></lucide-icon>\n      {{ buttonLabel }}\n    </button>\n  </div>\n</div>\n\n<div class=\"search-input-container\">\n  <argenta-search-input\n    id=\"search\"\n    label=\"\"\n    placeholder=\"Buscar\"\n    [(ngModel)]=\"filterDescription\"\n    (search)=\"onSearch($event)\"\n  ></argenta-search-input>\n</div>\n\n<div class=\"table-responsive\" style=\"margin-top: 1rem\">\n  <table class=\"table table-hover\">\n    <thead>\n      <tr>\n        <ng-container *ngFor=\"let column of columns\">\n          <th\n            *ngIf=\"!isColumnHidden(column.prop)\"\n            (click)=\"onSelectSearchField(column.prop)\"\n          >\n            {{ column.label }}\n            <span>\n              <i-lucide\n                name=\"arrow-up\"\n                [size]=\"14\"\n                [class.selected]=\"\n                  column.isSearchSelected && sortDirection === 'asc'\n                \"\n              ></i-lucide>\n              <i-lucide\n                name=\"arrow-down\"\n                [size]=\"14\"\n                [class.selected]=\"\n                  column.isSearchSelected && sortDirection === 'desc'\n                \"\n              ></i-lucide>\n            </span>\n          </th>\n        </ng-container>\n        <th\n          *ngIf=\"showActionColumn\"\n          class=\"text-end\"\n          style=\"padding-right: 6.3rem\"\n        >\n          {{ actionColumnLabel }}\n        </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)\" [ngSwitch]=\"column.type\">\n            <!-- Default case (when type is undefined or not matched) -->\n            <span *ngSwitchDefault>\n              {{ getNestedProperty(item, column.prop) }}\n            </span>\n\n            <!-- String case -->\n            <span *ngSwitchCase=\"'string'\">\n              {{ getNestedProperty(item, column.prop) }}\n            </span>\n\n            <!-- Image case -->\n            <img\n              *ngSwitchCase=\"'image'\"\n              [src]=\"getNestedProperty(item, column.prop)\"\n              alt=\"Image\"\n              width=\"50\"\n              height=\"50\"\n            />\n          </td>\n        </ng-container>\n        <td *ngIf=\"showActionColumn\" class=\"text-end\">\n          <div class=\"d-flex justify-content-end\">\n            <div\n              *ngIf=\"\n                hasPermission(editPermissions) &&\n                onEditTable.observers.length > 0\n              \"\n              (click)=\"handleAction('edit', item, i)\"\n              class=\"clickable-icon\"\n              style=\"margin-right: 1.5rem\"\n            >\n              <lucide-icon\n                name=\"square-pen\"\n                [size]=\"20\"\n                color=\"#2CA58D\"\n                [strokeWidth]=\"1.75\"\n              ></lucide-icon>\n            </div>\n            <div\n              *ngIf=\"\n                hasPermission(inativoPermissions) &&\n                onInativoTable.observers.length > 0\n              \"\n              (click)=\"handleAction('inativar', item, i)\"\n              class=\"clickable-icon\"\n              style=\"margin-right: 1.5rem\"\n            >\n              <button\n                [ngClass]=\"\n                  item.status\n                    ? 'btn btn-danger small-rounded-btn'\n                    : 'btn btn-success small-rounded-btn'\n                \"\n              >\n                {{\n                  item.status ? inativoTexts.inactivate : inativoTexts.activate\n                }}\n              </button>\n            </div>\n            <div\n              *ngIf=\"\n                hasPermission(viewPermissions) &&\n                onViewTable.observers.length > 0\n              \"\n              (click)=\"handleAction('view', item, i)\"\n              class=\"clickable-icon\"\n              style=\"margin-right: 1.5rem\"\n            >\n              <lucide-icon\n                name=\"user-round\"\n                [size]=\"20\"\n                color=\"#2CA58D\"\n                [strokeWidth]=\"1.75\"\n              ></lucide-icon>\n            </div>\n            <div\n              *ngIf=\"\n                hasPermission(deletePermissions) &&\n                onDeleteTable.observers.length > 0\n              \"\n              (click)=\"handleAction('delete', item, i)\"\n              class=\"clickable-icon\"\n              style=\"margin-right: 1.5rem\"\n            >\n              <i-lucide\n                name=\"trash-2\"\n                [size]=\"20\"\n                color=\"#F26E6E\"\n                [strokeWidth]=\"1.75\"\n              ></i-lucide>\n            </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    (pageChange)=\"onPageChange($event)\"\n  >\n  </custom-pagination>\n</div>\n"]}
|
@@ -15,7 +15,6 @@ import * as i1$2 from '@angular/common/http';
|
|
15
15
|
import { HttpParams } from '@angular/common/http';
|
16
16
|
import jsPDF from 'jspdf';
|
17
17
|
import 'jspdf-autotable';
|
18
|
-
import * as i3$1 from 'projects/lib-portal-angular/src/public-api';
|
19
18
|
import { NgSelectModule } from '@ng-select/ng-select';
|
20
19
|
import * as CryptoJS from 'crypto-js';
|
21
20
|
|
@@ -3872,6 +3871,41 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
3872
3871
|
}]
|
3873
3872
|
}] });
|
3874
3873
|
|
3874
|
+
class ConfirmationService {
|
3875
|
+
constructor(modalService) {
|
3876
|
+
this.modalService = modalService;
|
3877
|
+
this.modalRef = null;
|
3878
|
+
}
|
3879
|
+
confirm(title, message, confirmButtonText = 'Sim', cancelButtonText = 'Não') {
|
3880
|
+
this.modalRef = this.modalService.open(ConfirmationComponent, { backdrop: 'static', keyboard: false });
|
3881
|
+
this.modalRef.componentInstance.title = title;
|
3882
|
+
this.modalRef.componentInstance.message = message;
|
3883
|
+
this.modalRef.componentInstance.confirmButtonText = confirmButtonText;
|
3884
|
+
this.modalRef.componentInstance.cancelButtonText = cancelButtonText;
|
3885
|
+
return this.modalRef.result.then((result) => {
|
3886
|
+
return result === 'confirm';
|
3887
|
+
}, () => {
|
3888
|
+
return false;
|
3889
|
+
}).finally(() => {
|
3890
|
+
this.modalRef = null; // Clear the reference after the modal is closed
|
3891
|
+
});
|
3892
|
+
}
|
3893
|
+
ngOnDestroy() {
|
3894
|
+
if (this.modalRef) {
|
3895
|
+
this.modalRef.dismiss();
|
3896
|
+
this.modalRef = null;
|
3897
|
+
}
|
3898
|
+
}
|
3899
|
+
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 }); }
|
3900
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ConfirmationService, providedIn: 'root' }); }
|
3901
|
+
}
|
3902
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ConfirmationService, decorators: [{
|
3903
|
+
type: Injectable,
|
3904
|
+
args: [{
|
3905
|
+
providedIn: 'root'
|
3906
|
+
}]
|
3907
|
+
}], ctorParameters: function () { return [{ type: i1$1.NgbModal }]; } });
|
3908
|
+
|
3875
3909
|
class DataTableComponent {
|
3876
3910
|
constructor(cdr, authService, refreshService, confirmationService) {
|
3877
3911
|
this.cdr = cdr;
|
@@ -4118,13 +4152,13 @@ class DataTableComponent {
|
|
4118
4152
|
onNewButtonClick() {
|
4119
4153
|
this.onButtonClick.emit(); // Emitindo o evento
|
4120
4154
|
}
|
4121
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DataTableComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: AuthService }, { token: RefreshService }, { token:
|
4155
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DataTableComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: AuthService }, { token: RefreshService }, { token: ConfirmationService }], target: i0.ɵɵFactoryTarget.Component }); }
|
4122
4156
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DataTableComponent, selector: "argenta-list-data-table", inputs: { columns: "columns", hiddenColumns: "hiddenColumns", defaultItemsPerPage: "defaultItemsPerPage", itemsPerPageLabel: "itemsPerPageLabel", showActionColumn: "showActionColumn", actionColumnLabel: "actionColumnLabel", totalItems: "totalItems", fetchDataFunction: "fetchDataFunction", editPermissions: "editPermissions", deletePermissions: "deletePermissions", inativoPermissions: "inativoPermissions", viewPermissions: "viewPermissions", inativoTexts: "inativoTexts", showPageInfo: "showPageInfo", pageText: "pageText", ofText: "ofText", filterDescription: "filterDescription", buttonLabel: "buttonLabel", pagedData: "pagedData", initialFilterField: "initialFilterField", buttonList: "buttonList", status: "status" }, outputs: { statusChange: "statusChange", sortChange: "sortChange", pageChange: "pageChange", itemsPerPageChange: "itemsPerPageChange", onEditTable: "onEditTable", onDeleteTable: "onDeleteTable", onInativoTable: "onInativoTable", onViewTable: "onViewTable", onButtonClick: "onButtonClick", filterFieldChange: "filterFieldChange" }, ngImport: i0, template: "<div class=\"data-table-header\" style=\"margin-top: 2.5rem\">\n <div class=\"left-section\">\n <div class=\"form-group\">\n <label for=\"itemsPerPageSelect\" class=\"items-per-page-label\">{{\n itemsPerPageLabel\n }}</label>\n <select\n id=\"itemsPerPageSelect\"\n class=\"form-control form-control-sm d-inline-block w-auto custom-select\"\n [(ngModel)]=\"defaultItemsPerPage\"\n (ngModelChange)=\"onItemsPerPageChange()\"\n >\n <option *ngFor=\"let option of itemsPerPageOptions\" [value]=\"option\">\n {{ option }}\n </option>\n </select>\n </div>\n </div>\n <div class=\"right-section\">\n <div *ngIf=\"buttonList && buttonList.length > 0\" class=\"ng-button-row\">\n <ng-container *ngFor=\"let buttonTemplate of buttonList\">\n <ng-container\n *ngTemplateOutlet=\"buttonTemplate\"\n class=\"ng-button\"\n ></ng-container>\n </ng-container>\n </div>\n <button\n *ngIf=\"buttonLabel && buttonLabel.length > 0\"\n class=\"custom-button\"\n (click)=\"onNewButtonClick()\"\n >\n <lucide-icon name=\"plus\" [size]=\"28\" [strokeWidth]=\"1.75\"></lucide-icon>\n {{ buttonLabel }}\n </button>\n </div>\n</div>\n\n<div class=\"search-input-container\">\n <argenta-search-input\n id=\"search\"\n label=\"\"\n placeholder=\"Buscar\"\n [(ngModel)]=\"filterDescription\"\n (search)=\"onSearch($event)\"\n ></argenta-search-input>\n</div>\n\n<div class=\"table-responsive\" style=\"margin-top: 1rem\">\n <table class=\"table table-hover\">\n <thead>\n <tr>\n <ng-container *ngFor=\"let column of columns\">\n <th\n *ngIf=\"!isColumnHidden(column.prop)\"\n (click)=\"onSelectSearchField(column.prop)\"\n >\n {{ column.label }}\n <span>\n <i-lucide\n name=\"arrow-up\"\n [size]=\"14\"\n [class.selected]=\"\n column.isSearchSelected && sortDirection === 'asc'\n \"\n ></i-lucide>\n <i-lucide\n name=\"arrow-down\"\n [size]=\"14\"\n [class.selected]=\"\n column.isSearchSelected && sortDirection === 'desc'\n \"\n ></i-lucide>\n </span>\n </th>\n </ng-container>\n <th\n *ngIf=\"showActionColumn\"\n class=\"text-end\"\n style=\"padding-right: 6.3rem\"\n >\n {{ actionColumnLabel }}\n </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)\" [ngSwitch]=\"column.type\">\n <!-- Default case (when type is undefined or not matched) -->\n <span *ngSwitchDefault>\n {{ getNestedProperty(item, column.prop) }}\n </span>\n\n <!-- String case -->\n <span *ngSwitchCase=\"'string'\">\n {{ getNestedProperty(item, column.prop) }}\n </span>\n\n <!-- Image case -->\n <img\n *ngSwitchCase=\"'image'\"\n [src]=\"getNestedProperty(item, column.prop)\"\n alt=\"Image\"\n width=\"50\"\n height=\"50\"\n />\n </td>\n </ng-container>\n <td *ngIf=\"showActionColumn\" class=\"text-end\">\n <div class=\"d-flex justify-content-end\">\n <div\n *ngIf=\"\n hasPermission(editPermissions) &&\n onEditTable.observers.length > 0\n \"\n (click)=\"handleAction('edit', item, i)\"\n class=\"clickable-icon\"\n style=\"margin-right: 1.5rem\"\n >\n <lucide-icon\n name=\"square-pen\"\n [size]=\"20\"\n color=\"#2CA58D\"\n [strokeWidth]=\"1.75\"\n ></lucide-icon>\n </div>\n <div\n *ngIf=\"\n hasPermission(inativoPermissions) &&\n onInativoTable.observers.length > 0\n \"\n (click)=\"handleAction('inativar', item, i)\"\n class=\"clickable-icon\"\n style=\"margin-right: 1.5rem\"\n >\n <button\n [ngClass]=\"\n item.status\n ? 'btn btn-danger small-rounded-btn'\n : 'btn btn-success small-rounded-btn'\n \"\n >\n {{\n item.status ? inativoTexts.inactivate : inativoTexts.activate\n }}\n </button>\n </div>\n <div\n *ngIf=\"\n hasPermission(viewPermissions) &&\n onViewTable.observers.length > 0\n \"\n (click)=\"handleAction('view', item, i)\"\n class=\"clickable-icon\"\n style=\"margin-right: 1.5rem\"\n >\n <lucide-icon\n name=\"user-round\"\n [size]=\"20\"\n color=\"#2CA58D\"\n [strokeWidth]=\"1.75\"\n ></lucide-icon>\n </div>\n <div\n *ngIf=\"\n hasPermission(deletePermissions) &&\n onDeleteTable.observers.length > 0\n \"\n (click)=\"handleAction('delete', item, i)\"\n class=\"clickable-icon\"\n style=\"margin-right: 1.5rem\"\n >\n <i-lucide\n name=\"trash-2\"\n [size]=\"20\"\n color=\"#F26E6E\"\n [strokeWidth]=\"1.75\"\n ></i-lucide>\n </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 (pageChange)=\"onPageChange($event)\"\n >\n </custom-pagination>\n</div>\n", styles: ["@charset \"UTF-8\";.clickable-icon{cursor:pointer}:host{font-family:var(--font-family)}.data-table-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:-.2rem}.left-section,.right-section{display:flex;align-items:center}.search-input-container{display:flex;justify-content:flex-start}.left-section .form-group{display:flex;align-items:center}.items-per-page-label{font-family:var(--font-family);font-size:14px;color:#666;margin-right:.2rem}.custom-select{font-family:var(--font-family);font-size:14px;color:#666;background:#fff url('data:image/svg+xml;charset=US-ASCII,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 4 5\"><path fill=\"#666\" d=\"M2 0L0 2h4L2 0zM2 5l2-2H0l2 2z\"/></svg>') no-repeat right .75rem center/8px 10px;border:1px solid #ccc;border-radius:.25rem;padding:.375rem 1.75rem .375rem .75rem;appearance:none;-webkit-appearance:none;-moz-appearance:none}.custom-select:focus{border-color:#80bdff;outline:0;box-shadow:0 0 0 .2rem #007bff40}.table{font-family:var(--font-family);font-size:var(--table-font-size, 14px);color:var(--table-font-color, #737b7b);border-collapse:separate;border-spacing:0;border-radius:8px;overflow:hidden}.table thead tr{height:60px}.table thead th{background-color:var(--primary-color);color:var(--text-color);font-family:var(--font-family);font-size:14px;font-weight:600;padding:10px;border-bottom:.1rem solid #dcdcdc;text-align:center;line-height:2.5}.table thead th:first-child{text-align:left;padding-left:1.4rem}.table tbody td{font-family:var(--font-family);font-size:14px;color:#737b7b;padding:10px;border-bottom:.1rem solid #dcdcdc;text-align:center}.table tbody td:first-child{text-align:left;padding-left:1.4rem}.table tbody tr:last-child td{border-bottom:.1rem solid #dcdcdc}.table tbody td{border-right:none;border-left: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:0}.table tbody tr:last-child td:last-child{border-bottom-right-radius:0}.btn-icon{width:24px;height:24px;background-size:cover;display:inline-block;cursor:pointer;margin-right:16px}.pagination-controls{display:flex;justify-content:center;align-items:center;margin-top:1rem}.custom-button{display:flex;align-items:center;padding:.5rem 1rem .5rem .5rem;border-radius:.25rem;transition:background-color .3s,border-color .3s,filter .3s;font-family:var(--font-family);font-size:16px;font-weight:600;height:40px;letter-spacing:.005em;text-align:left;color:#fff;background-color:var(--secondary-color);border:none;cursor:pointer}.custom-button lucide-icon{margin-right:.5rem}.custom-button:hover{box-shadow:0 0 0 .15rem var(--secondary-color)}.custom-button:active{background-color:var(--secondary-color)}.custom-button:focus{outline:none;box-shadow:0 0 0 .15rem var(--secondary-color)}.selected{color:var(--secondary-color);stroke-width:8}.ng-button-row{display:flex;gap:10px;margin-right:10px;margin-left:10px}.small-rounded-btn{padding:6px 12px;font-size:14px;border-radius:20px;height:32px;min-width:80px;border:none;transition:all .3s ease-in-out}.small-rounded-btn:hover{opacity:.8;transform:scale(1.05)}\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: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i1.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { 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: i3.LucideAngularComponent, selector: "lucide-angular, lucide-icon, i-lucide, span-lucide", inputs: ["class", "name", "img", "color", "absoluteStrokeWidth", "size", "strokeWidth"] }, { kind: "component", type: CustomPaginationComponent, selector: "custom-pagination", inputs: ["totalItems", "itemsPerPage", "currentPage", "showPageInfo"], outputs: ["pageChange"] }, { kind: "component", type: SearchInputComponent, selector: "argenta-search-input", inputs: ["id", "label", "type", "placeholder", "value", "disabled", "readonly", "autofocus", "maxlength", "minlength", "required", "pattern", "debounceTime"], outputs: ["search", "inputChange", "change", "focus", "blur", "keyup", "keydown", "keypress"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
4123
4157
|
}
|
4124
4158
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DataTableComponent, decorators: [{
|
4125
4159
|
type: Component,
|
4126
4160
|
args: [{ selector: "argenta-list-data-table", changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"data-table-header\" style=\"margin-top: 2.5rem\">\n <div class=\"left-section\">\n <div class=\"form-group\">\n <label for=\"itemsPerPageSelect\" class=\"items-per-page-label\">{{\n itemsPerPageLabel\n }}</label>\n <select\n id=\"itemsPerPageSelect\"\n class=\"form-control form-control-sm d-inline-block w-auto custom-select\"\n [(ngModel)]=\"defaultItemsPerPage\"\n (ngModelChange)=\"onItemsPerPageChange()\"\n >\n <option *ngFor=\"let option of itemsPerPageOptions\" [value]=\"option\">\n {{ option }}\n </option>\n </select>\n </div>\n </div>\n <div class=\"right-section\">\n <div *ngIf=\"buttonList && buttonList.length > 0\" class=\"ng-button-row\">\n <ng-container *ngFor=\"let buttonTemplate of buttonList\">\n <ng-container\n *ngTemplateOutlet=\"buttonTemplate\"\n class=\"ng-button\"\n ></ng-container>\n </ng-container>\n </div>\n <button\n *ngIf=\"buttonLabel && buttonLabel.length > 0\"\n class=\"custom-button\"\n (click)=\"onNewButtonClick()\"\n >\n <lucide-icon name=\"plus\" [size]=\"28\" [strokeWidth]=\"1.75\"></lucide-icon>\n {{ buttonLabel }}\n </button>\n </div>\n</div>\n\n<div class=\"search-input-container\">\n <argenta-search-input\n id=\"search\"\n label=\"\"\n placeholder=\"Buscar\"\n [(ngModel)]=\"filterDescription\"\n (search)=\"onSearch($event)\"\n ></argenta-search-input>\n</div>\n\n<div class=\"table-responsive\" style=\"margin-top: 1rem\">\n <table class=\"table table-hover\">\n <thead>\n <tr>\n <ng-container *ngFor=\"let column of columns\">\n <th\n *ngIf=\"!isColumnHidden(column.prop)\"\n (click)=\"onSelectSearchField(column.prop)\"\n >\n {{ column.label }}\n <span>\n <i-lucide\n name=\"arrow-up\"\n [size]=\"14\"\n [class.selected]=\"\n column.isSearchSelected && sortDirection === 'asc'\n \"\n ></i-lucide>\n <i-lucide\n name=\"arrow-down\"\n [size]=\"14\"\n [class.selected]=\"\n column.isSearchSelected && sortDirection === 'desc'\n \"\n ></i-lucide>\n </span>\n </th>\n </ng-container>\n <th\n *ngIf=\"showActionColumn\"\n class=\"text-end\"\n style=\"padding-right: 6.3rem\"\n >\n {{ actionColumnLabel }}\n </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)\" [ngSwitch]=\"column.type\">\n <!-- Default case (when type is undefined or not matched) -->\n <span *ngSwitchDefault>\n {{ getNestedProperty(item, column.prop) }}\n </span>\n\n <!-- String case -->\n <span *ngSwitchCase=\"'string'\">\n {{ getNestedProperty(item, column.prop) }}\n </span>\n\n <!-- Image case -->\n <img\n *ngSwitchCase=\"'image'\"\n [src]=\"getNestedProperty(item, column.prop)\"\n alt=\"Image\"\n width=\"50\"\n height=\"50\"\n />\n </td>\n </ng-container>\n <td *ngIf=\"showActionColumn\" class=\"text-end\">\n <div class=\"d-flex justify-content-end\">\n <div\n *ngIf=\"\n hasPermission(editPermissions) &&\n onEditTable.observers.length > 0\n \"\n (click)=\"handleAction('edit', item, i)\"\n class=\"clickable-icon\"\n style=\"margin-right: 1.5rem\"\n >\n <lucide-icon\n name=\"square-pen\"\n [size]=\"20\"\n color=\"#2CA58D\"\n [strokeWidth]=\"1.75\"\n ></lucide-icon>\n </div>\n <div\n *ngIf=\"\n hasPermission(inativoPermissions) &&\n onInativoTable.observers.length > 0\n \"\n (click)=\"handleAction('inativar', item, i)\"\n class=\"clickable-icon\"\n style=\"margin-right: 1.5rem\"\n >\n <button\n [ngClass]=\"\n item.status\n ? 'btn btn-danger small-rounded-btn'\n : 'btn btn-success small-rounded-btn'\n \"\n >\n {{\n item.status ? inativoTexts.inactivate : inativoTexts.activate\n }}\n </button>\n </div>\n <div\n *ngIf=\"\n hasPermission(viewPermissions) &&\n onViewTable.observers.length > 0\n \"\n (click)=\"handleAction('view', item, i)\"\n class=\"clickable-icon\"\n style=\"margin-right: 1.5rem\"\n >\n <lucide-icon\n name=\"user-round\"\n [size]=\"20\"\n color=\"#2CA58D\"\n [strokeWidth]=\"1.75\"\n ></lucide-icon>\n </div>\n <div\n *ngIf=\"\n hasPermission(deletePermissions) &&\n onDeleteTable.observers.length > 0\n \"\n (click)=\"handleAction('delete', item, i)\"\n class=\"clickable-icon\"\n style=\"margin-right: 1.5rem\"\n >\n <i-lucide\n name=\"trash-2\"\n [size]=\"20\"\n color=\"#F26E6E\"\n [strokeWidth]=\"1.75\"\n ></i-lucide>\n </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 (pageChange)=\"onPageChange($event)\"\n >\n </custom-pagination>\n</div>\n", styles: ["@charset \"UTF-8\";.clickable-icon{cursor:pointer}:host{font-family:var(--font-family)}.data-table-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:-.2rem}.left-section,.right-section{display:flex;align-items:center}.search-input-container{display:flex;justify-content:flex-start}.left-section .form-group{display:flex;align-items:center}.items-per-page-label{font-family:var(--font-family);font-size:14px;color:#666;margin-right:.2rem}.custom-select{font-family:var(--font-family);font-size:14px;color:#666;background:#fff url('data:image/svg+xml;charset=US-ASCII,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 4 5\"><path fill=\"#666\" d=\"M2 0L0 2h4L2 0zM2 5l2-2H0l2 2z\"/></svg>') no-repeat right .75rem center/8px 10px;border:1px solid #ccc;border-radius:.25rem;padding:.375rem 1.75rem .375rem .75rem;appearance:none;-webkit-appearance:none;-moz-appearance:none}.custom-select:focus{border-color:#80bdff;outline:0;box-shadow:0 0 0 .2rem #007bff40}.table{font-family:var(--font-family);font-size:var(--table-font-size, 14px);color:var(--table-font-color, #737b7b);border-collapse:separate;border-spacing:0;border-radius:8px;overflow:hidden}.table thead tr{height:60px}.table thead th{background-color:var(--primary-color);color:var(--text-color);font-family:var(--font-family);font-size:14px;font-weight:600;padding:10px;border-bottom:.1rem solid #dcdcdc;text-align:center;line-height:2.5}.table thead th:first-child{text-align:left;padding-left:1.4rem}.table tbody td{font-family:var(--font-family);font-size:14px;color:#737b7b;padding:10px;border-bottom:.1rem solid #dcdcdc;text-align:center}.table tbody td:first-child{text-align:left;padding-left:1.4rem}.table tbody tr:last-child td{border-bottom:.1rem solid #dcdcdc}.table tbody td{border-right:none;border-left: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:0}.table tbody tr:last-child td:last-child{border-bottom-right-radius:0}.btn-icon{width:24px;height:24px;background-size:cover;display:inline-block;cursor:pointer;margin-right:16px}.pagination-controls{display:flex;justify-content:center;align-items:center;margin-top:1rem}.custom-button{display:flex;align-items:center;padding:.5rem 1rem .5rem .5rem;border-radius:.25rem;transition:background-color .3s,border-color .3s,filter .3s;font-family:var(--font-family);font-size:16px;font-weight:600;height:40px;letter-spacing:.005em;text-align:left;color:#fff;background-color:var(--secondary-color);border:none;cursor:pointer}.custom-button lucide-icon{margin-right:.5rem}.custom-button:hover{box-shadow:0 0 0 .15rem var(--secondary-color)}.custom-button:active{background-color:var(--secondary-color)}.custom-button:focus{outline:none;box-shadow:0 0 0 .15rem var(--secondary-color)}.selected{color:var(--secondary-color);stroke-width:8}.ng-button-row{display:flex;gap:10px;margin-right:10px;margin-left:10px}.small-rounded-btn{padding:6px 12px;font-size:14px;border-radius:20px;height:32px;min-width:80px;border:none;transition:all .3s ease-in-out}.small-rounded-btn:hover{opacity:.8;transform:scale(1.05)}\n"] }]
|
4127
|
-
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: AuthService }, { type: RefreshService }, { type:
|
4161
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: AuthService }, { type: RefreshService }, { type: ConfirmationService }]; }, propDecorators: { columns: [{
|
4128
4162
|
type: Input
|
4129
4163
|
}], hiddenColumns: [{
|
4130
4164
|
type: Input
|
@@ -4677,41 +4711,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
4677
4711
|
}]
|
4678
4712
|
}], ctorParameters: function () { return [{ type: i0.ApplicationRef }, { type: i0.Injector }]; } });
|
4679
4713
|
|
4680
|
-
class ConfirmationService {
|
4681
|
-
constructor(modalService) {
|
4682
|
-
this.modalService = modalService;
|
4683
|
-
this.modalRef = null;
|
4684
|
-
}
|
4685
|
-
confirm(title, message, confirmButtonText = 'Sim', cancelButtonText = 'Não') {
|
4686
|
-
this.modalRef = this.modalService.open(ConfirmationComponent, { backdrop: 'static', keyboard: false });
|
4687
|
-
this.modalRef.componentInstance.title = title;
|
4688
|
-
this.modalRef.componentInstance.message = message;
|
4689
|
-
this.modalRef.componentInstance.confirmButtonText = confirmButtonText;
|
4690
|
-
this.modalRef.componentInstance.cancelButtonText = cancelButtonText;
|
4691
|
-
return this.modalRef.result.then((result) => {
|
4692
|
-
return result === 'confirm';
|
4693
|
-
}, () => {
|
4694
|
-
return false;
|
4695
|
-
}).finally(() => {
|
4696
|
-
this.modalRef = null; // Clear the reference after the modal is closed
|
4697
|
-
});
|
4698
|
-
}
|
4699
|
-
ngOnDestroy() {
|
4700
|
-
if (this.modalRef) {
|
4701
|
-
this.modalRef.dismiss();
|
4702
|
-
this.modalRef = null;
|
4703
|
-
}
|
4704
|
-
}
|
4705
|
-
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 }); }
|
4706
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ConfirmationService, providedIn: 'root' }); }
|
4707
|
-
}
|
4708
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ConfirmationService, decorators: [{
|
4709
|
-
type: Injectable,
|
4710
|
-
args: [{
|
4711
|
-
providedIn: 'root'
|
4712
|
-
}]
|
4713
|
-
}], ctorParameters: function () { return [{ type: i1$1.NgbModal }]; } });
|
4714
|
-
|
4715
4714
|
class DataPaginateService {
|
4716
4715
|
constructor(http) {
|
4717
4716
|
this.http = http;
|