keevo-components 2.0.243 → 2.0.245
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/kv-icon/kv-icon.component.mjs +3 -3
- package/esm2022/lib/components/kv-kanban/kv-kanban.component.mjs +4 -3
- package/esm2022/lib/components/kv-table/kv-table.component.mjs +18 -4
- package/esm2022/lib/components/kv-table-draggable/kv-table-draggable.component.mjs +35 -35
- package/esm2022/lib/components/kv-tree-environment/components/kv-tree-environment/kv-tree-environment.component.mjs +3 -3
- package/esm2022/lib/components/kv-tree-environment/components/no-arvore/no-arvore.component.mjs +3 -3
- package/esm2022/lib/components/kv-widget-card/kv-widget-card.component.mjs +3 -3
- package/fesm2022/keevo-components.mjs +61 -47
- package/fesm2022/keevo-components.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -136,9 +136,23 @@ export class KvTableComponent {
|
|
|
136
136
|
return [...dynamicColumns, ...this.deletedColuns];
|
|
137
137
|
});
|
|
138
138
|
this.returnMaxWidth = computed(() => (widthCol) => {
|
|
139
|
-
let widthTable =
|
|
140
|
-
|
|
141
|
-
|
|
139
|
+
let widthTable = 0;
|
|
140
|
+
const tableCellRef = this.tableCell ? this.tableCell() : null;
|
|
141
|
+
if (tableCellRef && tableCellRef.nativeElement && tableCellRef.nativeElement.parentElement) {
|
|
142
|
+
widthTable = tableCellRef.nativeElement.parentElement.offsetWidth;
|
|
143
|
+
}
|
|
144
|
+
else {
|
|
145
|
+
const tableElem = this.elementRef?.nativeElement?.querySelector('.p-datatable') ||
|
|
146
|
+
this.elementRef?.nativeElement?.querySelector('table');
|
|
147
|
+
if (tableElem && tableElem.offsetWidth) {
|
|
148
|
+
widthTable = tableElem.offsetWidth;
|
|
149
|
+
}
|
|
150
|
+
else if (this.table && this.table.el && this.table.el.nativeElement) {
|
|
151
|
+
widthTable = this.table.el.nativeElement.offsetWidth || 0;
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
const percent = Number((widthCol || '100%').toString().replace('%', '')) || 100;
|
|
155
|
+
const widthCalc = widthTable * percent / 100;
|
|
142
156
|
return `${widthCalc}px`;
|
|
143
157
|
});
|
|
144
158
|
this.isRowSelectable = this.isRowSelectable.bind(this);
|
|
@@ -734,4 +748,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
|
|
|
734
748
|
type: HostListener,
|
|
735
749
|
args: ['document:click', ['$event']]
|
|
736
750
|
}] } });
|
|
737
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-table.component.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/components/kv-table/kv-table.component.ts","../../../../../../projects/keevo-components/src/lib/components/kv-table/kv-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DatePipe, DecimalPipe } from '@angular/common';\r\n\r\nimport {\r\n  AfterViewInit,\r\n  Component,\r\n  ContentChildren,\r\n  DoCheck,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostListener,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  QueryList,\r\n  Renderer2,\r\n  TemplateRef,\r\n  ViewChild,\r\n  computed,\r\n  effect,\r\n  input,\r\n  model,\r\n  signal,\r\n  viewChild,\r\n} from '@angular/core';\r\n\r\nimport { MenuItem } from 'primeng/api';\r\nimport { Table, TablePageEvent } from 'primeng/table';\r\n\r\nimport { CpfCnpjPipe } from '../../api/pipes/cpfcnpj.pipe';\r\nimport {\r\n  getOrExecute,\r\n  ValueOrFn,\r\n  mapToMenuItem,\r\n} from '../../api/components/table/kv-menuitem';\r\nimport { TableConfig } from '../../api/components/table/table.config';\r\nimport { TableConfigColumn } from '../../api/components/table/table.config.column';\r\nimport { TablePaginate } from '../../api/components/table/table.paginate';\r\nimport { TelefonePipe } from '../../api/pipes/telefone.pipe';\r\nimport { TemplateDirective } from '../../api/directives/template/template.directive';\r\nimport { OverlayPanel } from 'primeng/overlaypanel';\r\n\r\n\r\nconst imgDefault =\r\n  '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';\r\n\r\n@Component({\r\n  selector: 'kv-table',\r\n  templateUrl: './kv-table.component.html',\r\n  styleUrls: ['./kv-table.component.scss'],\r\n})\r\nexport class KvTableComponent implements OnInit, DoCheck, AfterViewInit {\r\n  private readonly tableConfig = signal<TableConfig | undefined>(undefined);\r\n\r\n\r\n\r\n\r\n  globalFilterFields: string[] = [];\r\n\r\n  selectedSize: string = '';\r\n\r\n  widthPage = signal<number>(0);\r\n\r\n  checked: boolean = true;\r\n\r\n  columns: TableConfigColumn[] = [];\r\n  deletedColuns: TableConfigColumn[] = [];\r\n\r\n  private prepositions = new Set<string>([\r\n    'de', 'da', 'do', 'em', 'no', 'na', 'para', 'por', 'com', 'a', 'o', 'e'\r\n  ]);\r\n\r\n  private romanNumerals = new Set<string>([\r\n    'I', 'II', 'III', 'IV', 'V', 'VI', 'VII', 'VIII', 'IX', 'X', 'XI', 'XII', 'XIII', 'XIV', 'XV',\r\n    'XVI', 'XVII', 'XVIII', 'XIX', 'XX'\r\n  ]);\r\n\r\n  private siglas = new Set<string>([\r\n    'UI', 'UX', 'TI'\r\n  ]);\r\n\r\n  private overlayElement: HTMLElement | null = null;\r\n\r\n  menuFiltro: boolean = false;\r\n  checkboxClicked: boolean = false;\r\n\r\n  @Input() searchPlaceholder: string = 'Pesquisar...';\r\n\r\n  collapsed: boolean = false;\r\n\r\n  tableActions: MenuItem[][] = [];\r\n  currDataSource: any[] = [];\r\n\r\n  menuItems!: MenuItem[];\r\n\r\n  actionsOffset: number = 0;\r\n\r\n  @ContentChildren(TemplateDirective) templates!: QueryList<any>;\r\n  @Input('templates') _templates!: any;\r\n\r\n  @ViewChild('table', { static: false }) table!: Table;\r\n\r\n  @ViewChild(Table) ptable!: Table;\r\n\r\n  @ViewChild('op') op!: OverlayPanel;\r\n\r\n  @Input('config') set setConfig(value: TableConfig) {\r\n    this.tableConfig.set({\r\n      enableCation: value.enableCation || true,\r\n      enableSelect: value.enableSelect || false,\r\n      enableFilter: value.enableFilter || true,\r\n      ...value,\r\n    });\r\n\r\n    this.definirColunasConfiguraveis(this.tableConfig()!);\r\n  }\r\n\r\n  first = model<number>(0);\r\n  rows = model<number>(5);\r\n\r\n  @Input() defaultSortField: string | undefined = undefined;\r\n  @Input() dataSource: any[] = [];\r\n  @Input() selectedItems: any[] = [];\r\n  @Input() totalRecords!: number;\r\n  @Input() paginator: boolean = true;\r\n  @Input() rowsPerPageOptions!: number[];\r\n  @Input() tableSize!: number;\r\n  @Input() filterColumnsBtn: boolean = false;\r\n  @Input() replaceEmptyValues: boolean = true;\r\n  @Input() autoFocusSearch: boolean = true;\r\n\r\n\r\n  /**\r\n   * @deprecated Essa propriedade não será mais utilizada por esse componente nas próximas versões.\r\n   */\r\n  @Input() filtrosAvancados: boolean = false;\r\n\r\n  @Input() scrollHeight: string = '';\r\n  @Input() isTableScrollable: boolean = false;\r\n  @Input() tableCaptalized: boolean = false;\r\n\r\n  @Input() rowTrackBy: (index: number, item: any) => any = (index: number, item: any) => item;\r\n\r\n  @Input() responsiveLayout: boolean = true;\r\n\r\n  @Input() disabledHeaderCheckbox: boolean = false;\r\n\r\n  /**\r\n   * @deprecated Use a propriedade \"tagColor\" na configuração da coluna para estilizar a tag\r\n   */\r\n  @Input() applyStyle: Function = (rowData: any, col: TableConfigColumn) => '';\r\n\r\n  /**\r\n   * @deprecated O valor de pageLinks é atribuído de acordo com o tamanho da tela, essa propriedade não está sendo utilizada\r\n   */\r\n  @Input() pageLinksOptions!: number;\r\n\r\n  /**\r\n   * @deprecated A quantidade de paginitorPageIcons é atribuído de acordo com o tamanho da tela, essa propriedade não está sendo utilizada\r\n   */\r\n  @Input() showFirstLastIcon!: boolean;\r\n\r\n  @Output() onActiveItem: EventEmitter<any> = new EventEmitter();\r\n  @Output() onActiveItemLote: EventEmitter<any> = new EventEmitter();\r\n  @Output() onPaginate: EventEmitter<TablePaginate> = new EventEmitter();\r\n  @Output() onSelectionChange: EventEmitter<any> = new EventEmitter();\r\n  @Output() doubleClickEvent: EventEmitter<any> = new EventEmitter();\r\n  @Output() filterField: EventEmitter<any> = new EventEmitter();\r\n  @Output() onSwitchTableChange: EventEmitter<any> = new EventEmitter();\r\n\r\n  @ViewChild('menuFiltroDiv') menuFiltroDiv!: ElementRef;\r\n  @ViewChild('botaoFiltro') botaoFiltro!: ElementRef;\r\n  @ViewChild('inputField') inputField!: ElementRef;\r\n\r\n  tableCell = viewChild<ElementRef>('tableCell');\r\n  ellipsisText = input<boolean>(false);\r\n  isLoadingSkeleton = input<boolean>(false);\r\n\r\n  filterButton = input<boolean>(false);\r\n  filterButtonBadge = input<string>('');\r\n\r\n  emptyImage = input<boolean>(false);\r\n\r\n  @HostListener('document:click', ['$event'])\r\n  onClickOutside(event: MouseEvent) {\r\n    if (!this.op || !this.op.overlayVisible) {\r\n      return;\r\n    }\r\n\r\n    const targetElement = event.target as HTMLElement;\r\n\r\n    const filterButton = this.elementRef.nativeElement.querySelector('[label=\"Filtrar\"]');\r\n    if (filterButton && filterButton.contains(targetElement)) {\r\n      return;\r\n    }\r\n\r\n    if (targetElement.closest('.p-overlaypanel')) {\r\n      return;\r\n    }\r\n  }\r\n\r\n\r\n  constructor(\r\n    private readonly datePipe: DatePipe,\r\n    private readonly decimalPipe: DecimalPipe,\r\n    private readonly cpfCnpjPipe: CpfCnpjPipe,\r\n    private readonly telefonePipe: TelefonePipe,\r\n    private renderer: Renderer2,\r\n    private elementRef: ElementRef\r\n  ) {\r\n    this.isRowSelectable = this.isRowSelectable.bind(this);\r\n  }\r\n\r\n  configuracaoEffect = effect(() => {\r\n    const config = this.tableConfig()!;\r\n    this.definirFiltrosGlobais(config);\r\n    this.definirColunasConfiguraveis(config);\r\n  });\r\n\r\n  dataSourceSignal = signal<any[]>([]);\r\n\r\n  widthSkeletons: number[] = [];\r\n\r\n  widthRandom = computed(() => (col: any, row: any) => {\r\n    if (!col.template && !col.icon && !col.fieldType && !col.boolean && !col.pipe) {\r\n      return this.widthSkeletons[row] * 100;\r\n    } else {\r\n      return 100;\r\n    }\r\n  });\r\n\r\n  emptyTableImg = input<string>('https://work-assets.keevo.com.br/img/Nenhum_registro_localizado.png');\r\n\r\n  ngDoCheck(): void {\r\n    if (\r\n      JSON.stringify(this.dataSource) !== JSON.stringify(this.currDataSource)\r\n    ) {\r\n      if (this.dataSource) {\r\n        this.createTableActions();\r\n        this.currDataSource = [...this.dataSource];\r\n        this.dataSource = [...this.dataSource];\r\n        this.dataSourceSignal.set([...this.dataSource]);\r\n      }\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.removeOverlay();\r\n  }\r\n\r\n  dataSourceMock: any[] = [];\r\n\r\n  isEmptyDataSource = computed(() => {\r\n    return JSON.stringify(this.dataSourceSignal()) === JSON.stringify(this.dataSourceMock);\r\n  })\r\n\r\n  loadingSkeletonUtilities() {\r\n    if (this.dataSource.length === 0 && this.isLoadingSkeleton()) {\r\n      let rowItem: any = {};\r\n      this.tableConfig()?.columns.forEach((col) => {\r\n        rowItem[col.field] = '';\r\n      });\r\n\r\n      this.dataSourceMock = Array(this.rows()).fill({ ...rowItem });\r\n      this.dataSource = this.dataSourceMock;\r\n\r\n      for (let i = 0; i < this.rows(); i++) {\r\n        this.widthSkeletons.push(Math.random() * 0.7 + 0.2);\r\n      }\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.loadingSkeletonUtilities();\r\n    this.adjustTableSize();\r\n    this.widthPage.set(window.innerWidth);\r\n    // this.criarMenuColumns();\r\n    this.config.columns.forEach(col => {\r\n      this.columns.push(col);\r\n    });\r\n    this.checkHideColumns();\r\n    const defaultSortField = this.defaultSortField;\r\n    if (defaultSortField && this.dataSource) {\r\n      this.dataSource.sort((a, b) => {\r\n        if (\r\n          typeof a[defaultSortField] === 'string' &&\r\n          typeof b[defaultSortField] === 'string'\r\n        ) {\r\n          return (a[defaultSortField] as string).localeCompare(\r\n            (b[defaultSortField] as string)\r\n          );\r\n        } else if (\r\n          typeof a[defaultSortField] === 'boolean' &&\r\n          typeof b[defaultSortField] === 'boolean'\r\n        ) {\r\n          return a[defaultSortField] === b[defaultSortField]\r\n            ? 0\r\n            : a[defaultSortField]\r\n              ? 1\r\n              : -1;\r\n        } else if (\r\n          typeof a[defaultSortField] === 'number' &&\r\n          typeof b[defaultSortField] === 'number'\r\n        ) {\r\n          return (a[defaultSortField] as number) - (b[defaultSortField] as number);\r\n        } else {\r\n          return 0; // Ou outra lógica dependendo do caso\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    document.querySelectorAll('.disabled-row').forEach(row => {\r\n      row.querySelectorAll('td').forEach(cell => {\r\n        cell.addEventListener('click', event => {\r\n          const target = event.target as HTMLElement;\r\n          if (!target.classList.contains('tooltip')) {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n          }\r\n        });\r\n      });\r\n    });\r\n  }\r\n\r\n  toggleOverlayPanel(event: Event) {\r\n    event.stopPropagation();\r\n    this.op.toggle(event);\r\n\r\n    setTimeout(() => {\r\n      if (this.op.overlayVisible) {\r\n        this.createOverlay();\r\n      } else {\r\n        this.removeOverlay();\r\n      }\r\n    }, 0);\r\n  }\r\n\r\n  private createOverlay() {\r\n    if (this.overlayElement) {\r\n      return;\r\n    }\r\n\r\n    this.overlayElement = this.renderer.createElement('div');\r\n    this.renderer.addClass(this.overlayElement, 'filter-overlay');\r\n\r\n    this.renderer.listen(this.overlayElement, 'click', () => {\r\n      this.closeFilter();\r\n    })\r\n\r\n    this.renderer.appendChild(document.body, this.overlayElement);\r\n  }\r\n\r\n  removeOverlay() {\r\n    if (this.overlayElement) {\r\n      this.renderer.removeChild(document.body, this.overlayElement);\r\n      this.overlayElement = null;\r\n    }\r\n  }\r\n\r\n\r\n  public closeFilter() {\r\n    this.op?.hide();\r\n    this.removeOverlay();\r\n  }\r\n\r\n\r\n  definirColunasConfiguraveis(config: TableConfig) {\r\n    this.columns.splice(0, this.columns.length);\r\n\r\n    config.columns.forEach(col => {\r\n      this.columns.push(col);\r\n    });\r\n  }\r\n\r\n  definirFiltrosGlobais(config: TableConfig) {\r\n    if (config?.enableFilter) {\r\n\r\n      this.globalFilterFields.splice(0, this.globalFilterFields.length);\r\n\r\n      for (const column of config.columns) {\r\n        this.globalFilterFields.push(column.field);\r\n      }\r\n    }\r\n  }\r\n\r\n  resetTable() {\r\n    if (this.ptable) this.ptable.reset();\r\n    if (this.inputField) this.inputField.nativeElement.value = '';\r\n  }\r\n\r\n  @HostListener('window:resize', ['$event'])\r\n  onWindowResize() {\r\n    this.adjustTableSize();\r\n    this.widthPage.set(window.innerWidth);\r\n  }\r\n\r\n  public activeItem(rowData: any) {\r\n    this.onActiveItem.emit(rowData);\r\n  }\r\n\r\n  getOrExecute<T>(action: ValueOrFn<T>, data: any): T {\r\n    return getOrExecute(action, data);\r\n  }\r\n\r\n  isBooleanField(rowData: any, col: TableConfigColumn): boolean {\r\n    return typeof rowData[col.field] == 'boolean';\r\n  }\r\n\r\n  isChipField(col: TableConfigColumn): boolean {\r\n    return col.fieldType == 'chip';\r\n  }\r\n\r\n  protected onPage(event: TablePageEvent) {\r\n    this.first.set(event.first);\r\n    this.rows.set(event.rows);\r\n  }\r\n\r\n  isImageField(col: TableConfigColumn): boolean {\r\n    let retorno = col.fieldType && col.fieldType === 'image' ? true : false;\r\n    return retorno;\r\n  }\r\n\r\n  isSwitchField(col: TableConfigColumn): boolean {\r\n    let retorno = col.fieldType && col.fieldType === 'switch' ? true : false;\r\n    return retorno;\r\n  }\r\n\r\n  isRowSelectable(event: any) {\r\n    return !this.isDisabledCheckbox(event.data);\r\n  }\r\n\r\n  isDisabledCheckbox(rowData: any): boolean {\r\n    return this.config.disableControlCheckboxFunction\r\n      ? this.config.disableControlCheckboxFunction(rowData)\r\n      : false;\r\n  }\r\n\r\n  isDisabledRow(rowData: any): boolean {\r\n    return this.config.disableRow ? this.config.disableRow(rowData) : false;\r\n  }\r\n\r\n  // Não é utilizada\r\n  private getStyleClass(rowData: any, col: TableConfigColumn, data: any): string {\r\n    // console.log('ESTILO ->', col ? col.styleClass!(rowData, col, data) : '')\r\n    return col ? col.styleClass!(rowData, col, data) : ''\r\n  }\r\n\r\n  verificaCursor() {\r\n    document.querySelectorAll('.disabled-row').forEach(row => {\r\n      row.querySelectorAll('td').forEach(cell => {\r\n        cell.addEventListener('click', event => {\r\n          const target = event.target as HTMLElement;\r\n          if (!target.classList.contains('tooltip')) {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n          }\r\n        });\r\n      });\r\n    });\r\n  }\r\n\r\n  // Não está verificando se rowData[col.field] é string\r\n  loadImage(rowData: any, col: TableConfigColumn): string {\r\n    /*\r\n      Nossa coluna de imagem trabalha com strings do tipo: base64 ou url\r\n    */\r\n    let retorno = `data: image / jpg; base64, ${imgDefault} `;\r\n    if (rowData && col && rowData[col.field] && rowData[col.field] !== '') {\r\n      if (rowData[col.field].includes('http')) retorno = rowData[col.field];\r\n      else retorno = `data: image / jpg; base64, ${rowData[col.field]} `;\r\n    }\r\n\r\n    return retorno;\r\n  }\r\n\r\n  public onGlobalFilter(table: Table, event: Event) {\r\n    this.filterField.emit((event.target as HTMLInputElement).value);\r\n    table.filterGlobal((event.target as HTMLInputElement).value, 'contains');\r\n  }\r\n\r\n  public paginate(event: any) {\r\n    if (event) {\r\n      let paginaInicial =\r\n        (event?.first > 0 ? event.first / event.rows : event.first) + 1;\r\n      let termoPesquisa = '';\r\n      let ordenacao = '';\r\n\r\n      if (event.globalFilter) termoPesquisa = event.globalFilter;\r\n\r\n      if (event.sortField)\r\n        ordenacao = `${event.sortField} ${event.sortOrder === 1 ? 'ASC' : 'DESC'} `;\r\n\r\n      const objeto: TablePaginate = {\r\n        paginaInicial: paginaInicial,\r\n        tamanhoPagina: event.rows,\r\n        termoPesquisa: termoPesquisa,\r\n        ordenacao: ordenacao,\r\n        ordernacaoGroup: { column: event.sortField, direction: event.sortOrder === 1 ? 'ASC' : 'DESC' },\r\n      };\r\n\r\n      this.onPaginate.emit(objeto);\r\n\r\n      this.actionsOffset = event.first;\r\n      this.createTableActions();\r\n    }\r\n  }\r\n\r\n  selectionChange(value: any) {\r\n    this.onSelectionChange.emit(value);\r\n  }\r\n\r\n  public activeItemLote(selectedItems: any) {\r\n    this.onActiveItemLote.emit(selectedItems);\r\n  }\r\n\r\n  // Não está verificando se rowData[col.field] pode ser passado para Date\r\n  returnRowClass(rowData: any, col: TableConfigColumn) {\r\n    let value = rowData[col.field];\r\n    let rowClass: string;\r\n\r\n    this.tableSize > 800 ? (rowClass = 'text-base') : (rowClass = 'text-sm');\r\n\r\n    if (col.expiredDate == true) {\r\n      new Date(value) < new Date()\r\n        ? (rowClass = rowClass + ' text-red-400 font-semibold')\r\n        : '';\r\n    }\r\n    return rowClass;\r\n  }\r\n\r\n  // Não é usada\r\n  private expiredFile(rowData: any, col: TableConfigColumn): boolean {\r\n    let value = rowData['datavencimento'];\r\n    return new Date(value) < new Date() && col.field == 'area';\r\n  }\r\n\r\n  transformValue(rowData: any, col: TableConfigColumn) {\r\n    let value = rowData[col.field];\r\n\r\n    if (col.transform) {\r\n      return col.transform(value);\r\n    }\r\n\r\n    if ((value == null || value === '' || value === undefined) && this.replaceEmptyValues && this.isLoadingSkeleton()) {\r\n      return '-';\r\n    }\r\n\r\n    if (value != null) {\r\n      if (!col.pipe) {\r\n        return value;\r\n      }\r\n\r\n      switch (col.pipe) {\r\n        case 'date':\r\n          return this.datePipe.transform(value, 'dd/MM/yyyy', 'UTC');\r\n        case 'datetime':\r\n          return this.datePipe.transform(value, 'dd/MM/yyyy HH:mm');\r\n        case 'dateMonthYear':\r\n          return this.datePipe.transform(value, 'MM/yyyy');\r\n        case 'decimal':\r\n          return this.decimalPipe.transform(value, '1.2-2', 'pt-BR');\r\n        case 'cpfcnpj':\r\n          return this.cpfCnpjPipe.transform(value);\r\n        case 'telefone':\r\n          return this.telefonePipe.transform(value);\r\n        case 'capitalize':\r\n          return this.transformCapitalize(value);\r\n        case 'money':\r\n          return this.formatarValor(value);\r\n        case 'percentage':\r\n          return `${value} % `;\r\n\r\n        default:\r\n          break;\r\n      }\r\n    }\r\n  }\r\n\r\n  // transformDate(date: any) {\r\n  //   const datePipe = new DatePipe('en-US');\r\n  //   const utcDate = new Date(date);\r\n\r\n  //   // Ajuste a data para o fuso horário local\r\n  //   const localDate = new Date(utcDate.getTime() + (utcDate.getTimezoneOffset() * 60000));\r\n\r\n  //   console.log('localDate', localDate, \"input date\", date);\r\n\r\n  //   // Transforme a data local para o formato desejado\r\n  //   return datePipe.transform(localDate, 'dd/MM/yyyy');\r\n  // }\r\n\r\n  transformCapitalize(value: string): string {\r\n    if (!value) return value;\r\n\r\n    return value.split(' ').map((word, index) => {\r\n      const wordUpper = word.toUpperCase();\r\n      const wordLower = word.toLocaleLowerCase();\r\n\r\n      // Verifica numerais romanos\r\n      if (this.romanNumerals.has(wordUpper)) {\r\n        return word;\r\n      }\r\n\r\n      // Verifica siglas\r\n      if (this.siglas.has(wordUpper)) {\r\n        return word;\r\n      }\r\n\r\n      // Verifica preposições, mas não altera a primeira palavra\r\n      if (index !== 0 && this.prepositions.has(wordLower)) {\r\n        return wordLower;\r\n      }\r\n\r\n      // Capitaliza a primeira letra das demais palavras\r\n      return word.charAt(0).toLocaleUpperCase() + word.slice(1).toLocaleLowerCase();\r\n    }).join(' ');\r\n  }\r\n\r\n  formatarValor(valor: number): string {\r\n    const formatter = new Intl.NumberFormat('pt-BR', {\r\n      style: 'currency',\r\n      currency: 'BRL',\r\n    });\r\n\r\n    return formatter.format(valor);\r\n  }\r\n\r\n  adjustTableSize() {\r\n    if (this.tableSize < 800) {\r\n      this.selectedSize = 'p-datatable-sm';\r\n    } else {\r\n      this.selectedSize = '';\r\n    }\r\n  }\r\n\r\n  doubleClick(e: any, rowData: any) {\r\n    let eventDoubleClick = { event: e, rowData: rowData };\r\n\r\n    let array: string[] = [];\r\n    e.target.classList.forEach((x: any) => array.push(x));\r\n\r\n    this.doubleClickEvent.emit(eventDoubleClick);\r\n  }\r\n\r\n  // alignColunas(col: any): string {\r\n  //   if (col.align) {\r\n  //     return `text - align: ${ col.align } `;\r\n  //   } else return '';\r\n  // }\r\n\r\n  // alignColunasHeader(col: any): string {\r\n  //   if (col.align) {\r\n  //     if (col.align == 'right') return 'justify-content: end';\r\n  //     else return '';\r\n  //   } else return '';\r\n  // }\r\n\r\n  retornarRow(rowData: any, col: TableConfigColumn, field: string): string {\r\n    const _rowaction = this.config.rows ? this.config.rows[col.field] : null;\r\n    const _field: string =\r\n      _rowaction && _rowaction[field]\r\n        ? _rowaction[field].constructor === Function\r\n          ? _rowaction[field].apply(this, [rowData])\r\n          : _rowaction[field]\r\n        : null;\r\n    return _field;\r\n  }\r\n\r\n  // Não é usado\r\n  private exibirCampo(field: any, rowData: any) {\r\n    let visible = field.visible ? field.visible(rowData) : true;\r\n\r\n    return visible;\r\n  }\r\n\r\n  returnClassChip(rowData: any, col: TableConfigColumn): string {\r\n    return `chip - style w - auto border - round - 2xl p - 2 text - ${this.retornarRow(\r\n      rowData,\r\n      col,\r\n      'stylechip'\r\n    )\r\n      } border - ${this.retornarRow(rowData, col, 'stylechip')} `;\r\n  }\r\n\r\n  returnClassIcon(rowData: any, col: TableConfigColumn): string {\r\n    return this.retornarRow(rowData, col, 'iconrow');\r\n  }\r\n\r\n  returnTooltipIcon(rowData: any, col: TableConfigColumn): string {\r\n    return this.retornarRow(rowData, col, 'tooltipiconrow');\r\n  }\r\n\r\n  returnTooltipRow(rowData: any, col: TableConfigColumn): any {\r\n    return this.retornarRow(rowData, col, 'tooltiprow');\r\n  }\r\n\r\n  deleteColumn(field: string) {\r\n    let index: number;\r\n\r\n    let column: TableConfigColumn | undefined = this.config.columns.find(\r\n      x => x.field == field\r\n    );\r\n    if (column) {\r\n      index = this.config.columns.indexOf(column);\r\n      this.config.columns.splice(index, 1);\r\n      this.deletedColuns.push(column);\r\n    }\r\n  }\r\n\r\n  addColumn(field: string) {\r\n    let index: number;\r\n\r\n    let column: TableConfigColumn | undefined = this.config.columns.find(\r\n      (x) => x.field == field\r\n    );\r\n\r\n    if (!column) {\r\n      let deletedColumn: TableConfigColumn | undefined =\r\n        this.deletedColuns.find((x) => x.field == field);\r\n\r\n      if (deletedColumn != undefined) {\r\n        index = this.deletedColuns.indexOf(deletedColumn);\r\n        this.deletedColuns.slice(index, 1);\r\n        this.config.columns.push(deletedColumn);\r\n      }\r\n    }\r\n  }\r\n\r\n  dinamicColumnSet(e: any, col: TableConfigColumn) {\r\n    col.checked = e.checked;\r\n    if (e.checked) this.addColumn(col.field);\r\n    else this.deleteColumn(col.field);\r\n\r\n    if (col.position) this.config.columns.sort(this.sortByPosition());\r\n  }\r\n\r\n  abrirMenuFiltro(e: any) {\r\n    this.menuFiltro = !this.menuFiltro;\r\n    this.checkboxClicked = false;\r\n\r\n    if (this.widthPage() < 700)\r\n      this.styleSetter(\r\n        'left',\r\n        this.botaoFiltro.nativeElement.offsetLeft - 288 + 'px'\r\n      );\r\n    else\r\n      this.styleSetter(\r\n        'left',\r\n        this.botaoFiltro.nativeElement.offsetLeft + 40 + 'px'\r\n      );\r\n\r\n    this.styleSetter('top', this.botaoFiltro.nativeElement.offsetTop + 'px');\r\n    this.styleSetter('visibility', this.menuFiltro ? 'visible' : 'hidden');\r\n  }\r\n\r\n  fecharMenuFiltro() {\r\n    this.menuFiltro = false;\r\n    this.checkboxClicked = false;\r\n\r\n    this.styleSetter('visibility', 'hidden');\r\n  }\r\n\r\n  @HostListener('document:keydown.escape', ['$event'])\r\n  onEscapeKey(event: KeyboardEvent) {\r\n    if (this.filterColumnsBtn == true && this.menuFiltro == true) {\r\n      this.fecharMenuFiltro();\r\n    }\r\n  }\r\n\r\n  @HostListener('document:click', ['$event'])\r\n  onClickEvent(event: any) {\r\n    if (this.filterColumnsBtn == true && this.menuFiltro == true) {\r\n      const clickedElement = event.target as HTMLElement;\r\n      const menuFiltroDiv =\r\n        this.elementRef.nativeElement.querySelector('#menuFiltroDiv');\r\n      const botaoFiltro =\r\n        this.elementRef.nativeElement.querySelector('#botaoFiltro');\r\n      const isCheckboxClicked =\r\n        clickedElement.classList.toString().includes('p-checkbox') ||\r\n        event.target.classList.toString() == '';\r\n      const isInsideMenu =\r\n        menuFiltroDiv?.contains(clickedElement) ||\r\n        botaoFiltro?.contains(clickedElement) ||\r\n        isCheckboxClicked;\r\n\r\n      if (!isInsideMenu) this.fecharMenuFiltro();\r\n    }\r\n  }\r\n\r\n  styleSetter(style: string, data: string) {\r\n    this.renderer?.setStyle(this.menuFiltroDiv.nativeElement, style, data);\r\n  }\r\n\r\n  checkMenuFiltro(col: TableConfigColumn) {\r\n    let deletedColumn = this.deletedColuns.find(\r\n      x => x.field == col.field\r\n    );\r\n    if (deletedColumn) col.checked = false;\r\n    else col.checked = true;\r\n  }\r\n\r\n  sortByPosition() {\r\n    return function (elem1: any, elem2: any) {\r\n      if (elem1.position < elem2.position) {\r\n        return -1;\r\n      } else if (elem1.position > elem2.position) {\r\n        return 1;\r\n      } else {\r\n        return 0;\r\n      }\r\n    };\r\n  }\r\n\r\n  dinamicDisableColumn(col: TableConfigColumn): boolean {\r\n    if (col.fixedColumn) return col.fixedColumn;\r\n    else return false;\r\n  }\r\n\r\n  checkHideColumns() {\r\n    let hideColumnsConfig = this.columns.filter(\r\n      col => col.hideColumn == true\r\n    );\r\n    hideColumnsConfig.forEach(col => this.deleteColumn(col.field));\r\n  }\r\n\r\n  getCustomTemplate(templatename: string): TemplateRef<any> {\r\n    return this._templates[templatename];\r\n  }\r\n\r\n  onSwitchChange(estado: any, rowData: any, col: TableConfigColumn) {\r\n    this.onSwitchTableChange.emit({\r\n      estado: estado,\r\n      rowData: rowData,\r\n      col: col,\r\n    });\r\n\r\n    rowData[col.field] = estado;\r\n  }\r\n\r\n  createTableActions() {\r\n    this.tableActions = this.dataSource?.map((x) =>\r\n      this.config.actions\r\n        ? this.config.actions.map((y) => mapToMenuItem(y, x))\r\n        : []\r\n    );\r\n  }\r\n\r\n  onSort(e: any) {\r\n    this.dataSource = [...this.dataSource];\r\n  }\r\n\r\n  get config(): TableConfig {\r\n    return this.tableConfig()!;\r\n  }\r\n\r\n  columnsFilter = computed(() => {\r\n    const dynamicColumns = (this.tableConfig()?.columns ?? []).filter(col => !col.fixedColumn);\r\n\r\n    return [...dynamicColumns, ...this.deletedColuns];\r\n  });\r\n\r\n  returnMaxWidth = computed(() => (widthCol: string) => {\r\n    let widthTable = this.tableCell()?.nativeElement.parentElement.offsetWidth;\r\n    let percent = Number(widthCol.replace('%', ''));\r\n\r\n    let widthCalc = widthTable * percent / 100;\r\n\r\n    return `${widthCalc}px`;\r\n  })\r\n}\r\n","<div class=\"kv-table-container\">\r\n  @if (config) {\r\n  <p-table\r\n    #dt\r\n    styleClass=\"p-datatable-sm\"\r\n    [value]=\"dataSource\"\r\n    [(selection)]=\"selectedItems\"\r\n    [rowSelectable]=\"isRowSelectable\"\r\n    [columns]=\"config.columns\"\r\n    [globalFilterFields]=\"globalFilterFields\"\r\n    [rows]=\"rows()\"\r\n    [paginator]=\"paginator\"\r\n    [rowsPerPageOptions]=\"rowsPerPageOptions\"\r\n    [showCurrentPageReport]=\"true\"\r\n    currentPageReportTemplate=\"{first} - {last} de {totalRecords}\"\r\n    [rowHover]=\"true\"\r\n    [totalRecords]=\"totalRecords\"\r\n    [lazy]=\"config.lazy\"\r\n    [first]=\"first()\"\r\n    (onLazyLoad)=\"paginate($event)\"\r\n    (selectionChange)=\"selectionChange($event)\"\r\n    (onSort)=\"onSort($event)\"\r\n    (onPage)=\"onPage($event)\"\r\n    rowGroupMode=\"rowspan\"\r\n    [groupRowsBy]=\"config.fieldGroup\"\r\n    [showFirstLastIcon]=\"widthPage() > 960 ? true : false\"\r\n    [pageLinks]=\"widthPage() > 960 ? 2 : 1\"\r\n    [responsive]=\"true\"\r\n    [responsiveLayout]=\"responsiveLayout ? 'stack' : ''\"\r\n    [scrollable]=\"isTableScrollable\"\r\n    [scrollHeight]=\"scrollHeight\"\r\n    [rowTrackBy]=\"rowTrackBy\"\r\n  >\r\n    @if (config?.enableCation) {\r\n    <ng-template pTemplate=\"caption\">\r\n      <div\r\n        class=\"flex flex-row flex-wrap justify-content-between grid formgrid p-fluid col-12 m-0 mb-2\"\r\n        [style.padding.rem]=\"0.1\"\r\n      >\r\n        <div class=\"col-12 flex flex-column\">\r\n          @if (config.title) {\r\n          <div class=\"text-md font-bold my-3\">\r\n            {{ config.title }}\r\n          </div>\r\n          } @if (config.subtitle) {\r\n          <div class=\"text-sm mb-4 font-medium\">\r\n            {{ config.subtitle }}\r\n          </div>\r\n          }\r\n        </div>\r\n\r\n        <div\r\n          class=\"flex flex-row align-items-center md:col-6 lg:col-4 {{\r\n            widthPage() < 768 ? 'col-10' : 'col-12'\r\n          }}  gap-1 p-0\"\r\n        >\r\n          @if (config?.enableFilter) {\r\n          <!-- <span class=\"p-input-icon-left\">\r\n            <i class=\"pi pi-search text-sm\"></i>\r\n\r\n            <input\r\n              pInputText\r\n              pAutoFocus\r\n              [autofocus]=\"widthPage() > 800\"\r\n              type=\"text\"\r\n              (input)=\"onGlobalFilter(dt, $event)\"\r\n              [placeholder]=\"searchPlaceholder\"\r\n              autocomplete=\"off\"\r\n              #inputField\r\n              class=\"text-sm \"\r\n            />\r\n          </span> -->\r\n          @if(autoFocusSearch) {\r\n            <input\r\n              pInputText\r\n              pAutoFocus\r\n              [autofocus]=\"widthPage() > 800\"\r\n              type=\"text\"\r\n              (input)=\"onGlobalFilter(dt, $event)\"\r\n              [placeholder]=\"searchPlaceholder\"\r\n              autocomplete=\"off\"\r\n              #inputField\r\n              class=\"text-sm col-6\"\r\n            />\r\n          } \r\n          @else {<input\r\n              pInputText\r\n              [autofocus]=\"widthPage() > 800\"\r\n              type=\"text\"\r\n              (input)=\"onGlobalFilter(dt, $event)\"\r\n              [placeholder]=\"searchPlaceholder\"\r\n              autocomplete=\"off\"\r\n              #inputField\r\n              class=\"text-sm col-6\"\r\n            />}\r\n\r\n          } @if(filterColumnsBtn) {\r\n          <div #botaoFiltro>\r\n            <kv-button\r\n              id=\"botaoFiltro\"\r\n              [icon]=\"'align_vertical_top'\"\r\n              (onClick)=\"abrirMenuFiltro($event)\"\r\n              severity=\"tertiary\"\r\n              pTooltip=\"Ocultar/Exibir colunas\"\r\n              size=\"small\"\r\n            >\r\n            </kv-button>\r\n          </div>\r\n\r\n          <div\r\n            #menuFiltroDiv\r\n            id=\"menuFiltroDiv\"\r\n            [style.visibility]=\"'hidden'\"\r\n            class=\"absolute z-4 bg-gray-200 menu-columns-filtro\"\r\n          >\r\n            <p-card styleClass=\"p-1\">\r\n              <div\r\n                class=\"flex flex-column text-medium w-15rem p-1\"\r\n                *ngFor=\"let col of columnsFilter()\"\r\n              >\r\n                {{ checkMenuFiltro(col) }}\r\n                <p-checkbox\r\n                  #filterColumns\r\n                  [label]=\"col.header\"\r\n                  [binary]=\"true\"\r\n                  class=\"checkbox-container\"\r\n                  (onChange)=\"dinamicColumnSet($event, col)\"\r\n                  [(ngModel)]=\"col.checked\"\r\n                  *ngIf=\"!dinamicDisableColumn(col)\"\r\n                ></p-checkbox>\r\n              </div>\r\n            </p-card>\r\n          </div>\r\n          } @if(filterButton()) {\r\n          <!-- <p-button\r\n            styleClass=\"kv-button small tertiary text-xs font-medium\"\r\n            label=\"Filtrar\"\r\n            icon=\"pi pi-filter\"\r\n            [badge]=\"filterButtonBadge()\"\r\n            badgeClass=\"text-gray-800\"\r\n            class=\"text-xs\"\r\n            (onClick)=\"op.toggle($event)\"\r\n          ></p-button> -->\r\n\r\n             <kv-button\r\n              label=\"Filtrar\"\r\n              icon=\"filter_alt\"\r\n              severity=\"tertiary\"\r\n              (onClick)=\"toggleOverlayPanel($event)\"\r\n            ></kv-button>\r\n          }\r\n\r\n          <p-overlayPanel #op [dismissable]=\"false\">\r\n            <ng-content select=\"[filtro]\"> </ng-content>\r\n          </p-overlayPanel>\r\n        </div>\r\n\r\n        <div class=\"flex flex-row col-2 justify-content-end gap-2 p-0\">\r\n          @for (action of config.actionsLote; track i; let i = $index) {\r\n          <div class=\"flex align-items-center justify-content-center\">\r\n            @if ((selectedItems.length > 0 || action.showAcoesLote) &&\r\n            (getOrExecute(action.visible, selectedItems) ?? true)) {\r\n            <kv-button\r\n              (onClick)=\"action?.command(); activeItemLote(selectedItems)\"\r\n              [pTooltip]=\"getOrExecute(action.tooltip, selectedItems)\"\r\n              [tooltipPosition]=\"'left'\"\r\n              [disabled]=\"getOrExecute(action.disabled, selectedItems) || false\"\r\n              [icon]=\"getOrExecute(action.icon, selectedItems)\"\r\n              [severity]=\"action.severity || 'tertiary'\"\r\n              size=\"small\"\r\n              [label]=\"getOrExecute(action.label, selectedItems) || ''\"\r\n              [items]=\"action.items || []\"\r\n              [popup]=\"(action.items && action.items.length > 0) || false\"\r\n            />\r\n            }\r\n          </div>\r\n          }\r\n        </div>\r\n      </div>\r\n    </ng-template>\r\n    }\r\n\r\n    <ng-template pTemplate=\"header\" let-columns>\r\n      <tr>\r\n        @if (config.enableSelect) {\r\n        <th>\r\n          <p-tableHeaderCheckbox\r\n            (click)=\"activeItemLote(selectedItems)\"\r\n            [disabled]=\"disabledHeaderCheckbox\"\r\n          ></p-tableHeaderCheckbox>\r\n        </th>\r\n        } @for (col of columns; track $index) {\r\n        <th\r\n          [pSortableColumn]=\"col.field\"\r\n          [pSortableColumnDisabled]=\"col.sortable === false\"\r\n          [style.width]=\"col.width\"\r\n        >\r\n          <div\r\n            class=\"flex flex-row align-items-center {{\r\n              col?.centralize && 'justify-content-center'\r\n            }}\"\r\n          >\r\n            <span class=\"text-xs font-semibold\">{{ col.header }}</span>\r\n            @if (col.sortable) {\r\n            <p-sortIcon [field]=\"col.field\" class=\"pb-1\"></p-sortIcon>\r\n            } @if (col.headerTooltip) {\r\n            <span\r\n              class=\"material-symbols-outlined flex align-items-center\"\r\n              [pTooltip]=\"col.headerTooltip\"\r\n              >info</span\r\n            >\r\n            }\r\n          </div>\r\n        </th>\r\n        } @if (config.actions && config.actions.length > 0) {\r\n        <th></th>\r\n        }\r\n      </tr>\r\n    </ng-template>\r\n\r\n    <ng-template\r\n      pTemplate=\"body\"\r\n      let-rowData\r\n      let-columns=\"columns\"\r\n      let-rowgroup=\"rowgroup\"\r\n      let-rowspan=\"rowspan\"\r\n      let-rowIndex=\"rowIndex\"\r\n    >\r\n      <tr\r\n        (dblclick)=\"doubleClick($event, rowData)\"\r\n        [ngClass]=\"{\r\n          capitalize: tableCaptalized,\r\n          last: rowIndex === dataSource.length - 1\r\n        }\"\r\n        class=\"tr-td {{ isDisabledRow(rowData) ? 'disabled-row' : '' }}\"\r\n      >\r\n        @if (config.enableSelect) {\r\n        <td style=\"width: 8px !important\">\r\n          <p-tableCheckbox\r\n            [value]=\"rowData\"\r\n            [disabled]=\"isDisabledCheckbox(rowData)\"\r\n            (click)=\"activeItemLote(selectedItems)\"\r\n          ></p-tableCheckbox>\r\n        </td>\r\n        } @for (col of columns; track $index) {\r\n        <ng-container>\r\n          @if (rowgroup && !col.template) {\r\n          <td\r\n            [attr.rowspan]=\"rowgroup && col.grouped ? rowspan : null\"\r\n            [pTooltip]=\"returnTooltipRow(rowData, col)\"\r\n            class=\"{{\r\n              col.styleClass\r\n                ? col.styleClass(rowData, col, rowData[col.field])\r\n                : ''\r\n            }}\"\r\n          >\r\n            <span class=\"p-column-title text-xs\">{{ col.header }}:</span>\r\n\r\n            <span\r\n              *ngIf=\"!isBooleanField(rowData, col); else booleanField\"\r\n              [class]=\"returnRowClass(rowData, col)\"\r\n            >\r\n              @if (!isChipField(col) && !col.iconField && !isImageField(col) &&\r\n              !isEmptyDataSource()) {\r\n              <span\r\n                class=\"flex flex-row gap-2 align-items-center {{\r\n                  col?.centralize && 'justify-content-center'\r\n                }} text-xs {{ ellipsisText() && 'ellipsis-text' }}\"\r\n                [pTooltip]=\"\r\n                  col.tooltip && col.tooltip(rowData, col, rowData[col.field])\r\n                \"\r\n                [tooltipPosition]=\"'bottom'\"\r\n                [style.max-width]=\"\r\n                  ellipsisText() && returnMaxWidth()(col.width)\r\n                \"\r\n              >\r\n                @if(col.tagColor) {\r\n                <div\r\n                  class=\"tag\"\r\n                  [pTooltip]=\"\r\n                    col.tooltipTag &&\r\n                    col.tooltipTag(rowData, col, rowData[col.field])\r\n                  \"\r\n                  [style.background-color]=\"\r\n                    col.tagColor(rowData, col, rowData[col.field])\r\n                  \"\r\n                ></div>\r\n\r\n                } \r\n                <span class=\"text-xs {{ ellipsisText() && 'ellipsis-text' }}\">\r\n                  @if (col.icon) {\r\n                  <i [class]=\"col.icon + ' mr-2'\"></i>\r\n                  }\r\n                  {{ transformValue(rowData, col) }} \r\n                </span>           \r\n              </span>\r\n              } @if (isChipField(col) && !col.iconField) {\r\n              <div>\r\n                <span\r\n                  [class]=\"returnClassChip(rowData, col)\"\r\n                  [pTooltip]=\"returnTooltipIcon(rowData, col)\"\r\n                  class=\"text-xs\"\r\n                  >{{ transformValue(rowData, col) }}</span\r\n                >\r\n              </div>\r\n              } @if(isEmptyDataSource() && this.isLoadingSkeleton()) {\r\n              <div class=\"w-full\">\r\n                @if(!isSwitchField(col)) {\r\n\r\n                <div\r\n                  class=\"w-full flex {{\r\n                    col.centralize && 'justify-content-center'\r\n                  }}\"\r\n                >\r\n                  <div [style.width]=\"widthRandom()(col, rowIndex) + '%'\">\r\n                    <p-skeleton styleClass=\"w-full\"></p-skeleton>\r\n                  </div>\r\n                </div>\r\n\r\n                } @else {\r\n                <div class=\"flex flex-row justify-content-center\">\r\n                  <div\r\n                    [style]=\"{\r\n                      height: '16.8px',\r\n                      width: '28.8px',\r\n                      'border-radius': '30px'\r\n                    }\"\r\n                  >\r\n                    <p-skeleton styleClass=\"w-full\"></p-skeleton>\r\n                  </div>\r\n                </div>\r\n                }\r\n              </div>\r\n              }\r\n            </span>\r\n\r\n            @if (isImageField(col)) {\r\n            <span>\r\n              <span>\r\n                <img class=\"image\" [src]=\"loadImage(rowData, col)\" />\r\n              </span>\r\n            </span>\r\n            } @if (col.iconField) {\r\n            <i\r\n              [ngClass]=\"{\r\n                'material-icons': col.indIconMaterial,\r\n                'material-symbols-outlined mr-2': !col.indIconMaterial\r\n              }\"\r\n              [pTooltip]=\"returnTooltipIcon(rowData, col)\"\r\n            >\r\n              {{ returnClassIcon(rowData, col) }}\r\n            </i>\r\n            }\r\n\r\n            <ng-template #booleanField>\r\n              @if (!col.iconField && !isSwitchField(col)) {\r\n              <div\r\n                class=\"flex flex-row gap-2 align-items-center {{\r\n                  col?.centralize && 'justify-content-center'\r\n                }}\"\r\n                [pTooltip]=\"\r\n                  col.tooltip && col.tooltip(rowData, col, rowData[col.field])\r\n                \"\r\n                [tooltipPosition]=\"'bottom'\"\r\n              >\r\n                <i\r\n                  [ngClass]=\"\r\n                    rowData[col.field] ? 'text-green-500' : 'text-red-500'\r\n                  \"\r\n                  ><span\r\n                    class=\"material-symbols-outlined text-lg font-semibold\"\r\n                  >\r\n                    {{ rowData[col.field] ? \"check\" : \"close\" }}\r\n                  </span>\r\n                </i>\r\n              </div>\r\n\r\n              } @if (isSwitchField(col)) {\r\n              <span\r\n                [class]=\"\r\n                  returnRowClass(rowData, col) +\r\n                  ' flex flex-row align-items-center justify-content-center'\r\n                \"\r\n                style=\"height: 25px\"\r\n              >\r\n                @if(col.switchDisable){\r\n                <kv-switch\r\n                  (onSwitchChange)=\"onSwitchChange($event, rowData, col)\"\r\n                  [disabled]=\"col.switchDisable(rowData, col)\"\r\n                  [switchValue]=\"transformValue(rowData, col)\"\r\n                >\r\n                </kv-switch>\r\n                } @else {\r\n                <kv-switch\r\n                  (onSwitchChange)=\"onSwitchChange($event, rowData, col)\"\r\n                  [disabled]=\"col?.onlyReadField ?? true\"\r\n                  [switchValue]=\"transformValue(rowData, col)\"\r\n                >\r\n                </kv-switch>\r\n                }\r\n              </span>\r\n              } @if(isEmptyDataSource() && this.isLoadingSkeleton()) {\r\n              <div class=\"w-full\">\r\n                @if(!isSwitchField(col)) {\r\n                <div\r\n                  class=\"w-full flex {{\r\n                    col.centralize && 'justify-content-center'\r\n                  }}\"\r\n                >\r\n                  <div [style.width]=\"widthRandom()(col, rowIndex) + '%'\">\r\n                    <p-skeleton styleClass=\"w-full\"></p-skeleton>\r\n                  </div>\r\n                </div>\r\n\r\n                } @else {\r\n                <div class=\"flex flex-row justify-content-center\">\r\n                  <div\r\n                    [style]=\"{\r\n                      height: '16.8px',\r\n                      width: '28.8px',\r\n                      'border-radius': '30px'\r\n                    }\"\r\n                  >\r\n                    <p-skeleton styleClass=\"w-full\"></p-skeleton>\r\n                  </div>\r\n                </div>\r\n                }\r\n              </div>\r\n              }\r\n            </ng-template>\r\n          </td>\r\n          } @if (!rowgroup && !col.grouped && !col.template) {\r\n          <td\r\n            #tableCell\r\n            class=\"rowTable {{\r\n              col.styleClass\r\n                ? col.styleClass(rowData, col, rowData[col.field])\r\n                : ''\r\n            }} \"\r\n            [pTooltip]=\"returnTooltipRow(rowData, col)\"\r\n          >\r\n            <span class=\"p-column-title text-xs\">{{ col.header }}:</span>\r\n\r\n            @if(!isEmptyDataSource()) {\r\n\r\n            <span\r\n              *ngIf=\"!isBooleanField(rowData, col); else booleanField\"\r\n              [class]=\"\r\n                returnRowClass(rowData, col) +\r\n                ' flex flex-row gap-2 align-items-center ' +\r\n                (col?.centralize && 'justify-content-center')\r\n              \"\r\n              [pTooltip]=\"\r\n                col.tooltip && col.tooltip(rowData, col, rowData[col.field])\r\n              \"\r\n              [tooltipPosition]=\"'bottom'\"\r\n              [style.max-width]=\"ellipsisText() && returnMaxWidth()(col.width)\"\r\n            >\r\n              @if(col.tagColor) {\r\n              <div\r\n                class=\"tag\"\r\n                [pTooltip]=\"\r\n                  col.tooltipTag &&\r\n                  col.tooltipTag(rowData, col, rowData[col.field])\r\n                \"\r\n                [style.background-color]=\"\r\n                  col.tagColor(rowData, col, rowData[col.field])\r\n                \"\r\n              ></div>\r\n\r\n              } @if (!isChipField(col) && !col.iconField && !isImageField(col)){\r\n              <span class=\"text-xs {{ ellipsisText() && 'ellipsis-text' }}\">\r\n                @if (col.icon) {\r\n                <i [class]=\"col.icon + ' mr-2'\"></i>\r\n                }\r\n                {{ transformValue(rowData, col) }}\r\n              </span>\r\n              } @if (isChipField(col) && !col.iconField) {\r\n              <div>\r\n                <span\r\n                  [class]=\"returnClassChip(rowData, col)\"\r\n                  [pTooltip]=\"returnTooltipIcon(rowData, col)\"\r\n                  class=\"text-xs\"\r\n                >\r\n                  {{ transformValue(rowData, col) }}</span\r\n                >\r\n              </div>\r\n              }\r\n            </span>\r\n            } @if (isImageField(col)) {\r\n            <span>\r\n              <span>\r\n                <img class=\"image\" [src]=\"loadImage(rowData, col)\" />\r\n              </span>\r\n            </span>\r\n            } @if (col.iconField) {\r\n            <i\r\n              [ngClass]=\"{\r\n                'material-icons': col.indIconMaterial,\r\n                'material-symbols-outlined mr-2': !col.indIconMaterial\r\n              }\"\r\n              [pTooltip]=\"returnTooltipIcon(rowData, col)\"\r\n            >\r\n              {{ returnClassIcon(rowData, col) }}\r\n            </i>\r\n            }\r\n\r\n            <ng-template #booleanField>\r\n              @if (!col.iconField && !isSwitchField(col)) {\r\n              <div\r\n                class=\"flex flex-row gap-2 align-items-center {{\r\n                  col?.centralize && 'justify-content-center'\r\n                }}\"\r\n                [pTooltip]=\"\r\n                  col.tooltip && col.tooltip(rowData, col, rowData[col.field])\r\n                \"\r\n                [tooltipPosition]=\"'bottom'\"\r\n              >\r\n                <i\r\n                  [ngClass]=\"\r\n                    rowData[col.field] ? 'text-green-500' : 'text-red-500'\r\n                  \"\r\n                  ><span\r\n                    class=\"material-symbols-outlined text-lg font-semibold\"\r\n                  >\r\n                    {{ rowData[col.field] ? \"check\" : \"close\" }}\r\n                  </span>\r\n                </i>\r\n              </div>\r\n              } @if (isSwitchField(col)) {\r\n\r\n              <span\r\n                [class]=\"\r\n                  returnRowClass(rowData, col) +\r\n                  ' flex flex-row align-items-center justify-content-center'\r\n                \"\r\n                style=\"height: 25px\"\r\n              >\r\n                @if(col.switchDisable){\r\n                <kv-switch\r\n                  (onSwitchChange)=\"onSwitchChange($event, rowData, col)\"\r\n                  [disabled]=\"col.switchDisable(rowData, col)\"\r\n                  [switchValue]=\"transformValue(rowData, col)\"\r\n                >\r\n                </kv-switch>\r\n                } @else {\r\n                <kv-switch\r\n                  (onSwitchChange)=\"onSwitchChange($event, rowData, col)\"\r\n                  [disabled]=\"col?.onlyReadField ?? true\"\r\n                  [switchValue]=\"transformValue(rowData, col)\"\r\n                >\r\n                </kv-switch>\r\n                }\r\n              </span>\r\n              }\r\n            </ng-template>\r\n\r\n            @if(isEmptyDataSource() && this.isLoadingSkeleton()) {\r\n            <div class=\"w-full\">\r\n              @if(!isSwitchField(col)) {\r\n              <div\r\n                class=\"w-full flex {{\r\n                  col.centralize && 'justify-content-center'\r\n                }}\"\r\n              >\r\n                <div [style.width]=\"widthRandom()(col, rowIndex) + '%'\">\r\n                  <p-skeleton styleClass=\"w-full\"></p-skeleton>\r\n                </div>\r\n              </div>\r\n\r\n              } @else {\r\n              <div class=\"flex flex-row justify-content-center\">\r\n                <div\r\n                  [style]=\"{\r\n                    height: '16.8px',\r\n                    width: '28.8px',\r\n                    'border-radius': '30px'\r\n                  }\"\r\n                >\r\n                  <p-skeleton styleClass=\"w-full\"></p-skeleton>\r\n                </div>\r\n              </div>\r\n              }\r\n            </div>\r\n            }\r\n          </td>\r\n          } @if (col.template) {\r\n          <td\r\n            class=\"rowTable {{\r\n              col.styleClass\r\n                ? col.styleClass(rowData, col, rowData[col.field])\r\n                : ''\r\n            }} \"\r\n          >\r\n            <span class=\"p-column-title text-xs\">{{ col.header }}:</span>\r\n            @if (getCustomTemplate(col.template.name)) {\r\n\r\n            <div\r\n              class=\"flex flex-row gap-2 align-items-center {{\r\n                col?.centralize && ' justify-content-center'\r\n              }}\"\r\n              [pTooltip]=\"\r\n                col.tooltip && col.tooltip(rowData, col, rowData[col.field])\r\n              \"\r\n              [tooltipPosition]=\"'bottom'\"\r\n            >\r\n              @if(col.tagColor) {\r\n              <div\r\n                class=\"tag\"\r\n                [pTooltip]=\"col.tooltipTag && col.tooltipTag(rowData, col)\"\r\n                [style.background-color]=\"col.tagColor(rowData, col)\"\r\n              ></div>\r\n              } @if(!isEmptyDataSource()) {\r\n\r\n              <div class=\"w-full\">\r\n                <ng-container\r\n                  [ngTemplateOutlet]=\"getCustomTemplate(col.template.name)\"\r\n                  [ngTemplateOutletContext]=\"{ $implicit: rowData }\"\r\n                />\r\n              </div>\r\n              }\r\n            </div>\r\n\r\n            @if(isEmptyDataSource() && this.isLoadingSkeleton()) {\r\n            <p-skeleton\r\n              [width]=\"widthRandom()(col, rowIndex) + '%'\"\r\n            ></p-skeleton>\r\n            } }\r\n          </td>\r\n          }\r\n        </ng-container>\r\n        } @if (config.actions && config.actions.length > 0) {\r\n        <td>\r\n          <div class=\"flex flex-row justify-content-end w-full\">\r\n            <span\r\n              class=\"material-symbols-outlined cursor-pointer icon-more\"\r\n              (click)=\"menu.toggle($event); activeItem(rowData)\"\r\n            >\r\n              <!-- more_vert -->\r\n              more_horiz\r\n            </span>\r\n\r\n            <p-tieredMenu\r\n              #menu\r\n              [popup]=\"true\"\r\n              [model]=\"tableActions[rowIndex - actionsOffset]\"\r\n              appendTo=\"body\"\r\n            >\r\n              <ng-template let-item pTemplate=\"item\">\r\n                <div\r\n                  [pTooltip]=\"item.tooltip\"\r\n                  tooltipPosition=\"left\"\r\n                  class=\"cursor-pointer\"\r\n                >\r\n                  <span class=\"text-xs\">\r\n                    {{ item.label }}\r\n                  </span>\r\n                </div>\r\n              </ng-template>\r\n            </p-tieredMenu>\r\n            <!-- <span pTooltip=\"{{ tableActions[rowIndex - actionsOffset][0]?.tooltip }}\" tooltipPosition=\"top\">a</span> -->\r\n          </div>\r\n        </td>\r\n        }\r\n      </tr>\r\n    </ng-template>\r\n\r\n    @if(emptyImage()) {\r\n      <ng-template pTemplate=\"emptymessage\" let-columns>\r\n        <tr>\r\n          <td [attr.colspan]=\"columns.length + 2\">\r\n            <div\r\n              class=\"w-full h-full flex align-items-center justify-content-center\"\r\n            >\r\n              <img [src]=\"emptyTableImg()\" class=\"h-10rem w-auto\" />\r\n            </div>\r\n          </td>\r\n        </tr>\r\n      </ng-template>\r\n    } @else {\r\n      <ng-template pTemplate=\"emptymessage\" let-columns>\r\n        <tr>\r\n          <td\r\n            [attr.colspan]=\"columns.length + 2\"\r\n            style=\"text-align: center; border-radius: 10px !important\"\r\n          >\r\n            <p class=\"font-medium m-0 text-xs\">Nenhum registro encontrado</p>\r\n          </td>\r\n        </tr>\r\n      </ng-template>\r\n    }\r\n  </p-table>\r\n  }\r\n</div>\r\n\r\n<link\r\n  rel=\"stylesheet\"\r\n  href=\"https://fonts.googleapis.com/icon?family=Material+Icons\"\r\n/>\r\n\r\n<link\r\n  rel=\"stylesheet\"\r\n  href=\"https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@48,400,0,0\"\r\n/>\r\n"]}
|
|
751
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-table.component.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/components/kv-table/kv-table.component.ts","../../../../../../projects/keevo-components/src/lib/components/kv-table/kv-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DatePipe, DecimalPipe } from '@angular/common';\r\n\r\nimport {\r\n  AfterViewInit,\r\n  Component,\r\n  ContentChildren,\r\n  DoCheck,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostListener,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  QueryList,\r\n  Renderer2,\r\n  TemplateRef,\r\n  ViewChild,\r\n  computed,\r\n  effect,\r\n  input,\r\n  model,\r\n  signal,\r\n  viewChild,\r\n} from '@angular/core';\r\n\r\nimport { MenuItem } from 'primeng/api';\r\nimport { Table, TablePageEvent } from 'primeng/table';\r\n\r\nimport { CpfCnpjPipe } from '../../api/pipes/cpfcnpj.pipe';\r\nimport {\r\n  getOrExecute,\r\n  ValueOrFn,\r\n  mapToMenuItem,\r\n} from '../../api/components/table/kv-menuitem';\r\nimport { TableConfig } from '../../api/components/table/table.config';\r\nimport { TableConfigColumn } from '../../api/components/table/table.config.column';\r\nimport { TablePaginate } from '../../api/components/table/table.paginate';\r\nimport { TelefonePipe } from '../../api/pipes/telefone.pipe';\r\nimport { TemplateDirective } from '../../api/directives/template/template.directive';\r\nimport { OverlayPanel } from 'primeng/overlaypanel';\r\n\r\n\r\nconst imgDefault =\r\n  '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';\r\n\r\n@Component({\r\n  selector: 'kv-table',\r\n  templateUrl: './kv-table.component.html',\r\n  styleUrls: ['./kv-table.component.scss'],\r\n})\r\nexport class KvTableComponent implements OnInit, DoCheck, AfterViewInit {\r\n  private readonly tableConfig = signal<TableConfig | undefined>(undefined);\r\n\r\n\r\n\r\n\r\n  globalFilterFields: string[] = [];\r\n\r\n  selectedSize: string = '';\r\n\r\n  widthPage = signal<number>(0);\r\n\r\n  checked: boolean = true;\r\n\r\n  columns: TableConfigColumn[] = [];\r\n  deletedColuns: TableConfigColumn[] = [];\r\n\r\n  private prepositions = new Set<string>([\r\n    'de', 'da', 'do', 'em', 'no', 'na', 'para', 'por', 'com', 'a', 'o', 'e'\r\n  ]);\r\n\r\n  private romanNumerals = new Set<string>([\r\n    'I', 'II', 'III', 'IV', 'V', 'VI', 'VII', 'VIII', 'IX', 'X', 'XI', 'XII', 'XIII', 'XIV', 'XV',\r\n    'XVI', 'XVII', 'XVIII', 'XIX', 'XX'\r\n  ]);\r\n\r\n  private siglas = new Set<string>([\r\n    'UI', 'UX', 'TI'\r\n  ]);\r\n\r\n  private overlayElement: HTMLElement | null = null;\r\n\r\n  menuFiltro: boolean = false;\r\n  checkboxClicked: boolean = false;\r\n\r\n  @Input() searchPlaceholder: string = 'Pesquisar...';\r\n\r\n  collapsed: boolean = false;\r\n\r\n  tableActions: MenuItem[][] = [];\r\n  currDataSource: any[] = [];\r\n\r\n  menuItems!: MenuItem[];\r\n\r\n  actionsOffset: number = 0;\r\n\r\n  @ContentChildren(TemplateDirective) templates!: QueryList<any>;\r\n  @Input('templates') _templates!: any;\r\n\r\n  @ViewChild('table', { static: false }) table!: Table;\r\n\r\n  @ViewChild(Table) ptable!: Table;\r\n\r\n  @ViewChild('op') op!: OverlayPanel;\r\n\r\n  @Input('config') set setConfig(value: TableConfig) {\r\n    this.tableConfig.set({\r\n      enableCation: value.enableCation || true,\r\n      enableSelect: value.enableSelect || false,\r\n      enableFilter: value.enableFilter || true,\r\n      ...value,\r\n    });\r\n\r\n    this.definirColunasConfiguraveis(this.tableConfig()!);\r\n  }\r\n\r\n  first = model<number>(0);\r\n  rows = model<number>(5);\r\n\r\n  @Input() defaultSortField: string | undefined = undefined;\r\n  @Input() dataSource: any[] = [];\r\n  @Input() selectedItems: any[] = [];\r\n  @Input() totalRecords!: number;\r\n  @Input() paginator: boolean = true;\r\n  @Input() rowsPerPageOptions!: number[];\r\n  @Input() tableSize!: number;\r\n  @Input() filterColumnsBtn: boolean = false;\r\n  @Input() replaceEmptyValues: boolean = true;\r\n  @Input() autoFocusSearch: boolean = true;\r\n\r\n\r\n  /**\r\n   * @deprecated Essa propriedade não será mais utilizada por esse componente nas próximas versões.\r\n   */\r\n  @Input() filtrosAvancados: boolean = false;\r\n\r\n  @Input() scrollHeight: string = '';\r\n  @Input() isTableScrollable: boolean = false;\r\n  @Input() tableCaptalized: boolean = false;\r\n\r\n  @Input() rowTrackBy: (index: number, item: any) => any = (index: number, item: any) => item;\r\n\r\n  @Input() responsiveLayout: boolean = true;\r\n\r\n  @Input() disabledHeaderCheckbox: boolean = false;\r\n\r\n  /**\r\n   * @deprecated Use a propriedade \"tagColor\" na configuração da coluna para estilizar a tag\r\n   */\r\n  @Input() applyStyle: Function = (rowData: any, col: TableConfigColumn) => '';\r\n\r\n  /**\r\n   * @deprecated O valor de pageLinks é atribuído de acordo com o tamanho da tela, essa propriedade não está sendo utilizada\r\n   */\r\n  @Input() pageLinksOptions!: number;\r\n\r\n  /**\r\n   * @deprecated A quantidade de paginitorPageIcons é atribuído de acordo com o tamanho da tela, essa propriedade não está sendo utilizada\r\n   */\r\n  @Input() showFirstLastIcon!: boolean;\r\n\r\n  @Output() onActiveItem: EventEmitter<any> = new EventEmitter();\r\n  @Output() onActiveItemLote: EventEmitter<any> = new EventEmitter();\r\n  @Output() onPaginate: EventEmitter<TablePaginate> = new EventEmitter();\r\n  @Output() onSelectionChange: EventEmitter<any> = new EventEmitter();\r\n  @Output() doubleClickEvent: EventEmitter<any> = new EventEmitter();\r\n  @Output() filterField: EventEmitter<any> = new EventEmitter();\r\n  @Output() onSwitchTableChange: EventEmitter<any> = new EventEmitter();\r\n\r\n  @ViewChild('menuFiltroDiv') menuFiltroDiv!: ElementRef;\r\n  @ViewChild('botaoFiltro') botaoFiltro!: ElementRef;\r\n  @ViewChild('inputField') inputField!: ElementRef;\r\n\r\n  tableCell = viewChild<ElementRef>('tableCell');\r\n  ellipsisText = input<boolean>(false);\r\n  isLoadingSkeleton = input<boolean>(false);\r\n\r\n  filterButton = input<boolean>(false);\r\n  filterButtonBadge = input<string>('');\r\n\r\n  emptyImage = input<boolean>(false);\r\n\r\n  @HostListener('document:click', ['$event'])\r\n  onClickOutside(event: MouseEvent) {\r\n    if (!this.op || !this.op.overlayVisible) {\r\n      return;\r\n    }\r\n\r\n    const targetElement = event.target as HTMLElement;\r\n\r\n    const filterButton = this.elementRef.nativeElement.querySelector('[label=\"Filtrar\"]');\r\n    if (filterButton && filterButton.contains(targetElement)) {\r\n      return;\r\n    }\r\n\r\n    if (targetElement.closest('.p-overlaypanel')) {\r\n      return;\r\n    }\r\n  }\r\n\r\n\r\n  constructor(\r\n    private readonly datePipe: DatePipe,\r\n    private readonly decimalPipe: DecimalPipe,\r\n    private readonly cpfCnpjPipe: CpfCnpjPipe,\r\n    private readonly telefonePipe: TelefonePipe,\r\n    private renderer: Renderer2,\r\n    private elementRef: ElementRef\r\n  ) {\r\n    this.isRowSelectable = this.isRowSelectable.bind(this);\r\n  }\r\n\r\n  configuracaoEffect = effect(() => {\r\n    const config = this.tableConfig()!;\r\n    this.definirFiltrosGlobais(config);\r\n    this.definirColunasConfiguraveis(config);\r\n  });\r\n\r\n  dataSourceSignal = signal<any[]>([]);\r\n\r\n  widthSkeletons: number[] = [];\r\n\r\n  widthRandom = computed(() => (col: any, row: any) => {\r\n    if (!col.template && !col.icon && !col.fieldType && !col.boolean && !col.pipe) {\r\n      return this.widthSkeletons[row] * 100;\r\n    } else {\r\n      return 100;\r\n    }\r\n  });\r\n\r\n  emptyTableImg = input<string>('https://work-assets.keevo.com.br/img/Nenhum_registro_localizado.png');\r\n\r\n  ngDoCheck(): void {\r\n    if (\r\n      JSON.stringify(this.dataSource) !== JSON.stringify(this.currDataSource)\r\n    ) {\r\n      if (this.dataSource) {\r\n        this.createTableActions();\r\n        this.currDataSource = [...this.dataSource];\r\n        this.dataSource = [...this.dataSource];\r\n        this.dataSourceSignal.set([...this.dataSource]);\r\n      }\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.removeOverlay();\r\n  }\r\n\r\n  dataSourceMock: any[] = [];\r\n\r\n  isEmptyDataSource = computed(() => {\r\n    return JSON.stringify(this.dataSourceSignal()) === JSON.stringify(this.dataSourceMock);\r\n  })\r\n\r\n  loadingSkeletonUtilities() {\r\n    if (this.dataSource.length === 0 && this.isLoadingSkeleton()) {\r\n      let rowItem: any = {};\r\n      this.tableConfig()?.columns.forEach((col) => {\r\n        rowItem[col.field] = '';\r\n      });\r\n\r\n      this.dataSourceMock = Array(this.rows()).fill({ ...rowItem });\r\n      this.dataSource = this.dataSourceMock;\r\n\r\n      for (let i = 0; i < this.rows(); i++) {\r\n        this.widthSkeletons.push(Math.random() * 0.7 + 0.2);\r\n      }\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.loadingSkeletonUtilities();\r\n    this.adjustTableSize();\r\n    this.widthPage.set(window.innerWidth);\r\n    // this.criarMenuColumns();\r\n    this.config.columns.forEach(col => {\r\n      this.columns.push(col);\r\n    });\r\n    this.checkHideColumns();\r\n    const defaultSortField = this.defaultSortField;\r\n    if (defaultSortField && this.dataSource) {\r\n      this.dataSource.sort((a, b) => {\r\n        if (\r\n          typeof a[defaultSortField] === 'string' &&\r\n          typeof b[defaultSortField] === 'string'\r\n        ) {\r\n          return (a[defaultSortField] as string).localeCompare(\r\n            (b[defaultSortField] as string)\r\n          );\r\n        } else if (\r\n          typeof a[defaultSortField] === 'boolean' &&\r\n          typeof b[defaultSortField] === 'boolean'\r\n        ) {\r\n          return a[defaultSortField] === b[defaultSortField]\r\n            ? 0\r\n            : a[defaultSortField]\r\n              ? 1\r\n              : -1;\r\n        } else if (\r\n          typeof a[defaultSortField] === 'number' &&\r\n          typeof b[defaultSortField] === 'number'\r\n        ) {\r\n          return (a[defaultSortField] as number) - (b[defaultSortField] as number);\r\n        } else {\r\n          return 0; // Ou outra lógica dependendo do caso\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    document.querySelectorAll('.disabled-row').forEach(row => {\r\n      row.querySelectorAll('td').forEach(cell => {\r\n        cell.addEventListener('click', event => {\r\n          const target = event.target as HTMLElement;\r\n          if (!target.classList.contains('tooltip')) {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n          }\r\n        });\r\n      });\r\n    });\r\n  }\r\n\r\n  toggleOverlayPanel(event: Event) {\r\n    event.stopPropagation();\r\n    this.op.toggle(event);\r\n\r\n    setTimeout(() => {\r\n      if (this.op.overlayVisible) {\r\n        this.createOverlay();\r\n      } else {\r\n        this.removeOverlay();\r\n      }\r\n    }, 0);\r\n  }\r\n\r\n  private createOverlay() {\r\n    if (this.overlayElement) {\r\n      return;\r\n    }\r\n\r\n    this.overlayElement = this.renderer.createElement('div');\r\n    this.renderer.addClass(this.overlayElement, 'filter-overlay');\r\n\r\n    this.renderer.listen(this.overlayElement, 'click', () => {\r\n      this.closeFilter();\r\n    })\r\n\r\n    this.renderer.appendChild(document.body, this.overlayElement);\r\n  }\r\n\r\n  removeOverlay() {\r\n    if (this.overlayElement) {\r\n      this.renderer.removeChild(document.body, this.overlayElement);\r\n      this.overlayElement = null;\r\n    }\r\n  }\r\n\r\n\r\n  public closeFilter() {\r\n    this.op?.hide();\r\n    this.removeOverlay();\r\n  }\r\n\r\n\r\n  definirColunasConfiguraveis(config: TableConfig) {\r\n    this.columns.splice(0, this.columns.length);\r\n\r\n    config.columns.forEach(col => {\r\n      this.columns.push(col);\r\n    });\r\n  }\r\n\r\n  definirFiltrosGlobais(config: TableConfig) {\r\n    if (config?.enableFilter) {\r\n\r\n      this.globalFilterFields.splice(0, this.globalFilterFields.length);\r\n\r\n      for (const column of config.columns) {\r\n        this.globalFilterFields.push(column.field);\r\n      }\r\n    }\r\n  }\r\n\r\n  resetTable() {\r\n    if (this.ptable) this.ptable.reset();\r\n    if (this.inputField) this.inputField.nativeElement.value = '';\r\n  }\r\n\r\n  @HostListener('window:resize', ['$event'])\r\n  onWindowResize() {\r\n    this.adjustTableSize();\r\n    this.widthPage.set(window.innerWidth);\r\n  }\r\n\r\n  public activeItem(rowData: any) {\r\n    this.onActiveItem.emit(rowData);\r\n  }\r\n\r\n  getOrExecute<T>(action: ValueOrFn<T>, data: any): T {\r\n    return getOrExecute(action, data);\r\n  }\r\n\r\n  isBooleanField(rowData: any, col: TableConfigColumn): boolean {\r\n    return typeof rowData[col.field] == 'boolean';\r\n  }\r\n\r\n  isChipField(col: TableConfigColumn): boolean {\r\n    return col.fieldType == 'chip';\r\n  }\r\n\r\n  protected onPage(event: TablePageEvent) {\r\n    this.first.set(event.first);\r\n    this.rows.set(event.rows);\r\n  }\r\n\r\n  isImageField(col: TableConfigColumn): boolean {\r\n    let retorno = col.fieldType && col.fieldType === 'image' ? true : false;\r\n    return retorno;\r\n  }\r\n\r\n  isSwitchField(col: TableConfigColumn): boolean {\r\n    let retorno = col.fieldType && col.fieldType === 'switch' ? true : false;\r\n    return retorno;\r\n  }\r\n\r\n  isRowSelectable(event: any) {\r\n    return !this.isDisabledCheckbox(event.data);\r\n  }\r\n\r\n  isDisabledCheckbox(rowData: any): boolean {\r\n    return this.config.disableControlCheckboxFunction\r\n      ? this.config.disableControlCheckboxFunction(rowData)\r\n      : false;\r\n  }\r\n\r\n  isDisabledRow(rowData: any): boolean {\r\n    return this.config.disableRow ? this.config.disableRow(rowData) : false;\r\n  }\r\n\r\n  // Não é utilizada\r\n  private getStyleClass(rowData: any, col: TableConfigColumn, data: any): string {\r\n    // console.log('ESTILO ->', col ? col.styleClass!(rowData, col, data) : '')\r\n    return col ? col.styleClass!(rowData, col, data) : ''\r\n  }\r\n\r\n  verificaCursor() {\r\n    document.querySelectorAll('.disabled-row').forEach(row => {\r\n      row.querySelectorAll('td').forEach(cell => {\r\n        cell.addEventListener('click', event => {\r\n          const target = event.target as HTMLElement;\r\n          if (!target.classList.contains('tooltip')) {\r\n            event.preventDefault();\r\n            event.stopPropagation();\r\n          }\r\n        });\r\n      });\r\n    });\r\n  }\r\n\r\n  // Não está verificando se rowData[col.field] é string\r\n  loadImage(rowData: any, col: TableConfigColumn): string {\r\n    /*\r\n      Nossa coluna de imagem trabalha com strings do tipo: base64 ou url\r\n    */\r\n    let retorno = `data: image / jpg; base64, ${imgDefault} `;\r\n    if (rowData && col && rowData[col.field] && rowData[col.field] !== '') {\r\n      if (rowData[col.field].includes('http')) retorno = rowData[col.field];\r\n      else retorno = `data: image / jpg; base64, ${rowData[col.field]} `;\r\n    }\r\n\r\n    return retorno;\r\n  }\r\n\r\n  public onGlobalFilter(table: Table, event: Event) {\r\n    this.filterField.emit((event.target as HTMLInputElement).value);\r\n    table.filterGlobal((event.target as HTMLInputElement).value, 'contains');\r\n  }\r\n\r\n  public paginate(event: any) {\r\n    if (event) {\r\n      let paginaInicial =\r\n        (event?.first > 0 ? event.first / event.rows : event.first) + 1;\r\n      let termoPesquisa = '';\r\n      let ordenacao = '';\r\n\r\n      if (event.globalFilter) termoPesquisa = event.globalFilter;\r\n\r\n      if (event.sortField)\r\n        ordenacao = `${event.sortField} ${event.sortOrder === 1 ? 'ASC' : 'DESC'} `;\r\n\r\n      const objeto: TablePaginate = {\r\n        paginaInicial: paginaInicial,\r\n        tamanhoPagina: event.rows,\r\n        termoPesquisa: termoPesquisa,\r\n        ordenacao: ordenacao,\r\n        ordernacaoGroup: { column: event.sortField, direction: event.sortOrder === 1 ? 'ASC' : 'DESC' },\r\n      };\r\n\r\n      this.onPaginate.emit(objeto);\r\n\r\n      this.actionsOffset = event.first;\r\n      this.createTableActions();\r\n    }\r\n  }\r\n\r\n  selectionChange(value: any) {\r\n    this.onSelectionChange.emit(value);\r\n  }\r\n\r\n  public activeItemLote(selectedItems: any) {\r\n    this.onActiveItemLote.emit(selectedItems);\r\n  }\r\n\r\n  // Não está verificando se rowData[col.field] pode ser passado para Date\r\n  returnRowClass(rowData: any, col: TableConfigColumn) {\r\n    let value = rowData[col.field];\r\n    let rowClass: string;\r\n\r\n    this.tableSize > 800 ? (rowClass = 'text-base') : (rowClass = 'text-sm');\r\n\r\n    if (col.expiredDate == true) {\r\n      new Date(value) < new Date()\r\n        ? (rowClass = rowClass + ' text-red-400 font-semibold')\r\n        : '';\r\n    }\r\n    return rowClass;\r\n  }\r\n\r\n  // Não é usada\r\n  private expiredFile(rowData: any, col: TableConfigColumn): boolean {\r\n    let value = rowData['datavencimento'];\r\n    return new Date(value) < new Date() && col.field == 'area';\r\n  }\r\n\r\n  transformValue(rowData: any, col: TableConfigColumn) {\r\n    let value = rowData[col.field];\r\n\r\n    if (col.transform) {\r\n      return col.transform(value);\r\n    }\r\n\r\n    if ((value == null || value === '' || value === undefined) && this.replaceEmptyValues && this.isLoadingSkeleton()) {\r\n      return '-';\r\n    }\r\n\r\n    if (value != null) {\r\n      if (!col.pipe) {\r\n        return value;\r\n      }\r\n\r\n      switch (col.pipe) {\r\n        case 'date':\r\n          return this.datePipe.transform(value, 'dd/MM/yyyy', 'UTC');\r\n        case 'datetime':\r\n          return this.datePipe.transform(value, 'dd/MM/yyyy HH:mm');\r\n        case 'dateMonthYear':\r\n          return this.datePipe.transform(value, 'MM/yyyy');\r\n        case 'decimal':\r\n          return this.decimalPipe.transform(value, '1.2-2', 'pt-BR');\r\n        case 'cpfcnpj':\r\n          return this.cpfCnpjPipe.transform(value);\r\n        case 'telefone':\r\n          return this.telefonePipe.transform(value);\r\n        case 'capitalize':\r\n          return this.transformCapitalize(value);\r\n        case 'money':\r\n          return this.formatarValor(value);\r\n        case 'percentage':\r\n          return `${value} % `;\r\n\r\n        default:\r\n          break;\r\n      }\r\n    }\r\n  }\r\n\r\n  // transformDate(date: any) {\r\n  //   const datePipe = new DatePipe('en-US');\r\n  //   const utcDate = new Date(date);\r\n\r\n  //   // Ajuste a data para o fuso horário local\r\n  //   const localDate = new Date(utcDate.getTime() + (utcDate.getTimezoneOffset() * 60000));\r\n\r\n  //   console.log('localDate', localDate, \"input date\", date);\r\n\r\n  //   // Transforme a data local para o formato desejado\r\n  //   return datePipe.transform(localDate, 'dd/MM/yyyy');\r\n  // }\r\n\r\n  transformCapitalize(value: string): string {\r\n    if (!value) return value;\r\n\r\n    return value.split(' ').map((word, index) => {\r\n      const wordUpper = word.toUpperCase();\r\n      const wordLower = word.toLocaleLowerCase();\r\n\r\n      // Verifica numerais romanos\r\n      if (this.romanNumerals.has(wordUpper)) {\r\n        return word;\r\n      }\r\n\r\n      // Verifica siglas\r\n      if (this.siglas.has(wordUpper)) {\r\n        return word;\r\n      }\r\n\r\n      // Verifica preposições, mas não altera a primeira palavra\r\n      if (index !== 0 && this.prepositions.has(wordLower)) {\r\n        return wordLower;\r\n      }\r\n\r\n      // Capitaliza a primeira letra das demais palavras\r\n      return word.charAt(0).toLocaleUpperCase() + word.slice(1).toLocaleLowerCase();\r\n    }).join(' ');\r\n  }\r\n\r\n  formatarValor(valor: number): string {\r\n    const formatter = new Intl.NumberFormat('pt-BR', {\r\n      style: 'currency',\r\n      currency: 'BRL',\r\n    });\r\n\r\n    return formatter.format(valor);\r\n  }\r\n\r\n  adjustTableSize() {\r\n    if (this.tableSize < 800) {\r\n      this.selectedSize = 'p-datatable-sm';\r\n    } else {\r\n      this.selectedSize = '';\r\n    }\r\n  }\r\n\r\n  doubleClick(e: any, rowData: any) {\r\n    let eventDoubleClick = { event: e, rowData: rowData };\r\n\r\n    let array: string[] = [];\r\n    e.target.classList.forEach((x: any) => array.push(x));\r\n\r\n    this.doubleClickEvent.emit(eventDoubleClick);\r\n  }\r\n\r\n  // alignColunas(col: any): string {\r\n  //   if (col.align) {\r\n  //     return `text - align: ${ col.align } `;\r\n  //   } else return '';\r\n  // }\r\n\r\n  // alignColunasHeader(col: any): string {\r\n  //   if (col.align) {\r\n  //     if (col.align == 'right') return 'justify-content: end';\r\n  //     else return '';\r\n  //   } else return '';\r\n  // }\r\n\r\n  retornarRow(rowData: any, col: TableConfigColumn, field: string): string {\r\n    const _rowaction = this.config.rows ? this.config.rows[col.field] : null;\r\n    const _field: string =\r\n      _rowaction && _rowaction[field]\r\n        ? _rowaction[field].constructor === Function\r\n          ? _rowaction[field].apply(this, [rowData])\r\n          : _rowaction[field]\r\n        : null;\r\n    return _field;\r\n  }\r\n\r\n  // Não é usado\r\n  private exibirCampo(field: any, rowData: any) {\r\n    let visible = field.visible ? field.visible(rowData) : true;\r\n\r\n    return visible;\r\n  }\r\n\r\n  returnClassChip(rowData: any, col: TableConfigColumn): string {\r\n    return `chip - style w - auto border - round - 2xl p - 2 text - ${this.retornarRow(\r\n      rowData,\r\n      col,\r\n      'stylechip'\r\n    )\r\n      } border - ${this.retornarRow(rowData, col, 'stylechip')} `;\r\n  }\r\n\r\n  returnClassIcon(rowData: any, col: TableConfigColumn): string {\r\n    return this.retornarRow(rowData, col, 'iconrow');\r\n  }\r\n\r\n  returnTooltipIcon(rowData: any, col: TableConfigColumn): string {\r\n    return this.retornarRow(rowData, col, 'tooltipiconrow');\r\n  }\r\n\r\n  returnTooltipRow(rowData: any, col: TableConfigColumn): any {\r\n    return this.retornarRow(rowData, col, 'tooltiprow');\r\n  }\r\n\r\n  deleteColumn(field: string) {\r\n    let index: number;\r\n\r\n    let column: TableConfigColumn | undefined = this.config.columns.find(\r\n      x => x.field == field\r\n    );\r\n    if (column) {\r\n      index = this.config.columns.indexOf(column);\r\n      this.config.columns.splice(index, 1);\r\n      this.deletedColuns.push(column);\r\n    }\r\n  }\r\n\r\n  addColumn(field: string) {\r\n    let index: number;\r\n\r\n    let column: TableConfigColumn | undefined = this.config.columns.find(\r\n      (x) => x.field == field\r\n    );\r\n\r\n    if (!column) {\r\n      let deletedColumn: TableConfigColumn | undefined =\r\n        this.deletedColuns.find((x) => x.field == field);\r\n\r\n      if (deletedColumn != undefined) {\r\n        index = this.deletedColuns.indexOf(deletedColumn);\r\n        this.deletedColuns.slice(index, 1);\r\n        this.config.columns.push(deletedColumn);\r\n      }\r\n    }\r\n  }\r\n\r\n  dinamicColumnSet(e: any, col: TableConfigColumn) {\r\n    col.checked = e.checked;\r\n    if (e.checked) this.addColumn(col.field);\r\n    else this.deleteColumn(col.field);\r\n\r\n    if (col.position) this.config.columns.sort(this.sortByPosition());\r\n  }\r\n\r\n  abrirMenuFiltro(e: any) {\r\n    this.menuFiltro = !this.menuFiltro;\r\n    this.checkboxClicked = false;\r\n\r\n    if (this.widthPage() < 700)\r\n      this.styleSetter(\r\n        'left',\r\n        this.botaoFiltro.nativeElement.offsetLeft - 288 + 'px'\r\n      );\r\n    else\r\n      this.styleSetter(\r\n        'left',\r\n        this.botaoFiltro.nativeElement.offsetLeft + 40 + 'px'\r\n      );\r\n\r\n    this.styleSetter('top', this.botaoFiltro.nativeElement.offsetTop + 'px');\r\n    this.styleSetter('visibility', this.menuFiltro ? 'visible' : 'hidden');\r\n  }\r\n\r\n  fecharMenuFiltro() {\r\n    this.menuFiltro = false;\r\n    this.checkboxClicked = false;\r\n\r\n    this.styleSetter('visibility', 'hidden');\r\n  }\r\n\r\n  @HostListener('document:keydown.escape', ['$event'])\r\n  onEscapeKey(event: KeyboardEvent) {\r\n    if (this.filterColumnsBtn == true && this.menuFiltro == true) {\r\n      this.fecharMenuFiltro();\r\n    }\r\n  }\r\n\r\n  @HostListener('document:click', ['$event'])\r\n  onClickEvent(event: any) {\r\n    if (this.filterColumnsBtn == true && this.menuFiltro == true) {\r\n      const clickedElement = event.target as HTMLElement;\r\n      const menuFiltroDiv =\r\n        this.elementRef.nativeElement.querySelector('#menuFiltroDiv');\r\n      const botaoFiltro =\r\n        this.elementRef.nativeElement.querySelector('#botaoFiltro');\r\n      const isCheckboxClicked =\r\n        clickedElement.classList.toString().includes('p-checkbox') ||\r\n        event.target.classList.toString() == '';\r\n      const isInsideMenu =\r\n        menuFiltroDiv?.contains(clickedElement) ||\r\n        botaoFiltro?.contains(clickedElement) ||\r\n        isCheckboxClicked;\r\n\r\n      if (!isInsideMenu) this.fecharMenuFiltro();\r\n    }\r\n  }\r\n\r\n  styleSetter(style: string, data: string) {\r\n    this.renderer?.setStyle(this.menuFiltroDiv.nativeElement, style, data);\r\n  }\r\n\r\n  checkMenuFiltro(col: TableConfigColumn) {\r\n    let deletedColumn = this.deletedColuns.find(\r\n      x => x.field == col.field\r\n    );\r\n    if (deletedColumn) col.checked = false;\r\n    else col.checked = true;\r\n  }\r\n\r\n  sortByPosition() {\r\n    return function (elem1: any, elem2: any) {\r\n      if (elem1.position < elem2.position) {\r\n        return -1;\r\n      } else if (elem1.position > elem2.position) {\r\n        return 1;\r\n      } else {\r\n        return 0;\r\n      }\r\n    };\r\n  }\r\n\r\n  dinamicDisableColumn(col: TableConfigColumn): boolean {\r\n    if (col.fixedColumn) return col.fixedColumn;\r\n    else return false;\r\n  }\r\n\r\n  checkHideColumns() {\r\n    let hideColumnsConfig = this.columns.filter(\r\n      col => col.hideColumn == true\r\n    );\r\n    hideColumnsConfig.forEach(col => this.deleteColumn(col.field));\r\n  }\r\n\r\n  getCustomTemplate(templatename: string): TemplateRef<any> {\r\n    return this._templates[templatename];\r\n  }\r\n\r\n  onSwitchChange(estado: any, rowData: any, col: TableConfigColumn) {\r\n    this.onSwitchTableChange.emit({\r\n      estado: estado,\r\n      rowData: rowData,\r\n      col: col,\r\n    });\r\n\r\n    rowData[col.field] = estado;\r\n  }\r\n\r\n  createTableActions() {\r\n    this.tableActions = this.dataSource?.map((x) =>\r\n      this.config.actions\r\n        ? this.config.actions.map((y) => mapToMenuItem(y, x))\r\n        : []\r\n    );\r\n  }\r\n\r\n  onSort(e: any) {\r\n    this.dataSource = [...this.dataSource];\r\n  }\r\n\r\n  get config(): TableConfig {\r\n    return this.tableConfig()!;\r\n  }\r\n\r\n  columnsFilter = computed(() => {\r\n    const dynamicColumns = (this.tableConfig()?.columns ?? []).filter(col => !col.fixedColumn);\r\n\r\n    return [...dynamicColumns, ...this.deletedColuns];\r\n  });\r\n\r\n  returnMaxWidth = computed(() => (widthCol: string) => {\r\n    let widthTable = 0;\r\n        \r\n      const tableCellRef = this.tableCell ? this.tableCell() : null;\r\n      if (tableCellRef && tableCellRef.nativeElement && tableCellRef.nativeElement.parentElement) {\r\n        widthTable = tableCellRef.nativeElement.parentElement.offsetWidth;\r\n      } else {\r\n        const tableElem = this.elementRef?.nativeElement?.querySelector('.p-datatable') ||\r\n          this.elementRef?.nativeElement?.querySelector('table');\r\n        if (tableElem && tableElem.offsetWidth) {\r\n          widthTable = tableElem.offsetWidth;\r\n        } else if (this.table && (this.table as any).el && (this.table as any).el.nativeElement) {\r\n          widthTable = (this.table as any).el.nativeElement.offsetWidth || 0;\r\n        }\r\n      }\r\n\r\n    const percent = Number((widthCol || '100%').toString().replace('%', '')) || 100;\r\n    const widthCalc = widthTable * percent / 100;\r\n\r\n    return `${widthCalc}px`;\r\n  })\r\n}\r\n","<div class=\"kv-table-container\">\r\n  @if (config) {\r\n  <p-table\r\n    #dt\r\n    styleClass=\"p-datatable-sm\"\r\n    [value]=\"dataSource\"\r\n    [(selection)]=\"selectedItems\"\r\n    [rowSelectable]=\"isRowSelectable\"\r\n    [columns]=\"config.columns\"\r\n    [globalFilterFields]=\"globalFilterFields\"\r\n    [rows]=\"rows()\"\r\n    [paginator]=\"paginator\"\r\n    [rowsPerPageOptions]=\"rowsPerPageOptions\"\r\n    [showCurrentPageReport]=\"true\"\r\n    currentPageReportTemplate=\"{first} - {last} de {totalRecords}\"\r\n    [rowHover]=\"true\"\r\n    [totalRecords]=\"totalRecords\"\r\n    [lazy]=\"config.lazy\"\r\n    [first]=\"first()\"\r\n    (onLazyLoad)=\"paginate($event)\"\r\n    (selectionChange)=\"selectionChange($event)\"\r\n    (onSort)=\"onSort($event)\"\r\n    (onPage)=\"onPage($event)\"\r\n    rowGroupMode=\"rowspan\"\r\n    [groupRowsBy]=\"config.fieldGroup\"\r\n    [showFirstLastIcon]=\"widthPage() > 960 ? true : false\"\r\n    [pageLinks]=\"widthPage() > 960 ? 2 : 1\"\r\n    [responsive]=\"true\"\r\n    [responsiveLayout]=\"responsiveLayout ? 'stack' : ''\"\r\n    [scrollable]=\"isTableScrollable\"\r\n    [scrollHeight]=\"scrollHeight\"\r\n    [rowTrackBy]=\"rowTrackBy\"\r\n  >\r\n    @if (config?.enableCation) {\r\n    <ng-template pTemplate=\"caption\">\r\n      <div\r\n        class=\"flex flex-row flex-wrap justify-content-between grid formgrid p-fluid col-12 m-0 mb-2\"\r\n        [style.padding.rem]=\"0.1\"\r\n      >\r\n        <div class=\"col-12 flex flex-column\">\r\n          @if (config.title) {\r\n          <div class=\"text-md font-bold my-3\">\r\n            {{ config.title }}\r\n          </div>\r\n          } @if (config.subtitle) {\r\n          <div class=\"text-sm mb-4 font-medium\">\r\n            {{ config.subtitle }}\r\n          </div>\r\n          }\r\n        </div>\r\n\r\n        <div\r\n          class=\"flex flex-row align-items-center md:col-6 lg:col-4 {{\r\n            widthPage() < 768 ? 'col-10' : 'col-12'\r\n          }}  gap-1 p-0\"\r\n        >\r\n          @if (config?.enableFilter) {\r\n          <!-- <span class=\"p-input-icon-left\">\r\n            <i class=\"pi pi-search text-sm\"></i>\r\n\r\n            <input\r\n              pInputText\r\n              pAutoFocus\r\n              [autofocus]=\"widthPage() > 800\"\r\n              type=\"text\"\r\n              (input)=\"onGlobalFilter(dt, $event)\"\r\n              [placeholder]=\"searchPlaceholder\"\r\n              autocomplete=\"off\"\r\n              #inputField\r\n              class=\"text-sm \"\r\n            />\r\n          </span> -->\r\n          @if(autoFocusSearch) {\r\n            <input\r\n              pInputText\r\n              pAutoFocus\r\n              [autofocus]=\"widthPage() > 800\"\r\n              type=\"text\"\r\n              (input)=\"onGlobalFilter(dt, $event)\"\r\n              [placeholder]=\"searchPlaceholder\"\r\n              autocomplete=\"off\"\r\n              #inputField\r\n              class=\"text-sm col-6\"\r\n            />\r\n          } \r\n          @else {<input\r\n              pInputText\r\n              [autofocus]=\"widthPage() > 800\"\r\n              type=\"text\"\r\n              (input)=\"onGlobalFilter(dt, $event)\"\r\n              [placeholder]=\"searchPlaceholder\"\r\n              autocomplete=\"off\"\r\n              #inputField\r\n              class=\"text-sm col-6\"\r\n            />}\r\n\r\n          } @if(filterColumnsBtn) {\r\n          <div #botaoFiltro>\r\n            <kv-button\r\n              id=\"botaoFiltro\"\r\n              [icon]=\"'align_vertical_top'\"\r\n              (onClick)=\"abrirMenuFiltro($event)\"\r\n              severity=\"tertiary\"\r\n              pTooltip=\"Ocultar/Exibir colunas\"\r\n              size=\"small\"\r\n            >\r\n            </kv-button>\r\n          </div>\r\n\r\n          <div\r\n            #menuFiltroDiv\r\n            id=\"menuFiltroDiv\"\r\n            [style.visibility]=\"'hidden'\"\r\n            class=\"absolute z-4 bg-gray-200 menu-columns-filtro\"\r\n          >\r\n            <p-card styleClass=\"p-1\">\r\n              <div\r\n                class=\"flex flex-column text-medium w-15rem p-1\"\r\n                *ngFor=\"let col of columnsFilter()\"\r\n              >\r\n                {{ checkMenuFiltro(col) }}\r\n                <p-checkbox\r\n                  #filterColumns\r\n                  [label]=\"col.header\"\r\n                  [binary]=\"true\"\r\n                  class=\"checkbox-container\"\r\n                  (onChange)=\"dinamicColumnSet($event, col)\"\r\n                  [(ngModel)]=\"col.checked\"\r\n                  *ngIf=\"!dinamicDisableColumn(col)\"\r\n                ></p-checkbox>\r\n              </div>\r\n            </p-card>\r\n          </div>\r\n          } @if(filterButton()) {\r\n          <!-- <p-button\r\n            styleClass=\"kv-button small tertiary text-xs font-medium\"\r\n            label=\"Filtrar\"\r\n            icon=\"pi pi-filter\"\r\n            [badge]=\"filterButtonBadge()\"\r\n            badgeClass=\"text-gray-800\"\r\n            class=\"text-xs\"\r\n            (onClick)=\"op.toggle($event)\"\r\n          ></p-button> -->\r\n\r\n             <kv-button\r\n              label=\"Filtrar\"\r\n              icon=\"filter_alt\"\r\n              severity=\"tertiary\"\r\n              (onClick)=\"toggleOverlayPanel($event)\"\r\n            ></kv-button>\r\n          }\r\n\r\n          <p-overlayPanel #op [dismissable]=\"false\">\r\n            <ng-content select=\"[filtro]\"> </ng-content>\r\n          </p-overlayPanel>\r\n        </div>\r\n\r\n        <div class=\"flex flex-row col-2 justify-content-end gap-2 p-0\">\r\n          @for (action of config.actionsLote; track i; let i = $index) {\r\n          <div class=\"flex align-items-center justify-content-center\">\r\n            @if ((selectedItems.length > 0 || action.showAcoesLote) &&\r\n            (getOrExecute(action.visible, selectedItems) ?? true)) {\r\n            <kv-button\r\n              (onClick)=\"action?.command(); activeItemLote(selectedItems)\"\r\n              [pTooltip]=\"getOrExecute(action.tooltip, selectedItems)\"\r\n              [tooltipPosition]=\"'left'\"\r\n              [disabled]=\"getOrExecute(action.disabled, selectedItems) || false\"\r\n              [icon]=\"getOrExecute(action.icon, selectedItems)\"\r\n              [severity]=\"action.severity || 'tertiary'\"\r\n              size=\"small\"\r\n              [label]=\"getOrExecute(action.label, selectedItems) || ''\"\r\n              [items]=\"action.items || []\"\r\n              [popup]=\"(action.items && action.items.length > 0) || false\"\r\n            />\r\n            }\r\n          </div>\r\n          }\r\n        </div>\r\n      </div>\r\n    </ng-template>\r\n    }\r\n\r\n    <ng-template pTemplate=\"header\" let-columns>\r\n      <tr>\r\n        @if (config.enableSelect) {\r\n        <th>\r\n          <p-tableHeaderCheckbox\r\n            (click)=\"activeItemLote(selectedItems)\"\r\n            [disabled]=\"disabledHeaderCheckbox\"\r\n          ></p-tableHeaderCheckbox>\r\n        </th>\r\n        } @for (col of columns; track $index) {\r\n        <th\r\n          [pSortableColumn]=\"col.field\"\r\n          [pSortableColumnDisabled]=\"col.sortable === false\"\r\n          [style.width]=\"col.width\"\r\n        >\r\n          <div\r\n            class=\"flex flex-row align-items-center {{\r\n              col?.centralize && 'justify-content-center'\r\n            }}\"\r\n          >\r\n            <span class=\"text-xs font-semibold\">{{ col.header }}</span>\r\n            @if (col.sortable) {\r\n            <p-sortIcon [field]=\"col.field\" class=\"pb-1\"></p-sortIcon>\r\n            } @if (col.headerTooltip) {\r\n            <span\r\n              class=\"material-symbols-outlined flex align-items-center\"\r\n              [pTooltip]=\"col.headerTooltip\"\r\n              >info</span\r\n            >\r\n            }\r\n          </div>\r\n        </th>\r\n        } @if (config.actions && config.actions.length > 0) {\r\n        <th></th>\r\n        }\r\n      </tr>\r\n    </ng-template>\r\n\r\n    <ng-template\r\n      pTemplate=\"body\"\r\n      let-rowData\r\n      let-columns=\"columns\"\r\n      let-rowgroup=\"rowgroup\"\r\n      let-rowspan=\"rowspan\"\r\n      let-rowIndex=\"rowIndex\"\r\n    >\r\n      <tr\r\n        (dblclick)=\"doubleClick($event, rowData)\"\r\n        [ngClass]=\"{\r\n          capitalize: tableCaptalized,\r\n          last: rowIndex === dataSource.length - 1\r\n        }\"\r\n        class=\"tr-td {{ isDisabledRow(rowData) ? 'disabled-row' : '' }}\"\r\n      >\r\n        @if (config.enableSelect) {\r\n        <td style=\"width: 8px !important\">\r\n          <p-tableCheckbox\r\n            [value]=\"rowData\"\r\n            [disabled]=\"isDisabledCheckbox(rowData)\"\r\n            (click)=\"activeItemLote(selectedItems)\"\r\n          ></p-tableCheckbox>\r\n        </td>\r\n        } @for (col of columns; track $index) {\r\n        <ng-container>\r\n          @if (rowgroup && !col.template) {\r\n          <td\r\n            [attr.rowspan]=\"rowgroup && col.grouped ? rowspan : null\"\r\n            [pTooltip]=\"returnTooltipRow(rowData, col)\"\r\n            class=\"{{\r\n              col.styleClass\r\n                ? col.styleClass(rowData, col, rowData[col.field])\r\n                : ''\r\n            }}\"\r\n          >\r\n            <span class=\"p-column-title text-xs\">{{ col.header }}:</span>\r\n\r\n            <span\r\n              *ngIf=\"!isBooleanField(rowData, col); else booleanField\"\r\n              [class]=\"returnRowClass(rowData, col)\"\r\n            >\r\n              @if (!isChipField(col) && !col.iconField && !isImageField(col) &&\r\n              !isEmptyDataSource()) {\r\n              <span\r\n                class=\"flex flex-row gap-2 align-items-center {{\r\n                  col?.centralize && 'justify-content-center'\r\n                }} text-xs {{ ellipsisText() && 'ellipsis-text' }}\"\r\n                [pTooltip]=\"\r\n                  col.tooltip && col.tooltip(rowData, col, rowData[col.field])\r\n                \"\r\n                [tooltipPosition]=\"'bottom'\"\r\n                [style.max-width]=\"\r\n                  ellipsisText() && returnMaxWidth()(col.width)\r\n                \"\r\n              >\r\n                @if(col.tagColor) {\r\n                <div\r\n                  class=\"tag\"\r\n                  [pTooltip]=\"\r\n                    col.tooltipTag &&\r\n                    col.tooltipTag(rowData, col, rowData[col.field])\r\n                  \"\r\n                  [style.background-color]=\"\r\n                    col.tagColor(rowData, col, rowData[col.field])\r\n                  \"\r\n                ></div>\r\n\r\n                } \r\n                <span class=\"text-xs {{ ellipsisText() && 'ellipsis-text' }}\">\r\n                  @if (col.icon) {\r\n                  <i [class]=\"col.icon + ' mr-2'\"></i>\r\n                  }\r\n                  {{ transformValue(rowData, col) }} \r\n                </span>           \r\n              </span>\r\n              } @if (isChipField(col) && !col.iconField) {\r\n              <div>\r\n                <span\r\n                  [class]=\"returnClassChip(rowData, col)\"\r\n                  [pTooltip]=\"returnTooltipIcon(rowData, col)\"\r\n                  class=\"text-xs\"\r\n                  >{{ transformValue(rowData, col) }}</span\r\n                >\r\n              </div>\r\n              } @if(isEmptyDataSource() && this.isLoadingSkeleton()) {\r\n              <div class=\"w-full\">\r\n                @if(!isSwitchField(col)) {\r\n\r\n                <div\r\n                  class=\"w-full flex {{\r\n                    col.centralize && 'justify-content-center'\r\n                  }}\"\r\n                >\r\n                  <div [style.width]=\"widthRandom()(col, rowIndex) + '%'\">\r\n                    <p-skeleton styleClass=\"w-full\"></p-skeleton>\r\n                  </div>\r\n                </div>\r\n\r\n                } @else {\r\n                <div class=\"flex flex-row justify-content-center\">\r\n                  <div\r\n                    [style]=\"{\r\n                      height: '16.8px',\r\n                      width: '28.8px',\r\n                      'border-radius': '30px'\r\n                    }\"\r\n                  >\r\n                    <p-skeleton styleClass=\"w-full\"></p-skeleton>\r\n                  </div>\r\n                </div>\r\n                }\r\n              </div>\r\n              }\r\n            </span>\r\n\r\n            @if (isImageField(col)) {\r\n            <span>\r\n              <span>\r\n                <img class=\"image\" [src]=\"loadImage(rowData, col)\" />\r\n              </span>\r\n            </span>\r\n            } @if (col.iconField) {\r\n            <i\r\n              [ngClass]=\"{\r\n                'material-icons': col.indIconMaterial,\r\n                'material-symbols-outlined mr-2': !col.indIconMaterial\r\n              }\"\r\n              [pTooltip]=\"returnTooltipIcon(rowData, col)\"\r\n            >\r\n              {{ returnClassIcon(rowData, col) }}\r\n            </i>\r\n            }\r\n\r\n            <ng-template #booleanField>\r\n              @if (!col.iconField && !isSwitchField(col)) {\r\n              <div\r\n                class=\"flex flex-row gap-2 align-items-center {{\r\n                  col?.centralize && 'justify-content-center'\r\n                }}\"\r\n                [pTooltip]=\"\r\n                  col.tooltip && col.tooltip(rowData, col, rowData[col.field])\r\n                \"\r\n                [tooltipPosition]=\"'bottom'\"\r\n              >\r\n                <i\r\n                  [ngClass]=\"\r\n                    rowData[col.field] ? 'text-green-500' : 'text-red-500'\r\n                  \"\r\n                  ><span\r\n                    class=\"material-symbols-outlined text-lg font-semibold\"\r\n                  >\r\n                    {{ rowData[col.field] ? \"check\" : \"close\" }}\r\n                  </span>\r\n                </i>\r\n              </div>\r\n\r\n              } @if (isSwitchField(col)) {\r\n              <span\r\n                [class]=\"\r\n                  returnRowClass(rowData, col) +\r\n                  ' flex flex-row align-items-center justify-content-center'\r\n                \"\r\n                style=\"height: 25px\"\r\n              >\r\n                @if(col.switchDisable){\r\n                <kv-switch\r\n                  (onSwitchChange)=\"onSwitchChange($event, rowData, col)\"\r\n                  [disabled]=\"col.switchDisable(rowData, col)\"\r\n                  [switchValue]=\"transformValue(rowData, col)\"\r\n                >\r\n                </kv-switch>\r\n                } @else {\r\n                <kv-switch\r\n                  (onSwitchChange)=\"onSwitchChange($event, rowData, col)\"\r\n                  [disabled]=\"col?.onlyReadField ?? true\"\r\n                  [switchValue]=\"transformValue(rowData, col)\"\r\n                >\r\n                </kv-switch>\r\n                }\r\n              </span>\r\n              } @if(isEmptyDataSource() && this.isLoadingSkeleton()) {\r\n              <div class=\"w-full\">\r\n                @if(!isSwitchField(col)) {\r\n                <div\r\n                  class=\"w-full flex {{\r\n                    col.centralize && 'justify-content-center'\r\n                  }}\"\r\n                >\r\n                  <div [style.width]=\"widthRandom()(col, rowIndex) + '%'\">\r\n                    <p-skeleton styleClass=\"w-full\"></p-skeleton>\r\n                  </div>\r\n                </div>\r\n\r\n                } @else {\r\n                <div class=\"flex flex-row justify-content-center\">\r\n                  <div\r\n                    [style]=\"{\r\n                      height: '16.8px',\r\n                      width: '28.8px',\r\n                      'border-radius': '30px'\r\n                    }\"\r\n                  >\r\n                    <p-skeleton styleClass=\"w-full\"></p-skeleton>\r\n                  </div>\r\n                </div>\r\n                }\r\n              </div>\r\n              }\r\n            </ng-template>\r\n          </td>\r\n          } @if (!rowgroup && !col.grouped && !col.template) {\r\n          <td\r\n            #tableCell\r\n            class=\"rowTable {{\r\n              col.styleClass\r\n                ? col.styleClass(rowData, col, rowData[col.field])\r\n                : ''\r\n            }} \"\r\n            [pTooltip]=\"returnTooltipRow(rowData, col)\"\r\n          >\r\n            <span class=\"p-column-title text-xs\">{{ col.header }}:</span>\r\n\r\n            @if(!isEmptyDataSource()) {\r\n\r\n            <span\r\n              *ngIf=\"!isBooleanField(rowData, col); else booleanField\"\r\n              [class]=\"\r\n                returnRowClass(rowData, col) +\r\n                ' flex flex-row gap-2 align-items-center ' +\r\n                (col?.centralize && 'justify-content-center')\r\n              \"\r\n              [pTooltip]=\"\r\n                col.tooltip && col.tooltip(rowData, col, rowData[col.field])\r\n              \"\r\n              [tooltipPosition]=\"'bottom'\"\r\n              [style.max-width]=\"ellipsisText() && returnMaxWidth()(col.width)\"\r\n            >\r\n              @if(col.tagColor) {\r\n              <div\r\n                class=\"tag\"\r\n                [pTooltip]=\"\r\n                  col.tooltipTag &&\r\n                  col.tooltipTag(rowData, col, rowData[col.field])\r\n                \"\r\n                [style.background-color]=\"\r\n                  col.tagColor(rowData, col, rowData[col.field])\r\n                \"\r\n              ></div>\r\n\r\n              } @if (!isChipField(col) && !col.iconField && !isImageField(col)){\r\n              <span class=\"text-xs {{ ellipsisText() && 'ellipsis-text' }}\">\r\n                @if (col.icon) {\r\n                <i [class]=\"col.icon + ' mr-2'\"></i>\r\n                }\r\n                {{ transformValue(rowData, col) }}\r\n              </span>\r\n              } @if (isChipField(col) && !col.iconField) {\r\n              <div>\r\n                <span\r\n                  [class]=\"returnClassChip(rowData, col)\"\r\n                  [pTooltip]=\"returnTooltipIcon(rowData, col)\"\r\n                  class=\"text-xs\"\r\n                >\r\n                  {{ transformValue(rowData, col) }}</span\r\n                >\r\n              </div>\r\n              }\r\n            </span>\r\n            } @if (isImageField(col)) {\r\n            <span>\r\n              <span>\r\n                <img class=\"image\" [src]=\"loadImage(rowData, col)\" />\r\n              </span>\r\n            </span>\r\n            } @if (col.iconField) {\r\n            <i\r\n              [ngClass]=\"{\r\n                'material-icons': col.indIconMaterial,\r\n                'material-symbols-outlined mr-2': !col.indIconMaterial\r\n              }\"\r\n              [pTooltip]=\"returnTooltipIcon(rowData, col)\"\r\n            >\r\n              {{ returnClassIcon(rowData, col) }}\r\n            </i>\r\n            }\r\n\r\n            <ng-template #booleanField>\r\n              @if (!col.iconField && !isSwitchField(col)) {\r\n              <div\r\n                class=\"flex flex-row gap-2 align-items-center {{\r\n                  col?.centralize && 'justify-content-center'\r\n                }}\"\r\n                [pTooltip]=\"\r\n                  col.tooltip && col.tooltip(rowData, col, rowData[col.field])\r\n                \"\r\n                [tooltipPosition]=\"'bottom'\"\r\n              >\r\n                <i\r\n                  [ngClass]=\"\r\n                    rowData[col.field] ? 'text-green-500' : 'text-red-500'\r\n                  \"\r\n                  ><span\r\n                    class=\"material-symbols-outlined text-lg font-semibold\"\r\n                  >\r\n                    {{ rowData[col.field] ? \"check\" : \"close\" }}\r\n                  </span>\r\n                </i>\r\n              </div>\r\n              } @if (isSwitchField(col)) {\r\n\r\n              <span\r\n                [class]=\"\r\n                  returnRowClass(rowData, col) +\r\n                  ' flex flex-row align-items-center justify-content-center'\r\n                \"\r\n                style=\"height: 25px\"\r\n              >\r\n                @if(col.switchDisable){\r\n                <kv-switch\r\n                  (onSwitchChange)=\"onSwitchChange($event, rowData, col)\"\r\n                  [disabled]=\"col.switchDisable(rowData, col)\"\r\n                  [switchValue]=\"transformValue(rowData, col)\"\r\n                >\r\n                </kv-switch>\r\n                } @else {\r\n                <kv-switch\r\n                  (onSwitchChange)=\"onSwitchChange($event, rowData, col)\"\r\n                  [disabled]=\"col?.onlyReadField ?? true\"\r\n                  [switchValue]=\"transformValue(rowData, col)\"\r\n                >\r\n                </kv-switch>\r\n                }\r\n              </span>\r\n              }\r\n            </ng-template>\r\n\r\n            @if(isEmptyDataSource() && this.isLoadingSkeleton()) {\r\n            <div class=\"w-full\">\r\n              @if(!isSwitchField(col)) {\r\n              <div\r\n                class=\"w-full flex {{\r\n                  col.centralize && 'justify-content-center'\r\n                }}\"\r\n              >\r\n                <div [style.width]=\"widthRandom()(col, rowIndex) + '%'\">\r\n                  <p-skeleton styleClass=\"w-full\"></p-skeleton>\r\n                </div>\r\n              </div>\r\n\r\n              } @else {\r\n              <div class=\"flex flex-row justify-content-center\">\r\n                <div\r\n                  [style]=\"{\r\n                    height: '16.8px',\r\n                    width: '28.8px',\r\n                    'border-radius': '30px'\r\n                  }\"\r\n                >\r\n                  <p-skeleton styleClass=\"w-full\"></p-skeleton>\r\n                </div>\r\n              </div>\r\n              }\r\n            </div>\r\n            }\r\n          </td>\r\n          } @if (col.template) {\r\n          <td\r\n            class=\"rowTable {{\r\n              col.styleClass\r\n                ? col.styleClass(rowData, col, rowData[col.field])\r\n                : ''\r\n            }} \"\r\n          >\r\n            <span class=\"p-column-title text-xs\">{{ col.header }}:</span>\r\n            @if (getCustomTemplate(col.template.name)) {\r\n\r\n            <div\r\n              class=\"flex flex-row gap-2 align-items-center {{\r\n                col?.centralize && ' justify-content-center'\r\n              }}\"\r\n              [pTooltip]=\"\r\n                col.tooltip && col.tooltip(rowData, col, rowData[col.field])\r\n              \"\r\n              [tooltipPosition]=\"'bottom'\"\r\n            >\r\n              @if(col.tagColor) {\r\n              <div\r\n                class=\"tag\"\r\n                [pTooltip]=\"col.tooltipTag && col.tooltipTag(rowData, col)\"\r\n                [style.background-color]=\"col.tagColor(rowData, col)\"\r\n              ></div>\r\n              } @if(!isEmptyDataSource()) {\r\n\r\n              <div class=\"w-full\">\r\n                <ng-container\r\n                  [ngTemplateOutlet]=\"getCustomTemplate(col.template.name)\"\r\n                  [ngTemplateOutletContext]=\"{ $implicit: rowData }\"\r\n                />\r\n              </div>\r\n              }\r\n            </div>\r\n\r\n            @if(isEmptyDataSource() && this.isLoadingSkeleton()) {\r\n            <p-skeleton\r\n              [width]=\"widthRandom()(col, rowIndex) + '%'\"\r\n            ></p-skeleton>\r\n            } }\r\n          </td>\r\n          }\r\n        </ng-container>\r\n        } @if (config.actions && config.actions.length > 0) {\r\n        <td>\r\n          <div class=\"flex flex-row justify-content-end w-full\">\r\n            <span\r\n              class=\"material-symbols-outlined cursor-pointer icon-more\"\r\n              (click)=\"menu.toggle($event); activeItem(rowData)\"\r\n            >\r\n              <!-- more_vert -->\r\n              more_horiz\r\n            </span>\r\n\r\n            <p-tieredMenu\r\n              #menu\r\n              [popup]=\"true\"\r\n              [model]=\"tableActions[rowIndex - actionsOffset]\"\r\n              appendTo=\"body\"\r\n            >\r\n              <ng-template let-item pTemplate=\"item\">\r\n                <div\r\n                  [pTooltip]=\"item.tooltip\"\r\n                  tooltipPosition=\"left\"\r\n                  class=\"cursor-pointer\"\r\n                >\r\n                  <span class=\"text-xs\">\r\n                    {{ item.label }}\r\n                  </span>\r\n                </div>\r\n              </ng-template>\r\n            </p-tieredMenu>\r\n            <!-- <span pTooltip=\"{{ tableActions[rowIndex - actionsOffset][0]?.tooltip }}\" tooltipPosition=\"top\">a</span> -->\r\n          </div>\r\n        </td>\r\n        }\r\n      </tr>\r\n    </ng-template>\r\n\r\n    @if(emptyImage()) {\r\n      <ng-template pTemplate=\"emptymessage\" let-columns>\r\n        <tr>\r\n          <td [attr.colspan]=\"columns.length + 2\">\r\n            <div\r\n              class=\"w-full h-full flex align-items-center justify-content-center\"\r\n            >\r\n              <img [src]=\"emptyTableImg()\" class=\"h-10rem w-auto\" />\r\n            </div>\r\n          </td>\r\n        </tr>\r\n      </ng-template>\r\n    } @else {\r\n      <ng-template pTemplate=\"emptymessage\" let-columns>\r\n        <tr>\r\n          <td\r\n            [attr.colspan]=\"columns.length + 2\"\r\n            style=\"text-align: center; border-radius: 10px !important\"\r\n          >\r\n            <p class=\"font-medium m-0 text-xs\">Nenhum registro encontrado</p>\r\n          </td>\r\n        </tr>\r\n      </ng-template>\r\n    }\r\n  </p-table>\r\n  }\r\n</div>\r\n\r\n<link\r\n  rel=\"stylesheet\"\r\n  href=\"https://fonts.googleapis.com/icon?family=Material+Icons\"\r\n/>\r\n\r\n<link\r\n  rel=\"stylesheet\"\r\n  href=\"https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@48,400,0,0\"\r\n/>\r\n"]}
|