keevo-components 1.7.0 → 1.7.2

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.
@@ -301,8 +301,8 @@ export class TreeTableComponent {
301
301
  let eventDoubleClick = { event: e, rowData: rowData, rowNode: rowNode };
302
302
  let array = [];
303
303
  e.target.classList.forEach((x) => array.push(x));
304
- if (array.find((x) => x == 'ng-star-inserted') != undefined)
305
- this.doubleClickEvent.emit(eventDoubleClick);
304
+ //if (array.find((x: any) => x == 'ng-star-inserted') != undefined)
305
+ this.doubleClickEvent.emit(eventDoubleClick);
306
306
  }
307
307
  isDisabledCheckbox(rowData, rowNode) {
308
308
  return this.config.disableControlCheckboxFunction
@@ -368,4 +368,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
368
368
  type: HostListener,
369
369
  args: ['window:resize', ['$event']]
370
370
  }] } });
371
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-treetable.component.js","sourceRoot":"","sources":["../../../../../projects/keevo-components/src/lib/tree-table/kv-treetable.component.ts","../../../../../projects/keevo-components/src/lib/tree-table/kv-treetable.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ContentChildren,\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} from '@angular/core';\r\nimport { MenuItemCommandEvent, TreeNode } from 'primeng/api';\r\nimport {\r\n  CodigoFipePipe,\r\n  CpfCnpjPipe,\r\n  KvMenuItem,\r\n  TableConfig,\r\n  TableConfigColumn,\r\n  TablePaginate,\r\n  TelefonePipe,\r\n} from '../../public-api';\r\nimport { Table } from 'primeng/table';\r\nimport { TreeTable } from 'primeng/treetable';\r\nimport { DatePipe, DecimalPipe } from '@angular/common';\r\nimport { DomSanitizer } from '@angular/platform-browser';\r\nimport { TemplateDirective } from '../directives/template.directive';\r\n\r\ninterface Column {\r\n  field: string;\r\n  header: string;\r\n}\r\n\r\n@Component({\r\n  selector: 'kv-treetable',\r\n  templateUrl: './kv-treetable.component.html',\r\n  styleUrls: ['./kv-treetable.component.scss'],\r\n})\r\nexport class TreeTableComponent implements OnInit {\r\n  @Input() config!: TableConfig;\r\n  @Input() dataSource!: TreeNode[];\r\n  @Input() selectedItems: any = [];\r\n\r\n  @Input() acoesLinhaTabela: boolean = true;\r\n\r\n  @Input() espacamentoPai: string = '2px';\r\n  @Input() espacamentoLateral: boolean = true;\r\n\r\n  @Input() tamanhoTotalTree!: number;\r\n  @Input() rowsPerPageOptions!: number[];\r\n  @Input() rows: number = 5;\r\n  @Input() tableSize!: number;\r\n  @Input() paginator: boolean = true;\r\n  @Input() showFirstLastIcon: boolean = false;\r\n  @Input() rightCollapse: boolean = false;\r\n  @Input() applyStyle: Function = (rowData: any, col: TableConfigColumn) => '';\r\n\r\n  @Input('templates') _templates!: any;\r\n\r\n  @Input() colorButtonToggleNodes: string = 'surface-600';\r\n\r\n  @ContentChildren(TemplateDirective) templates!: QueryList<any>;\r\n  @ViewChild('table', { static: false }) table!: Table;\r\n\r\n  @Output() onFilter: EventEmitter<any> = new EventEmitter();\r\n  @Output() onPaginate: EventEmitter<any> = new EventEmitter();\r\n  @Output() onActiveItem: EventEmitter<any> = new EventEmitter();\r\n  @Output() onActiveItemLote: EventEmitter<any> = new EventEmitter();\r\n  @Output() doubleClickEvent: EventEmitter<any> = new EventEmitter();\r\n  tamanhoTela!: number;\r\n  selectedSize: string = '';\r\n  nodeContext = { $implicit: 'rowData', rowNode: 'rowNode' };\r\n\r\n  selectedNodes!: TreeNode[];\r\n  menuItems: KvMenuItem[] = [];\r\n  imgDefault: string =\r\n    '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';\r\n\r\n  isExpanded: boolean = false;\r\n\r\n  commandEvent!: MenuItemCommandEvent;\r\n\r\n  constructor(\r\n    private readonly datePipe: DatePipe,\r\n    private readonly decimalPipe: DecimalPipe,\r\n    private readonly codigoFipePipe: CodigoFipePipe,\r\n    private readonly cpfCnpjPipe: CpfCnpjPipe,\r\n    private readonly telefonePipe: TelefonePipe\r\n  ) {}\r\n\r\n  ngOnInit() {\r\n    this.tamanhoTela = window.innerWidth;\r\n  }\r\n\r\n  public onGlobalFilter(table: TreeTable, event: Event) {\r\n    this.onFilter.emit((event.target as HTMLInputElement).value);\r\n    table.filterGlobal((event.target as HTMLInputElement).value, 'contains');\r\n  }\r\n  @HostListener('window:resize', ['$event'])\r\n  onWindowResize() {\r\n    this.adjustTableSize();\r\n    this.tamanhoTela = window.innerWidth;\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  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} ${\r\n          $event.sortOrder === 1 ? 'ASC' : 'DESC'\r\n        }`;\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      };\r\n\r\n      this.onPaginate.emit(objeto);\r\n    }\r\n  }\r\n\r\n  isBooleanField(rowData: any, col: TableConfigColumn): boolean {\r\n    return col.fieldType == 'boolean';\r\n  }\r\n\r\n  isChipField(col: TableConfigColumn): boolean {\r\n    return col.fieldType == 'chip';\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  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  transformValue(rowData: any, col: TableConfigColumn) {\r\n    let value = rowData[col.field];\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');\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 'codigofipe':\r\n          return this.codigoFipePipe.transform(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  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  centralizarColunas(col: any): string {\r\n    if (col.centralize) {\r\n      return 'text-align: center; ';\r\n    } else return '';\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  returnClassIcon(rowData: any, col: any): string {\r\n    return this.retornarRow(rowData, col, 'iconrow');\r\n  }\r\n\r\n  returnTooltipIcon(rowData: any, col: any): string {\r\n    return this.retornarRow(rowData, col, 'tooltipiconrow');\r\n  }\r\n  returnClassChip(rowData: any, col: any): 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    )} border-${this.retornarRow(rowData, col, 'stylechip')}`;\r\n  }\r\n  retornarRow(rowData: any, col: any, 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  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  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, ${this.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  getCustomTemplate(templatename: string): TemplateRef<any> {\r\n    return this._templates[templatename];\r\n  }\r\n  exibirCampo(field: any, rowData: any) {\r\n    let visible = field.visible ? field.visible(rowData) : true;\r\n    return visible;\r\n  }\r\n  public activeItem(rowData: any, rowNode: any) {\r\n    console.log(rowNode);\r\n    this.onActiveItem.emit({ rowData: rowData, rowNode: rowNode });\r\n  }\r\n  public activeItemLote(rowData: any) {\r\n    this.onActiveItemLote.emit(rowData);\r\n  }\r\n\r\n  retornarCampo(action: KvMenuItem, rowData: any, field: string): string {\r\n    const _function = action.dynamicfields\r\n      ? (action.dynamicfields[field] as Function)\r\n      : null;\r\n    const _field: string = _function\r\n      ? _function.apply(action, [rowData])\r\n      : action[field];\r\n    return _field;\r\n  }\r\n  callDisabled(action: KvMenuItem, data: any): boolean {\r\n    if (action?.disabled) {\r\n      return action.disabled(data);\r\n    }\r\n    return false;\r\n  }\r\n  criarMenusModal(data: any, rowNode: any) {\r\n    if (this.config.actions && data) {\r\n      const items = this.config.actions.map((action) => {\r\n        const icon = this.retornarCampo(action, data, 'icon');\r\n        const tooltip = this.retornarCampo(action, data, 'tooltip');\r\n        const label = this.retornarCampo(action, data, 'label');\r\n        const command: any = this.retornarCampo(action, data, 'command');\r\n        const visible: boolean = action.visible\r\n          ? action.visible(data, rowNode)\r\n          : true;\r\n        const disabled: boolean = action.disabled\r\n          ? action.disabled(data)\r\n          : false;\r\n\r\n        const menuInsert: KvMenuItem = {\r\n          label,\r\n          icon,\r\n          tooltip,\r\n          command,\r\n          disabled,\r\n          visible,\r\n        };\r\n\r\n        let item = this.menuItems.filter(\r\n          (x) => x.command == menuInsert.command\r\n        );\r\n\r\n        if (item.length == 0) this.menuItems.push(menuInsert);\r\n        else {\r\n          if (menuInsert.label != item[0].label) {\r\n            let index = this.menuItems.indexOf(item[0]);\r\n            this.menuItems.splice(index, 1);\r\n          }\r\n\r\n          if (menuInsert.visible != item[0].visible) {\r\n            let index = this.menuItems.indexOf(item[0]);\r\n            this.menuItems.splice(index, 1);\r\n          }\r\n\r\n          if (menuInsert.disabled != item[0].disabled) {\r\n            let index = this.menuItems.indexOf(item[0]);\r\n            this.menuItems.splice(index, 1);\r\n          }\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  recuperarRowNode(rowNode: any) {\r\n    return rowNode;\r\n  }\r\n\r\n  validaLinhaAcaoVazia(rowData: any, rowNode: any) {\r\n    var algumItemVisivel = this.config.actions.some((a) => {\r\n      if (typeof a.visible === 'function') {\r\n        return a.visible(rowData, rowNode) === true;\r\n      } else {\r\n        return true; // Retorna true se a.visible(rowData) não existir\r\n      }\r\n    });\r\n\r\n    return !algumItemVisivel;\r\n  }\r\n\r\n  toggleNodes() {\r\n    if (this.isExpanded) {\r\n      this.collapseAll();\r\n    } else {\r\n      this.expandAll();\r\n    }\r\n    this.isExpanded = !this.isExpanded;\r\n  }\r\n\r\n  expandAll(): void {\r\n    this.dataSource.forEach((node) => {\r\n      this.expandCollapseRecursive(node, true);\r\n    });\r\n  }\r\n\r\n  collapseAll(): void {\r\n    this.dataSource.forEach((node) => {\r\n      this.expandCollapseRecursive(node, false);\r\n    });\r\n  }\r\n\r\n  private expandCollapseRecursive(node: TreeNode, isExpand: boolean): void {\r\n    node.expanded = isExpand;\r\n    if (node.children) {\r\n      node.children.forEach((childNode) => {\r\n        this.expandCollapseRecursive(childNode, isExpand);\r\n      });\r\n      this.dataSource = [...this.dataSource];\r\n    }\r\n  }\r\n\r\n  doubleClick(e: any, rowData: any, rowNode: any) {\r\n    let eventDoubleClick = { event: e, rowData: rowData, rowNode: rowNode };\r\n\r\n    let array: string[] = [];\r\n    e.target.classList.forEach((x: any) => array.push(x));\r\n\r\n    if (array.find((x: any) => x == 'ng-star-inserted') != undefined)\r\n      this.doubleClickEvent.emit(eventDoubleClick);\r\n  }\r\n  isDisabledCheckbox(rowData: any, rowNode: any): boolean {\r\n    return this.config.disableControlCheckboxFunction\r\n      ? this.config.disableControlCheckboxFunction(rowData, rowNode)\r\n      : false;\r\n  }\r\n}\r\n","<div>\r\n  <p-treeTable\r\n    #tt\r\n    *ngIf=\"config\"\r\n    [value]=\"dataSource\"\r\n    styleClass=\"p-datatable-sm\"\r\n    [columns]=\"config.columns\"\r\n    [(selection)]=\"selectedItems\"\r\n    [scrollable]=\"true\"\r\n    selectionMode=\"checkbox\"\r\n    [showCurrentPageReport]=\"true\"\r\n    currentPageReportTemplate=\"{first} - {last} de {totalRecords}\"\r\n    [rowsPerPageOptions]=\"rowsPerPageOptions\"\r\n    [showFirstLastIcon]=\"showFirstLastIcon\"\r\n    [paginator]=\"paginator\"\r\n    [rows]=\"rows\"\r\n    [totalRecords]=\"tamanhoTotalTree\"\r\n    [lazy]=\"config.lazy\"\r\n    (onLazyLoad)=\"paginate($event)\"\r\n    rowGroupMode=\"rowspan\"\r\n    responsiveLayout=\"stack\"\r\n  >\r\n    <ng-template pTemplate=\"caption\" *ngIf=\"config.enableCation\">\r\n      <div\r\n        class=\"flex flex-row flex-wrap justify-content-between align-items-center grid formgrid p-fluid col-12\"\r\n      >\r\n        <div class=\"col-12 flex flex-column\">\r\n          <div *ngIf=\"config.title\" class=\"text-md font-bold my-3\">\r\n            {{ config.title }}\r\n          </div>\r\n          <div *ngIf=\"config.subtitle\" class=\"text-sm mb-4 font-medium\">\r\n            {{ config.subtitle }}\r\n          </div>\r\n        </div>\r\n\r\n        <div \r\n          [class]=\"\r\n            tamanhoTela < 768\r\n              ? 'flex flex-row align-items-center col-10 md:col-6 lg:col-4 justify-content-center'\r\n              : 'flex flex-row align-items-center col-12 md:col-6 lg:col-4 justify-content-center input-search'\r\n          \"\r\n        >\r\n          <span\r\n            *ngIf=\"config.enableFilter\"\r\n            class=\"block mt-2 md:mt-0 p-input-icon-left text-align-center\"\r\n          >\r\n            <i\r\n              class=\"material-symbols-outlined icon-search\"\r\n              style=\"display: inline-block\"\r\n            >\r\n              search\r\n            </i>\r\n\r\n            <input\r\n              pInputText\r\n              pAutoFocus\r\n              [autofocus]=\"true\"\r\n              type=\"text\"\r\n              (input)=\"onGlobalFilter(tt, $event)\"\r\n              placeholder=\"Pesquisar...\"\r\n              class=\"w-full mb-1\"\r\n              style=\"height: 40px\"\r\n            />\r\n          </span>\r\n\r\n          <div *ngIf=\"config.enableToggleNodes\">\r\n            <button\r\n              (click)=\"toggleNodes()\"\r\n              id=\"recolherExpandirBtn\"\r\n              [pTooltip]=\"isExpanded ? 'Recolher Todos' : 'Expandir Todos'\"\r\n              pButton\r\n              class=\"recolherExpandirBtn toggle p-button-raised p-button-text\"\r\n            >\r\n              <span\r\n                class=\"pi\"\r\n                [ngClass]=\"{\r\n                  'pi-chevron-down': isExpanded,\r\n                  ' pi-chevron-right': !isExpanded\r\n                }\"\r\n              >\r\n              </span>\r\n            </button>\r\n          </div>\r\n        </div>\r\n\r\n        <div class=\"flex flex-row col-1 justify-content-end\">\r\n          <div *ngFor=\"let action of config.actionsLote\" class=\"btns-options\">\r\n            <button\r\n              id=\"actionLoteBtns\"\r\n              pButton\r\n              *ngIf=\"\r\n                (selectedItems.length > 0 || action.showAcoesLote) &&\r\n                exibirCampo(action, this.action)\r\n              \"\r\n              class=\"actionLoteBtns p-button-raised p-button-text\"\r\n              (click)=\"action?.command(commandEvent); activeItemLote(selectedItems)\"\r\n              [pTooltip]=\"retornarCampo(action, selectedItems, 'tooltip')\"\r\n              [tooltipPosition]=\"'bottom'\"\r\n              [style.backgroundColor]=\"\r\n                retornarCampo(action, selectedItems, 'btnColor')\r\n              \"\r\n              [disabled]=\"retornarCampo(action, selectedItems, 'disabled')\"\r\n            >\r\n              <span\r\n                class=\"material-symbols-outlined md-22\"\r\n                [style.color]=\"\r\n                  retornarCampo(action, selectedItems, 'iconBtnColor')\r\n                \"\r\n              >\r\n                {{ retornarCampo(action, selectedItems, \"icon\") }}\r\n              </span>\r\n            </button>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </ng-template>\r\n\r\n    <ng-template pTemplate=\"header\" let-columns>\r\n      <tr>\r\n        <th\r\n          *ngFor=\"let col of columns; index as i\"\r\n          [ttSortableColumn]=\"col.field\"\r\n          [ttSortableColumnDisabled]=\"col.sortable === false\"\r\n          class=\"text-sm\"\r\n          [style.width]=\"col.width\"\r\n        >\r\n          <div>\r\n            <div [ngClass]=\"{ flex: i == 0, 'gap-3': i == 0 }\">\r\n              <div *ngIf=\"i == 0 && config.enableSelect\">\r\n                <p-treeTableHeaderCheckbox\r\n                  (click)=\"activeItemLote(selectedItems)\"\r\n                ></p-treeTableHeaderCheckbox>\r\n              </div>\r\n\r\n              <div\r\n                [class]=\"\r\n                  centralizarColunas(col) && alignColunasHeader(col) == ''\r\n                    ? 'flex flex-row justify-content-center'\r\n                    : 'flex flex-row'\r\n                \"\r\n                [style]=\"alignColunasHeader(col)\"\r\n              >\r\n                <span>{{ col.header }}</span>\r\n                <p-sortIcon\r\n                  *ngIf=\"col.sortable === true\"\r\n                  [field]=\"col.field\"\r\n                  style=\"font-size: 10px\"\r\n                ></p-sortIcon>\r\n\r\n                <span\r\n                  *ngIf=\"col.headerTooltip\"\r\n                  class=\"material-symbols-outlined flex align-items-center\"\r\n                  [pTooltip]=\"col.headerTooltip\"\r\n                  >info</span\r\n                >\r\n              </div>\r\n            </div>\r\n          </div>\r\n        </th>\r\n      </tr>\r\n    </ng-template>\r\n\r\n    <ng-template \r\n      pTemplate=\"body\"\r\n      let-rowNode\r\n      let-rowData=\"rowData\"\r\n      let-columns=\"columns\"\r\n      let-rowgroup=\"rowgroup\"\r\n      let-rowspan=\"rowspan\"\r\n    >\r\n\r\n      <tr \r\n        [ttRow]=\"rowNode\"\r\n        *ngIf=\"rowNode.level == 0\"\r\n        [style.height]=\"espacamentoPai\"\r\n      ></tr>\r\n\r\n      <tr [ttRow]=\"rowNode\" (dblclick)=\"doubleClick($event, rowData, rowNode)\">\r\n        <ng-container *ngFor=\"let col of columns; index as i\" >\r\n          <td\r\n            [style.width]=\"col.width\"\r\n            [ngClass]=\"{ 'margem-filho': rowNode.level != 0 }\"\r\n            *ngIf=\"rowgroup && !col.template\"\r\n            [attr.rowspan]=\"rowgroup && col.grouped ? rowspan : null\"\r\n            class=\"rowTable\"\r\n            [style]=\"\r\n              applyStyle(rowData, col) +\r\n              centralizarColunas(col) +\r\n              alignColunas(col)\r\n            \"\r\n          >\r\n            <div\r\n              class=\"w-full-h-full flex\"  \r\n              [style]=\"centralizarColunas(col)\"\r\n              [ngClass]=\"{ 'justify-content-between': i == columns.length - 1 }\"\r\n            >\r\n              <div class=\"w-full-h-full flex align-items-center\" *ngIf=\"i == 0\">\r\n                <p-treeTableCheckbox\r\n                  [disabled]=\"isDisabledCheckbox(rowData, rowNode)\"\r\n                  (click)=\"activeItemLote(selectedItems)\"\r\n                  [value]=\"rowNode\"\r\n                  *ngIf=\"config.enableSelect == true\"\r\n                ></p-treeTableCheckbox>\r\n\r\n                <p-treeTableToggler\r\n                  [rowNode]=\"rowNode\"\r\n                  *ngIf=\"!rightCollapse\"\r\n                ></p-treeTableToggler>\r\n                <p-treeTableToggler\r\n                  class=\"hiddenVisible\"\r\n                  [rowNode]=\"rowNode\"\r\n                  *ngIf=\"rightCollapse\"\r\n                ></p-treeTableToggler>\r\n              </div>\r\n\r\n              <span\r\n                *ngIf=\"!isBooleanField(rowData, col); else booleanField\"\r\n                [class]=\"returnRowClass(rowData, col)\"\r\n              >\r\n                <span\r\n                  *ngIf=\"\r\n                    !isChipField(col) && !col.iconField && !isImageField(col)\r\n                  \"\r\n                >\r\n                  <i *ngIf=\"col.icon\" [class]=\"col.icon + ' mr-2'\"></i>\r\n                  {{ transformValue(rowData, col) }}\r\n                </span>\r\n\r\n                <div *ngIf=\"isChipField(col) && !col.iconField\">\r\n                  <span\r\n                    [class]=\"returnClassChip(rowData, col)\"\r\n                    [pTooltip]=\"returnTooltipIcon(rowData, col)\"\r\n                    >{{ transformValue(rowData, col) }}</span\r\n                  >\r\n                </div>\r\n              </span>\r\n\r\n              <span *ngIf=\"isImageField(col)\">\r\n                <span>\r\n                  <img class=\"image\" [src]=\"loadImage(rowData, col)\" />\r\n                </span>\r\n              </span>\r\n\r\n              <i\r\n                *ngIf=\"col.iconField\"\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              <ng-template #booleanField>\r\n                <i\r\n                  *ngIf=\"!col.iconField\"\r\n                  [ngClass]=\"\r\n                    rowData[col.field] ? 'text-green-500' : 'text-red-500'\r\n                  \"\r\n                  ><span class=\"material-symbols-outlined\">\r\n                    {{ rowData[col.field] ? \"check\" : \"close\" }}\r\n                  </span>\r\n                </i>\r\n              </ng-template>\r\n\r\n              <div\r\n                class=\"w-full-h-full flex\"\r\n                *ngIf=\"\r\n                  i == columns.length - 1 &&\r\n                  config.actions &&\r\n                  config.actions.length > 0\r\n                \"\r\n                [style]=\"\r\n                  applyStyle(rowData, { field: 'btns-options', header: '' })\r\n                \"\r\n              >\r\n                <div\r\n                  class=\"flex flex-row justify-content-end w-full\"\r\n                  *ngIf=\"acoesLinhaTabela\"\r\n                >\r\n                  <div *ngFor=\"let action of config.actions\">\r\n                    <button\r\n                      id=\"actionBtns\"\r\n                      pButton\r\n                      *ngIf=\"exibirCampo(action, rowData)\"\r\n                      class=\"actionBtns p-button-text p-button-raised\"\r\n                      (click)=\"activeItem(rowData, rowNode); action?.command(commandEvent)\"\r\n                      [pTooltip]=\"retornarCampo(action, rowData, 'tooltip')\"\r\n                      [tooltipPosition]=\"'bottom'\"\r\n                      [disabled]=\"callDisabled(action, rowData)\"\r\n                    >\r\n                      <span class=\"material-symbols-outlined md-19\">\r\n                        {{ retornarCampo(action, rowData, \"icon\") }}</span\r\n                      >\r\n                    </button>\r\n                  </div>\r\n                </div>\r\n                <div\r\n                  class=\"flex flex-row justify-content-end w-full\"\r\n                  *ngIf=\"!acoesLinhaTabela\"\r\n                >\r\n                  <button\r\n                    id=\"moreVertBtn\"\r\n                    pButton\r\n                    class=\"actionBtns p-button-text p-button-raised\"\r\n                    (click)=\"menu.toggle($event); activeItem(rowData, rowNode)\"\r\n                  >\r\n                    <span\r\n                      class=\"material-symbols-outlined\"\r\n                      style=\"font-size: 20px\"\r\n                    >\r\n                      more_horiz\r\n                    </span>\r\n                  </button>\r\n\r\n                  <div *ngFor=\"let action of config.actions\">\r\n                    {{ criarMenusModal(rowData, rowNode) }}\r\n                  </div>\r\n\r\n                  <!-- <div *ngFor=\"let action of config.actions\">\r\n                {{ criarMenusModal(rowData) }}\r\n              </div> -->\r\n\r\n                  <p-menu\r\n                    #menu\r\n                    [popup]=\"true\"\r\n                    [model]=\"menuItems\"\r\n                    appendTo=\"body\"\r\n                  ></p-menu>\r\n                </div>\r\n              </div>\r\n            </div>\r\n          </td>\r\n\r\n          <td \r\n            [style.width]=\"col.width\"\r\n            [ngClass]=\"{\r\n              'margem-filho': rowNode.level != 0,\r\n              'justify-content-between': i == columns.length - 1\r\n            }\"\r\n            *ngIf=\"!rowgroup && !col.grouped && !col.template\"\r\n            [style]=\"\r\n              applyStyle(rowData, col) +\r\n              centralizarColunas(col) +\r\n              alignColunas(col)\r\n            \"\r\n            class=\"rowTable\"\r\n          >\r\n          <div\r\n              class=\"w-full-h-full flex justify-content-between\"\r\n              [ngClass]=\"{ 'justify-content-between': i == columns.length - 1 }\"\r\n            >\r\n              <!-- Toggle -->\r\n              <div class=\"w-full-h-full flex align-items-center d-toggle\" *ngIf=\"i == 0\">\r\n                <p-treeTableCheckbox\r\n                  [disabled]=\"isDisabledCheckbox(rowData, rowNode)\"\r\n                  (click)=\"activeItemLote(selectedItems)\"\r\n                  [value]=\"rowNode\"\r\n                  *ngIf=\"config.enableSelect == true\"\r\n                ></p-treeTableCheckbox>\r\n\r\n                <p-treeTableToggler\r\n                  [rowNode]=\"rowNode\"\r\n                  *ngIf=\"!rightCollapse\"\r\n                ></p-treeTableToggler>\r\n                <p-treeTableToggler\r\n                  class=\"hiddenVisible\"\r\n                  [rowNode]=\"rowNode\"\r\n                  *ngIf=\"rightCollapse\"\r\n                ></p-treeTableToggler>\r\n              </div>\r\n\r\n              <!-- Texto -->\r\n              <div\r\n                class=\"w-full flex align-items-center\"\r\n                [style]=\"centralizarColunas(col)\"\r\n              >\r\n                <span\r\n                  *ngIf=\"!isBooleanField(rowData, col); else booleanField\"\r\n                  [class]=\"returnRowClass(rowData, col)\"\r\n                >\r\n                  <span\r\n                    *ngIf=\"\r\n                      !isChipField(col) && !col.iconField && !isImageField(col)\r\n                    \"\r\n                  >\r\n                    <i *ngIf=\"col.icon\" [class]=\"col.icon + ' mr-2'\"></i>\r\n                    {{ transformValue(rowData, col) }}\r\n                  </span>\r\n\r\n                  <div *ngIf=\"isChipField(col) && !col.iconField\">\r\n                    <span\r\n                      [class]=\"returnClassChip(rowData, col)\"\r\n                      [pTooltip]=\"returnTooltipIcon(rowData, col)\"\r\n                    >\r\n                      {{ transformValue(rowData, col) }}</span\r\n                    >\r\n                  </div>\r\n                </span>\r\n\r\n                <span *ngIf=\"isImageField(col)\">\r\n                  <span>\r\n                    <img class=\"image\" [src]=\"loadImage(rowData, col)\" />\r\n                  </span>\r\n                </span>\r\n\r\n                <i\r\n                  *ngIf=\"col.iconField\"\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                <ng-template #booleanField>\r\n                  <i\r\n                    *ngIf=\"!col.iconField\"\r\n                    [ngClass]=\"\r\n                      rowData[col.field] ? 'text-green-500' : 'text-red-500'\r\n                    \"\r\n                    ><span class=\"material-symbols-outlined\">\r\n                      {{ rowData[col.field] ? \"check\" : \"close\" }}\r\n                    </span>\r\n                  </i>\r\n                </ng-template>\r\n              </div>\r\n\r\n              <!-- Botao de ação -->\r\n              <div\r\n                class=\"w-full-h-full flex\"\r\n                *ngIf=\"\r\n                  i == columns.length - 1 &&\r\n                  config.actions &&\r\n                  config.actions.length > 0\r\n                \"\r\n                [style]=\"\r\n                  applyStyle(rowData, { field: 'btns-options', header: '' })\r\n                \"\r\n              >\r\n                <div\r\n                  class=\"flex flex-row justify-content-end w-full\"\r\n                  *ngIf=\"acoesLinhaTabela\"\r\n                >\r\n                  <div *ngFor=\"let action of config.actions\">\r\n                    <button\r\n                      id=\"actionBtns\"\r\n                      pButton\r\n                      *ngIf=\"exibirCampo(action, rowData)\"\r\n                      class=\"actionBtns p-button-text p-button-raised\"\r\n                      (click)=\"activeItem(rowData, rowNode); action?.command(commandEvent)\"\r\n                      [pTooltip]=\"retornarCampo(action, rowData, 'tooltip')\"\r\n                      [tooltipPosition]=\"'bottom'\"\r\n                      [disabled]=\"callDisabled(action, rowData)\"\r\n                    >\r\n                      <span class=\"material-symbols-outlined md-19\">\r\n                        {{ retornarCampo(action, rowData, \"icon\") }}</span\r\n                      >\r\n                    </button>\r\n                  </div>\r\n                </div>\r\n                <div\r\n                  class=\"flex flex-row justify-content-end w-full\"\r\n                  *ngIf=\"!acoesLinhaTabela\"\r\n                >\r\n                  <button\r\n                    id=\"moreVertBtn\"\r\n                    pButton\r\n                    class=\"actionBtns p-button-text p-button-raised\"\r\n                    (click)=\"menu.toggle($event); activeItem(rowData, rowNode)\"\r\n                  >\r\n                    <span\r\n                      class=\"material-symbols-outlined\"\r\n                      style=\"font-size: 20px\"\r\n                    >\r\n                      more_horiz\r\n                    </span>\r\n                  </button>\r\n\r\n                  <div *ngFor=\"let action of config.actions\">\r\n                    {{ criarMenusModal(rowData, rowNode) }}\r\n                  </div>\r\n\r\n                  <!-- <div *ngFor=\"let action of config.actions\">\r\n                  {{ criarMenusModal(rowData) }}\r\n                </div> -->\r\n\r\n                  <p-menu\r\n                    #menu\r\n                    [popup]=\"true\"\r\n                    [model]=\"menuItems\"\r\n                    appendTo=\"body\"\r\n                  ></p-menu>\r\n                </div>\r\n              </div>\r\n            </div>\r\n          </td>\r\n\r\n          <td\r\n            [style.width]=\"col.width\"\r\n            [ngClass]=\"{\r\n              'margem-filho': rowNode.level != 0,\r\n              'justify-content-between': i == columns.length - 1\r\n            }\"\r\n            *ngIf=\"col.template\"\r\n            [style]=\"\r\n              applyStyle(rowData, col) +\r\n              centralizarColunas(col) +\r\n              alignColunas(col)\r\n            \"\r\n            class=\"rowTable\"\r\n          >\r\n            <div class=\"flex\" [style]=\"centralizarColunas(col)\">\r\n              <div class=\"w-full-h-full flex align-items-center\" *ngIf=\"i == 0\">\r\n                <p-treeTableCheckbox\r\n                  [disabled]=\"isDisabledCheckbox(rowData, rowNode)\"\r\n                  (click)=\"activeItemLote(selectedItems)\"\r\n                  [value]=\"rowNode\"\r\n                  *ngIf=\"config.enableSelect == true\"\r\n                ></p-treeTableCheckbox>\r\n\r\n                <p-treeTableToggler\r\n                  [rowNode]=\"rowNode\"\r\n                  *ngIf=\"!rightCollapse\"\r\n                ></p-treeTableToggler>\r\n                <p-treeTableToggler\r\n                  class=\"hiddenVisible\"\r\n                  [rowNode]=\"rowNode\"\r\n                  *ngIf=\"rightCollapse\"\r\n                ></p-treeTableToggler>\r\n              </div>\r\n              <ng-container\r\n                *ngIf=\"getCustomTemplate(col.template.name)\"\r\n                [ngTemplateOutlet]=\"getCustomTemplate(col.template.name)\"\r\n                [ngTemplateOutletContext]=\"{ $implicit: rowData }\"\r\n              >\r\n              </ng-container>\r\n\r\n              <div\r\n                class=\"w-full-h-full flex\"\r\n                *ngIf=\"\r\n                  i == columns.length - 1 &&\r\n                  config.actions &&\r\n                  config.actions.length > 0\r\n                \"\r\n                [style]=\"\r\n                  applyStyle(rowData, { field: 'btns-options', header: '' })\r\n                \"\r\n              >\r\n                <div\r\n                  class=\"flex flex-row justify-content-end w-full\"\r\n                  *ngIf=\"acoesLinhaTabela\"\r\n                >\r\n                  <div *ngFor=\"let action of config.actions\">\r\n                    <button\r\n                      id=\"actionBtns\"\r\n                      pButton\r\n                      *ngIf=\"exibirCampo(action, rowData)\"\r\n                      class=\"actionBtns p-button-text p-button-raised\"\r\n                      (click)=\"activeItem(rowData, rowNode); action?.command(commandEvent)\"\r\n                      [pTooltip]=\"retornarCampo(action, rowData, 'tooltip')\"\r\n                      [tooltipPosition]=\"'bottom'\"\r\n                      [disabled]=\"callDisabled(action, rowData)\"\r\n                    >\r\n                      <span class=\"material-symbols-outlined md-19\">\r\n                        {{ retornarCampo(action, rowData, \"icon\") }}</span\r\n                      >\r\n                    </button>\r\n                  </div>\r\n                </div>\r\n                <div\r\n                  class=\"flex flex-row justify-content-end w-full\"\r\n                  *ngIf=\"!acoesLinhaTabela\"\r\n                >\r\n                  <button\r\n                    id=\"moreVertBtn\"\r\n                    pButton\r\n                    class=\"actionBtns p-button-text p-button-raised\"\r\n                    (click)=\"menu.toggle($event); activeItem(rowData, rowNode)\"\r\n                  >\r\n                    <span\r\n                      class=\"material-symbols-outlined\"\r\n                      style=\"font-size: 20px\"\r\n                    >\r\n                      more_horiz\r\n                    </span>\r\n                  </button>\r\n\r\n                  <div *ngFor=\"let action of config.actions\">\r\n                    {{ criarMenusModal(rowData, rowNode) }}\r\n                  </div>\r\n\r\n                  <!-- <div *ngFor=\"let action of config.actions\">\r\n                  {{ criarMenusModal(rowData) }}\r\n                </div> -->\r\n\r\n                  <p-menu\r\n                    #menu\r\n                    [popup]=\"true\"\r\n                    [model]=\"menuItems\"\r\n                    appendTo=\"body\"\r\n                  ></p-menu>\r\n                </div>\r\n              </div>\r\n            </div>\r\n          </td>\r\n          \r\n        </ng-container>\r\n      </tr>\r\n\r\n    </ng-template>\r\n\r\n    <!-- :: Hotfix do bug da versão 15 do primeng, ao retirar esse bloco de codigo na versão 15 do primeng os icones de prev e next do paginator irão sumir ( resolvido na versão 16.0)  :: -->\r\n\r\n    <ng-template pTemplate=\"paginatorfirstpagelinkicon\">\r\n      <span class=\"pi pi-angle-double-left\"></span>\r\n    </ng-template>\r\n    <ng-template pTemplate=\"paginatorpreviouspagelinkicon\">\r\n      <span class=\"pi pi-angle-left\"></span>\r\n    </ng-template>\r\n    <ng-template pTemplate=\"paginatornextpagelinkicon\">\r\n      <span class=\"pi pi-angle-right\"></span>\r\n    </ng-template>\r\n    <ng-template pTemplate=\"paginatorlastpagelinkicon\">\r\n      <span class=\"pi pi-angle-double-right\"></span>\r\n    </ng-template>\r\n\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;\r\n          border-radius: 10px !important;\r\n          \"\r\n        >\r\n         <p class=\"font-semibold\"> Nenhum registro encontrado </p>\r\n        </td>\r\n      </tr>\r\n    </ng-template>\r\n  </p-treeTable>\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"]}
371
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-treetable.component.js","sourceRoot":"","sources":["../../../../../projects/keevo-components/src/lib/tree-table/kv-treetable.component.ts","../../../../../projects/keevo-components/src/lib/tree-table/kv-treetable.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ContentChildren,\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} from '@angular/core';\r\nimport { MenuItemCommandEvent, TreeNode } from 'primeng/api';\r\nimport {\r\n  CodigoFipePipe,\r\n  CpfCnpjPipe,\r\n  KvMenuItem,\r\n  TableConfig,\r\n  TableConfigColumn,\r\n  TablePaginate,\r\n  TelefonePipe,\r\n} from '../../public-api';\r\nimport { Table } from 'primeng/table';\r\nimport { TreeTable } from 'primeng/treetable';\r\nimport { DatePipe, DecimalPipe } from '@angular/common';\r\nimport { DomSanitizer } from '@angular/platform-browser';\r\nimport { TemplateDirective } from '../directives/template.directive';\r\n\r\ninterface Column {\r\n  field: string;\r\n  header: string;\r\n}\r\n\r\n@Component({\r\n  selector: 'kv-treetable',\r\n  templateUrl: './kv-treetable.component.html',\r\n  styleUrls: ['./kv-treetable.component.scss'],\r\n})\r\nexport class TreeTableComponent implements OnInit {\r\n  @Input() config!: TableConfig;\r\n  @Input() dataSource!: TreeNode[];\r\n  @Input() selectedItems: any = [];\r\n\r\n  @Input() acoesLinhaTabela: boolean = true;\r\n\r\n  @Input() espacamentoPai: string = '2px';\r\n  @Input() espacamentoLateral: boolean = true;\r\n\r\n  @Input() tamanhoTotalTree!: number;\r\n  @Input() rowsPerPageOptions!: number[];\r\n  @Input() rows: number = 5;\r\n  @Input() tableSize!: number;\r\n  @Input() paginator: boolean = true;\r\n  @Input() showFirstLastIcon: boolean = false;\r\n  @Input() rightCollapse: boolean = false;\r\n  @Input() applyStyle: Function = (rowData: any, col: TableConfigColumn) => '';\r\n\r\n  @Input('templates') _templates!: any;\r\n\r\n  @Input() colorButtonToggleNodes: string = 'surface-600';\r\n\r\n  @ContentChildren(TemplateDirective) templates!: QueryList<any>;\r\n  @ViewChild('table', { static: false }) table!: Table;\r\n\r\n  @Output() onFilter: EventEmitter<any> = new EventEmitter();\r\n  @Output() onPaginate: EventEmitter<any> = new EventEmitter();\r\n  @Output() onActiveItem: EventEmitter<any> = new EventEmitter();\r\n  @Output() onActiveItemLote: EventEmitter<any> = new EventEmitter();\r\n  @Output() doubleClickEvent: EventEmitter<any> = new EventEmitter();\r\n  tamanhoTela!: number;\r\n  selectedSize: string = '';\r\n  nodeContext = { $implicit: 'rowData', rowNode: 'rowNode' };\r\n\r\n  selectedNodes!: TreeNode[];\r\n  menuItems: KvMenuItem[] = [];\r\n  imgDefault: string =\r\n    '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';\r\n\r\n  isExpanded: boolean = false;\r\n\r\n  commandEvent!: MenuItemCommandEvent;\r\n\r\n  constructor(\r\n    private readonly datePipe: DatePipe,\r\n    private readonly decimalPipe: DecimalPipe,\r\n    private readonly codigoFipePipe: CodigoFipePipe,\r\n    private readonly cpfCnpjPipe: CpfCnpjPipe,\r\n    private readonly telefonePipe: TelefonePipe\r\n  ) {}\r\n\r\n  ngOnInit() {\r\n    this.tamanhoTela = window.innerWidth;\r\n  }\r\n\r\n  public onGlobalFilter(table: TreeTable, event: Event) {\r\n    this.onFilter.emit((event.target as HTMLInputElement).value);\r\n    table.filterGlobal((event.target as HTMLInputElement).value, 'contains');\r\n  }\r\n  @HostListener('window:resize', ['$event'])\r\n  onWindowResize() {\r\n    this.adjustTableSize();\r\n    this.tamanhoTela = window.innerWidth;\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  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} ${\r\n          $event.sortOrder === 1 ? 'ASC' : 'DESC'\r\n        }`;\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      };\r\n\r\n      this.onPaginate.emit(objeto);\r\n    }\r\n  }\r\n\r\n  isBooleanField(rowData: any, col: TableConfigColumn): boolean {\r\n    return col.fieldType == 'boolean';\r\n  }\r\n\r\n  isChipField(col: TableConfigColumn): boolean {\r\n    return col.fieldType == 'chip';\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  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  transformValue(rowData: any, col: TableConfigColumn) {\r\n    let value = rowData[col.field];\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');\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 'codigofipe':\r\n          return this.codigoFipePipe.transform(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  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  centralizarColunas(col: any): string {\r\n    if (col.centralize) {\r\n      return 'text-align: center; ';\r\n    } else return '';\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  returnClassIcon(rowData: any, col: any): string {\r\n    return this.retornarRow(rowData, col, 'iconrow');\r\n  }\r\n\r\n  returnTooltipIcon(rowData: any, col: any): string {\r\n    return this.retornarRow(rowData, col, 'tooltipiconrow');\r\n  }\r\n  returnClassChip(rowData: any, col: any): 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    )} border-${this.retornarRow(rowData, col, 'stylechip')}`;\r\n  }\r\n  retornarRow(rowData: any, col: any, 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  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  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, ${this.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  getCustomTemplate(templatename: string): TemplateRef<any> {\r\n    return this._templates[templatename];\r\n  }\r\n  exibirCampo(field: any, rowData: any) {\r\n    let visible = field.visible ? field.visible(rowData) : true;\r\n    return visible;\r\n  }\r\n  public activeItem(rowData: any, rowNode: any) {\r\n    console.log(rowNode);\r\n    this.onActiveItem.emit({ rowData: rowData, rowNode: rowNode });\r\n  }\r\n  public activeItemLote(rowData: any) {\r\n    this.onActiveItemLote.emit(rowData);\r\n  }\r\n\r\n  retornarCampo(action: KvMenuItem, rowData: any, field: string): string {\r\n    const _function = action.dynamicfields\r\n      ? (action.dynamicfields[field] as Function)\r\n      : null;\r\n    const _field: string = _function\r\n      ? _function.apply(action, [rowData])\r\n      : action[field];\r\n    return _field;\r\n  }\r\n  callDisabled(action: KvMenuItem, data: any): boolean {\r\n    if (action?.disabled) {\r\n      return action.disabled(data);\r\n    }\r\n    return false;\r\n  }\r\n  criarMenusModal(data: any, rowNode: any) {\r\n    if (this.config.actions && data) {\r\n      const items = this.config.actions.map((action) => {\r\n        const icon = this.retornarCampo(action, data, 'icon');\r\n        const tooltip = this.retornarCampo(action, data, 'tooltip');\r\n        const label = this.retornarCampo(action, data, 'label');\r\n        const command: any = this.retornarCampo(action, data, 'command');\r\n        const visible: boolean = action.visible\r\n          ? action.visible(data, rowNode)\r\n          : true;\r\n        const disabled: boolean = action.disabled\r\n          ? action.disabled(data)\r\n          : false;\r\n\r\n        const menuInsert: KvMenuItem = {\r\n          label,\r\n          icon,\r\n          tooltip,\r\n          command,\r\n          disabled,\r\n          visible,\r\n        };\r\n\r\n        let item = this.menuItems.filter(\r\n          (x) => x.command == menuInsert.command\r\n        );\r\n\r\n        if (item.length == 0) this.menuItems.push(menuInsert);\r\n        else {\r\n          if (menuInsert.label != item[0].label) {\r\n            let index = this.menuItems.indexOf(item[0]);\r\n            this.menuItems.splice(index, 1);\r\n          }\r\n\r\n          if (menuInsert.visible != item[0].visible) {\r\n            let index = this.menuItems.indexOf(item[0]);\r\n            this.menuItems.splice(index, 1);\r\n          }\r\n\r\n          if (menuInsert.disabled != item[0].disabled) {\r\n            let index = this.menuItems.indexOf(item[0]);\r\n            this.menuItems.splice(index, 1);\r\n          }\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  recuperarRowNode(rowNode: any) {\r\n    return rowNode;\r\n  }\r\n\r\n  validaLinhaAcaoVazia(rowData: any, rowNode: any) {\r\n    var algumItemVisivel = this.config.actions.some((a) => {\r\n      if (typeof a.visible === 'function') {\r\n        return a.visible(rowData, rowNode) === true;\r\n      } else {\r\n        return true; // Retorna true se a.visible(rowData) não existir\r\n      }\r\n    });\r\n\r\n    return !algumItemVisivel;\r\n  }\r\n\r\n  toggleNodes() {\r\n    if (this.isExpanded) {\r\n      this.collapseAll();\r\n    } else {\r\n      this.expandAll();\r\n    }\r\n    this.isExpanded = !this.isExpanded;\r\n  }\r\n\r\n  expandAll(): void {\r\n    this.dataSource.forEach((node) => {\r\n      this.expandCollapseRecursive(node, true);\r\n    });\r\n  }\r\n\r\n  collapseAll(): void {\r\n    this.dataSource.forEach((node) => {\r\n      this.expandCollapseRecursive(node, false);\r\n    });\r\n  }\r\n\r\n  private expandCollapseRecursive(node: TreeNode, isExpand: boolean): void {\r\n    node.expanded = isExpand;\r\n    if (node.children) {\r\n      node.children.forEach((childNode) => {\r\n        this.expandCollapseRecursive(childNode, isExpand);\r\n      });\r\n      this.dataSource = [...this.dataSource];\r\n    }\r\n  }\r\n\r\n  doubleClick(e: any, rowData: any, rowNode: any) {\r\n    let eventDoubleClick = { event: e, rowData: rowData, rowNode: rowNode };\r\n\r\n    let array: string[] = [];\r\n    e.target.classList.forEach((x: any) => array.push(x));\r\n\r\n    //if (array.find((x: any) => x == 'ng-star-inserted') != undefined)\r\n    this.doubleClickEvent.emit(eventDoubleClick);\r\n  }\r\n  isDisabledCheckbox(rowData: any, rowNode: any): boolean {\r\n    return this.config.disableControlCheckboxFunction\r\n      ? this.config.disableControlCheckboxFunction(rowData, rowNode)\r\n      : false;\r\n  }\r\n}\r\n","<div>\r\n  <p-treeTable\r\n    #tt\r\n    *ngIf=\"config\"\r\n    [value]=\"dataSource\"\r\n    styleClass=\"p-datatable-sm\"\r\n    [columns]=\"config.columns\"\r\n    [(selection)]=\"selectedItems\"\r\n    [scrollable]=\"true\"\r\n    selectionMode=\"checkbox\"\r\n    [showCurrentPageReport]=\"true\"\r\n    currentPageReportTemplate=\"{first} - {last} de {totalRecords}\"\r\n    [rowsPerPageOptions]=\"rowsPerPageOptions\"\r\n    [showFirstLastIcon]=\"showFirstLastIcon\"\r\n    [paginator]=\"paginator\"\r\n    [rows]=\"rows\"\r\n    [totalRecords]=\"tamanhoTotalTree\"\r\n    [lazy]=\"config.lazy\"\r\n    (onLazyLoad)=\"paginate($event)\"\r\n    rowGroupMode=\"rowspan\"\r\n    responsiveLayout=\"stack\"\r\n  >\r\n    <ng-template pTemplate=\"caption\" *ngIf=\"config.enableCation\">\r\n      <div\r\n        class=\"flex flex-row flex-wrap justify-content-between align-items-center grid formgrid p-fluid col-12\"\r\n      >\r\n        <div class=\"col-12 flex flex-column\">\r\n          <div *ngIf=\"config.title\" class=\"text-md font-bold my-3\">\r\n            {{ config.title }}\r\n          </div>\r\n          <div *ngIf=\"config.subtitle\" class=\"text-sm mb-4 font-medium\">\r\n            {{ config.subtitle }}\r\n          </div>\r\n        </div>\r\n\r\n        <div \r\n          [class]=\"\r\n            tamanhoTela < 768\r\n              ? 'flex flex-row align-items-center col-10 md:col-6 lg:col-4 justify-content-center'\r\n              : 'flex flex-row align-items-center col-12 md:col-6 lg:col-4 justify-content-center input-search'\r\n          \"\r\n        >\r\n          <span\r\n            *ngIf=\"config.enableFilter\"\r\n            class=\"block mt-2 md:mt-0 p-input-icon-left text-align-center\"\r\n          >\r\n            <i\r\n              class=\"material-symbols-outlined icon-search\"\r\n              style=\"display: inline-block\"\r\n            >\r\n              search\r\n            </i>\r\n\r\n            <input\r\n              pInputText\r\n              pAutoFocus\r\n              [autofocus]=\"true\"\r\n              type=\"text\"\r\n              (input)=\"onGlobalFilter(tt, $event)\"\r\n              placeholder=\"Pesquisar...\"\r\n              class=\"w-full mb-1\"\r\n              style=\"height: 40px\"\r\n            />\r\n          </span>\r\n\r\n          <div *ngIf=\"config.enableToggleNodes\">\r\n            <button\r\n              (click)=\"toggleNodes()\"\r\n              id=\"recolherExpandirBtn\"\r\n              [pTooltip]=\"isExpanded ? 'Recolher Todos' : 'Expandir Todos'\"\r\n              pButton\r\n              class=\"recolherExpandirBtn toggle p-button-raised p-button-text\"\r\n            >\r\n              <span\r\n                class=\"pi\"\r\n                [ngClass]=\"{\r\n                  'pi-chevron-down': isExpanded,\r\n                  ' pi-chevron-right': !isExpanded\r\n                }\"\r\n              >\r\n              </span>\r\n            </button>\r\n          </div>\r\n        </div>\r\n\r\n        <div class=\"flex flex-row col-1 justify-content-end\">\r\n          <div *ngFor=\"let action of config.actionsLote\" class=\"btns-options\">\r\n            <button\r\n              id=\"actionLoteBtns\"\r\n              pButton\r\n              *ngIf=\"\r\n                (selectedItems.length > 0 || action.showAcoesLote) &&\r\n                exibirCampo(action, this.action)\r\n              \"\r\n              class=\"actionLoteBtns p-button-raised p-button-text\"\r\n              (click)=\"action?.command(commandEvent); activeItemLote(selectedItems)\"\r\n              [pTooltip]=\"retornarCampo(action, selectedItems, 'tooltip')\"\r\n              [tooltipPosition]=\"'bottom'\"\r\n              [style.backgroundColor]=\"\r\n                retornarCampo(action, selectedItems, 'btnColor')\r\n              \"\r\n              [disabled]=\"retornarCampo(action, selectedItems, 'disabled')\"\r\n            >\r\n              <span\r\n                class=\"material-symbols-outlined md-22\"\r\n                [style.color]=\"\r\n                  retornarCampo(action, selectedItems, 'iconBtnColor')\r\n                \"\r\n              >\r\n                {{ retornarCampo(action, selectedItems, \"icon\") }}\r\n              </span>\r\n            </button>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </ng-template>\r\n\r\n    <ng-template pTemplate=\"header\" let-columns>\r\n      <tr>\r\n        <th\r\n          *ngFor=\"let col of columns; index as i\"\r\n          [ttSortableColumn]=\"col.field\"\r\n          [ttSortableColumnDisabled]=\"col.sortable === false\"\r\n          class=\"text-sm\"\r\n          [style.width]=\"col.width\"\r\n        >\r\n          <div>\r\n            <div [ngClass]=\"{ flex: i == 0, 'gap-3': i == 0 }\">\r\n              <div *ngIf=\"i == 0 && config.enableSelect\">\r\n                <p-treeTableHeaderCheckbox\r\n                  (click)=\"activeItemLote(selectedItems)\"\r\n                ></p-treeTableHeaderCheckbox>\r\n              </div>\r\n\r\n              <div\r\n                [class]=\"\r\n                  centralizarColunas(col) && alignColunasHeader(col) == ''\r\n                    ? 'flex flex-row justify-content-center'\r\n                    : 'flex flex-row'\r\n                \"\r\n                [style]=\"alignColunasHeader(col)\"\r\n              >\r\n                <span>{{ col.header }}</span>\r\n                <p-sortIcon\r\n                  *ngIf=\"col.sortable === true\"\r\n                  [field]=\"col.field\"\r\n                  style=\"font-size: 10px\"\r\n                ></p-sortIcon>\r\n\r\n                <span\r\n                  *ngIf=\"col.headerTooltip\"\r\n                  class=\"material-symbols-outlined flex align-items-center\"\r\n                  [pTooltip]=\"col.headerTooltip\"\r\n                  >info</span\r\n                >\r\n              </div>\r\n            </div>\r\n          </div>\r\n        </th>\r\n      </tr>\r\n    </ng-template>\r\n\r\n    <ng-template \r\n      pTemplate=\"body\"\r\n      let-rowNode\r\n      let-rowData=\"rowData\"\r\n      let-columns=\"columns\"\r\n      let-rowgroup=\"rowgroup\"\r\n      let-rowspan=\"rowspan\"\r\n    >\r\n\r\n      <tr \r\n        [ttRow]=\"rowNode\"\r\n        *ngIf=\"rowNode.level == 0\"\r\n        [style.height]=\"espacamentoPai\"\r\n      ></tr>\r\n\r\n      <tr [ttRow]=\"rowNode\" (dblclick)=\"doubleClick($event, rowData, rowNode)\">\r\n        <ng-container *ngFor=\"let col of columns; index as i\" >\r\n          <td\r\n            [style.width]=\"col.width\"\r\n            [ngClass]=\"{ 'margem-filho': rowNode.level != 0 }\"\r\n            *ngIf=\"rowgroup && !col.template\"\r\n            [attr.rowspan]=\"rowgroup && col.grouped ? rowspan : null\"\r\n            class=\"rowTable\"\r\n            [style]=\"\r\n              applyStyle(rowData, col) +\r\n              centralizarColunas(col) +\r\n              alignColunas(col)\r\n            \"\r\n          >\r\n            <div\r\n              class=\"w-full-h-full flex\"  \r\n              [style]=\"centralizarColunas(col)\"\r\n              [ngClass]=\"{ 'justify-content-between': i == columns.length - 1 }\"\r\n            >\r\n              <div class=\"w-full-h-full flex align-items-center\" *ngIf=\"i == 0\">\r\n                <p-treeTableCheckbox\r\n                  [disabled]=\"isDisabledCheckbox(rowData, rowNode)\"\r\n                  (click)=\"activeItemLote(selectedItems)\"\r\n                  [value]=\"rowNode\"\r\n                  *ngIf=\"config.enableSelect == true\"\r\n                ></p-treeTableCheckbox>\r\n\r\n                <p-treeTableToggler\r\n                  [rowNode]=\"rowNode\"\r\n                  *ngIf=\"!rightCollapse\"\r\n                ></p-treeTableToggler>\r\n                <p-treeTableToggler\r\n                  class=\"hiddenVisible\"\r\n                  [rowNode]=\"rowNode\"\r\n                  *ngIf=\"rightCollapse\"\r\n                ></p-treeTableToggler>\r\n              </div>\r\n\r\n              <span\r\n                *ngIf=\"!isBooleanField(rowData, col); else booleanField\"\r\n                [class]=\"returnRowClass(rowData, col)\"\r\n              >\r\n                <span\r\n                  *ngIf=\"\r\n                    !isChipField(col) && !col.iconField && !isImageField(col)\r\n                  \"\r\n                >\r\n                  <i *ngIf=\"col.icon\" [class]=\"col.icon + ' mr-2'\"></i>\r\n                  {{ transformValue(rowData, col) }}\r\n                </span>\r\n\r\n                <div *ngIf=\"isChipField(col) && !col.iconField\">\r\n                  <span\r\n                    [class]=\"returnClassChip(rowData, col)\"\r\n                    [pTooltip]=\"returnTooltipIcon(rowData, col)\"\r\n                    >{{ transformValue(rowData, col) }}</span\r\n                  >\r\n                </div>\r\n              </span>\r\n\r\n              <span *ngIf=\"isImageField(col)\">\r\n                <span>\r\n                  <img class=\"image\" [src]=\"loadImage(rowData, col)\" />\r\n                </span>\r\n              </span>\r\n\r\n              <i\r\n                *ngIf=\"col.iconField\"\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              <ng-template #booleanField>\r\n                <i\r\n                  *ngIf=\"!col.iconField\"\r\n                  [ngClass]=\"\r\n                    rowData[col.field] ? 'text-green-500' : 'text-red-500'\r\n                  \"\r\n                  ><span class=\"material-symbols-outlined\">\r\n                    {{ rowData[col.field] ? \"check\" : \"close\" }}\r\n                  </span>\r\n                </i>\r\n              </ng-template>\r\n\r\n              <div\r\n                class=\"w-full-h-full flex\"\r\n                *ngIf=\"\r\n                  i == columns.length - 1 &&\r\n                  config.actions &&\r\n                  config.actions.length > 0\r\n                \"\r\n                [style]=\"\r\n                  applyStyle(rowData, { field: 'btns-options', header: '' })\r\n                \"\r\n              >\r\n                <div\r\n                  class=\"flex flex-row justify-content-end w-full\"\r\n                  *ngIf=\"acoesLinhaTabela\"\r\n                >\r\n                  <div *ngFor=\"let action of config.actions\">\r\n                    <button\r\n                      id=\"actionBtns\"\r\n                      pButton\r\n                      *ngIf=\"exibirCampo(action, rowData)\"\r\n                      class=\"actionBtns p-button-text p-button-raised\"\r\n                      (click)=\"activeItem(rowData, rowNode); action?.command(commandEvent)\"\r\n                      [pTooltip]=\"retornarCampo(action, rowData, 'tooltip')\"\r\n                      [tooltipPosition]=\"'bottom'\"\r\n                      [disabled]=\"callDisabled(action, rowData)\"\r\n                    >\r\n                      <span class=\"material-symbols-outlined md-19\">\r\n                        {{ retornarCampo(action, rowData, \"icon\") }}</span\r\n                      >\r\n                    </button>\r\n                  </div>\r\n                </div>\r\n                <div\r\n                  class=\"flex flex-row justify-content-end w-full\"\r\n                  *ngIf=\"!acoesLinhaTabela\"\r\n                >\r\n                  <button\r\n                    id=\"moreVertBtn\"\r\n                    pButton\r\n                    class=\"actionBtns p-button-text p-button-raised\"\r\n                    (click)=\"menu.toggle($event); activeItem(rowData, rowNode)\"\r\n                  >\r\n                    <span\r\n                      class=\"material-symbols-outlined\"\r\n                      style=\"font-size: 20px\"\r\n                    >\r\n                      more_horiz\r\n                    </span>\r\n                  </button>\r\n\r\n                  <div *ngFor=\"let action of config.actions\">\r\n                    {{ criarMenusModal(rowData, rowNode) }}\r\n                  </div>\r\n\r\n                  <!-- <div *ngFor=\"let action of config.actions\">\r\n                {{ criarMenusModal(rowData) }}\r\n              </div> -->\r\n\r\n                  <p-menu\r\n                    #menu\r\n                    [popup]=\"true\"\r\n                    [model]=\"menuItems\"\r\n                    appendTo=\"body\"\r\n                  ></p-menu>\r\n                </div>\r\n              </div>\r\n            </div>\r\n          </td>\r\n\r\n          <td \r\n            [style.width]=\"col.width\"\r\n            [ngClass]=\"{\r\n              'margem-filho': rowNode.level != 0,\r\n              'justify-content-between': i == columns.length - 1\r\n            }\"\r\n            *ngIf=\"!rowgroup && !col.grouped && !col.template\"\r\n            [style]=\"\r\n              applyStyle(rowData, col) +\r\n              centralizarColunas(col) +\r\n              alignColunas(col)\r\n            \"\r\n            class=\"rowTable\"\r\n          >\r\n          <div\r\n              class=\"w-full-h-full flex justify-content-between\"\r\n              [ngClass]=\"{ 'justify-content-between': i == columns.length - 1 }\"\r\n            >\r\n              <!-- Toggle -->\r\n              <div class=\"w-full-h-full flex align-items-center d-toggle\" *ngIf=\"i == 0\">\r\n                <p-treeTableCheckbox\r\n                  [disabled]=\"isDisabledCheckbox(rowData, rowNode)\"\r\n                  (click)=\"activeItemLote(selectedItems)\"\r\n                  [value]=\"rowNode\"\r\n                  *ngIf=\"config.enableSelect == true\"\r\n                ></p-treeTableCheckbox>\r\n\r\n                <p-treeTableToggler\r\n                  [rowNode]=\"rowNode\"\r\n                  *ngIf=\"!rightCollapse\"\r\n                ></p-treeTableToggler>\r\n                <p-treeTableToggler\r\n                  class=\"hiddenVisible\"\r\n                  [rowNode]=\"rowNode\"\r\n                  *ngIf=\"rightCollapse\"\r\n                ></p-treeTableToggler>\r\n              </div>\r\n\r\n              <!-- Texto -->\r\n              <div\r\n                class=\"w-full flex align-items-center\"\r\n                [style]=\"centralizarColunas(col)\"\r\n              >\r\n                <span\r\n                  *ngIf=\"!isBooleanField(rowData, col); else booleanField\"\r\n                  [class]=\"returnRowClass(rowData, col)\"\r\n                >\r\n                  <span\r\n                    *ngIf=\"\r\n                      !isChipField(col) && !col.iconField && !isImageField(col)\r\n                    \"\r\n                  >\r\n                    <i *ngIf=\"col.icon\" [class]=\"col.icon + ' mr-2'\"></i>\r\n                    {{ transformValue(rowData, col) }}\r\n                  </span>\r\n\r\n                  <div *ngIf=\"isChipField(col) && !col.iconField\">\r\n                    <span\r\n                      [class]=\"returnClassChip(rowData, col)\"\r\n                      [pTooltip]=\"returnTooltipIcon(rowData, col)\"\r\n                    >\r\n                      {{ transformValue(rowData, col) }}</span\r\n                    >\r\n                  </div>\r\n                </span>\r\n\r\n                <span *ngIf=\"isImageField(col)\">\r\n                  <span>\r\n                    <img class=\"image\" [src]=\"loadImage(rowData, col)\" />\r\n                  </span>\r\n                </span>\r\n\r\n                <i\r\n                  *ngIf=\"col.iconField\"\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                <ng-template #booleanField>\r\n                  <i\r\n                    *ngIf=\"!col.iconField\"\r\n                    [ngClass]=\"\r\n                      rowData[col.field] ? 'text-green-500' : 'text-red-500'\r\n                    \"\r\n                    ><span class=\"material-symbols-outlined\">\r\n                      {{ rowData[col.field] ? \"check\" : \"close\" }}\r\n                    </span>\r\n                  </i>\r\n                </ng-template>\r\n              </div>\r\n\r\n              <!-- Botao de ação -->\r\n              <div\r\n                class=\"w-full-h-full flex\"\r\n                *ngIf=\"\r\n                  i == columns.length - 1 &&\r\n                  config.actions &&\r\n                  config.actions.length > 0\r\n                \"\r\n                [style]=\"\r\n                  applyStyle(rowData, { field: 'btns-options', header: '' })\r\n                \"\r\n              >\r\n                <div\r\n                  class=\"flex flex-row justify-content-end w-full\"\r\n                  *ngIf=\"acoesLinhaTabela\"\r\n                >\r\n                  <div *ngFor=\"let action of config.actions\">\r\n                    <button\r\n                      id=\"actionBtns\"\r\n                      pButton\r\n                      *ngIf=\"exibirCampo(action, rowData)\"\r\n                      class=\"actionBtns p-button-text p-button-raised\"\r\n                      (click)=\"activeItem(rowData, rowNode); action?.command(commandEvent)\"\r\n                      [pTooltip]=\"retornarCampo(action, rowData, 'tooltip')\"\r\n                      [tooltipPosition]=\"'bottom'\"\r\n                      [disabled]=\"callDisabled(action, rowData)\"\r\n                    >\r\n                      <span class=\"material-symbols-outlined md-19\">\r\n                        {{ retornarCampo(action, rowData, \"icon\") }}</span\r\n                      >\r\n                    </button>\r\n                  </div>\r\n                </div>\r\n                <div\r\n                  class=\"flex flex-row justify-content-end w-full\"\r\n                  *ngIf=\"!acoesLinhaTabela\"\r\n                >\r\n                  <button\r\n                    id=\"moreVertBtn\"\r\n                    pButton\r\n                    class=\"actionBtns p-button-text p-button-raised\"\r\n                    (click)=\"menu.toggle($event); activeItem(rowData, rowNode)\"\r\n                  >\r\n                    <span\r\n                      class=\"material-symbols-outlined\"\r\n                      style=\"font-size: 20px\"\r\n                    >\r\n                      more_horiz\r\n                    </span>\r\n                  </button>\r\n\r\n                  <div *ngFor=\"let action of config.actions\">\r\n                    {{ criarMenusModal(rowData, rowNode) }}\r\n                  </div>\r\n\r\n                  <!-- <div *ngFor=\"let action of config.actions\">\r\n                  {{ criarMenusModal(rowData) }}\r\n                </div> -->\r\n\r\n                  <p-menu\r\n                    #menu\r\n                    [popup]=\"true\"\r\n                    [model]=\"menuItems\"\r\n                    appendTo=\"body\"\r\n                  ></p-menu>\r\n                </div>\r\n              </div>\r\n            </div>\r\n          </td>\r\n\r\n          <td\r\n            [style.width]=\"col.width\"\r\n            [ngClass]=\"{\r\n              'margem-filho': rowNode.level != 0,\r\n              'justify-content-between': i == columns.length - 1\r\n            }\"\r\n            *ngIf=\"col.template\"\r\n            [style]=\"\r\n              applyStyle(rowData, col) +\r\n              centralizarColunas(col) +\r\n              alignColunas(col)\r\n            \"\r\n            class=\"rowTable\"\r\n          >\r\n            <div class=\"flex\" [style]=\"centralizarColunas(col)\">\r\n              <div class=\"w-full-h-full flex align-items-center\" *ngIf=\"i == 0\">\r\n                <p-treeTableCheckbox\r\n                  [disabled]=\"isDisabledCheckbox(rowData, rowNode)\"\r\n                  (click)=\"activeItemLote(selectedItems)\"\r\n                  [value]=\"rowNode\"\r\n                  *ngIf=\"config.enableSelect == true\"\r\n                ></p-treeTableCheckbox>\r\n\r\n                <p-treeTableToggler\r\n                  [rowNode]=\"rowNode\"\r\n                  *ngIf=\"!rightCollapse\"\r\n                ></p-treeTableToggler>\r\n                <p-treeTableToggler\r\n                  class=\"hiddenVisible\"\r\n                  [rowNode]=\"rowNode\"\r\n                  *ngIf=\"rightCollapse\"\r\n                ></p-treeTableToggler>\r\n              </div>\r\n              <ng-container\r\n                *ngIf=\"getCustomTemplate(col.template.name)\"\r\n                [ngTemplateOutlet]=\"getCustomTemplate(col.template.name)\"\r\n                [ngTemplateOutletContext]=\"{ $implicit: rowData }\"\r\n              >\r\n              </ng-container>\r\n\r\n              <div\r\n                class=\"w-full-h-full flex\"\r\n                *ngIf=\"\r\n                  i == columns.length - 1 &&\r\n                  config.actions &&\r\n                  config.actions.length > 0\r\n                \"\r\n                [style]=\"\r\n                  applyStyle(rowData, { field: 'btns-options', header: '' })\r\n                \"\r\n              >\r\n                <div\r\n                  class=\"flex flex-row justify-content-end w-full\"\r\n                  *ngIf=\"acoesLinhaTabela\"\r\n                >\r\n                  <div *ngFor=\"let action of config.actions\">\r\n                    <button\r\n                      id=\"actionBtns\"\r\n                      pButton\r\n                      *ngIf=\"exibirCampo(action, rowData)\"\r\n                      class=\"actionBtns p-button-text p-button-raised\"\r\n                      (click)=\"activeItem(rowData, rowNode); action?.command(commandEvent)\"\r\n                      [pTooltip]=\"retornarCampo(action, rowData, 'tooltip')\"\r\n                      [tooltipPosition]=\"'bottom'\"\r\n                      [disabled]=\"callDisabled(action, rowData)\"\r\n                    >\r\n                      <span class=\"material-symbols-outlined md-19\">\r\n                        {{ retornarCampo(action, rowData, \"icon\") }}</span\r\n                      >\r\n                    </button>\r\n                  </div>\r\n                </div>\r\n                <div\r\n                  class=\"flex flex-row justify-content-end w-full\"\r\n                  *ngIf=\"!acoesLinhaTabela\"\r\n                >\r\n                  <button\r\n                    id=\"moreVertBtn\"\r\n                    pButton\r\n                    class=\"actionBtns p-button-text p-button-raised\"\r\n                    (click)=\"menu.toggle($event); activeItem(rowData, rowNode)\"\r\n                  >\r\n                    <span\r\n                      class=\"material-symbols-outlined\"\r\n                      style=\"font-size: 20px\"\r\n                    >\r\n                      more_horiz\r\n                    </span>\r\n                  </button>\r\n\r\n                  <div *ngFor=\"let action of config.actions\">\r\n                    {{ criarMenusModal(rowData, rowNode) }}\r\n                  </div>\r\n\r\n                  <!-- <div *ngFor=\"let action of config.actions\">\r\n                  {{ criarMenusModal(rowData) }}\r\n                </div> -->\r\n\r\n                  <p-menu\r\n                    #menu\r\n                    [popup]=\"true\"\r\n                    [model]=\"menuItems\"\r\n                    appendTo=\"body\"\r\n                  ></p-menu>\r\n                </div>\r\n              </div>\r\n            </div>\r\n          </td>\r\n          \r\n        </ng-container>\r\n      </tr>\r\n\r\n    </ng-template>\r\n\r\n    <!-- :: Hotfix do bug da versão 15 do primeng, ao retirar esse bloco de codigo na versão 15 do primeng os icones de prev e next do paginator irão sumir ( resolvido na versão 16.0)  :: -->\r\n\r\n    <ng-template pTemplate=\"paginatorfirstpagelinkicon\">\r\n      <span class=\"pi pi-angle-double-left\"></span>\r\n    </ng-template>\r\n    <ng-template pTemplate=\"paginatorpreviouspagelinkicon\">\r\n      <span class=\"pi pi-angle-left\"></span>\r\n    </ng-template>\r\n    <ng-template pTemplate=\"paginatornextpagelinkicon\">\r\n      <span class=\"pi pi-angle-right\"></span>\r\n    </ng-template>\r\n    <ng-template pTemplate=\"paginatorlastpagelinkicon\">\r\n      <span class=\"pi pi-angle-double-right\"></span>\r\n    </ng-template>\r\n\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;\r\n          border-radius: 10px !important;\r\n          \"\r\n        >\r\n         <p class=\"font-semibold\"> Nenhum registro encontrado </p>\r\n        </td>\r\n      </tr>\r\n    </ng-template>\r\n  </p-treeTable>\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"]}
@@ -6,6 +6,7 @@ import { AutoCompleteModule } from 'primeng/autocomplete';
6
6
  import { WorkspaceComponent } from './workspace.component';
7
7
  import { KvButtonsModule } from "../buttons/kvbutton.module";
8
8
  import { PrimeNgModule } from '../api/modules/primeng.module';
9
+ import { KvTableModule } from '../table/kvtable.module';
9
10
  import * as i0 from "@angular/core";
10
11
  export class KvWorkspaceModule {
11
12
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: KvWorkspaceModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
@@ -15,14 +16,16 @@ export class KvWorkspaceModule {
15
16
  ProgressSpinnerModule,
16
17
  AutoCompleteModule,
17
18
  FormsModule,
18
- KvButtonsModule], exports: [WorkspaceComponent] }); }
19
+ KvButtonsModule,
20
+ KvTableModule], exports: [WorkspaceComponent] }); }
19
21
  static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: KvWorkspaceModule, imports: [CommonModule,
20
22
  PrimeNgModule,
21
23
  ReactiveFormsModule,
22
24
  ProgressSpinnerModule,
23
25
  AutoCompleteModule,
24
26
  FormsModule,
25
- KvButtonsModule] }); }
27
+ KvButtonsModule,
28
+ KvTableModule] }); }
26
29
  }
27
30
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: KvWorkspaceModule, decorators: [{
28
31
  type: NgModule,
@@ -40,8 +43,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
40
43
  ProgressSpinnerModule,
41
44
  AutoCompleteModule,
42
45
  FormsModule,
43
- KvButtonsModule
46
+ KvButtonsModule,
47
+ KvTableModule
44
48
  ]
45
49
  }]
46
50
  }] });
47
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia3Z3b3Jrc3BhY2UubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2Vldm8tY29tcG9uZW50cy9zcmMvbGliL3dvcmtzcGFjZS9rdndvcmtzcGFjZS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ2hFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQzFELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQzNELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUM3RCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sK0JBQStCLENBQUM7O0FBcUI5RCxNQUFNLE9BQU8saUJBQWlCOytHQUFqQixpQkFBaUI7Z0hBQWpCLGlCQUFpQixpQkFmdEIsa0JBQWtCLGFBTWxCLFlBQVk7WUFDWixhQUFhO1lBQ2IsbUJBQW1CO1lBQ25CLHFCQUFxQjtZQUNyQixrQkFBa0I7WUFDbEIsV0FBVztZQUNYLGVBQWUsYUFUZixrQkFBa0I7Z0hBWWIsaUJBQWlCLFlBVHRCLFlBQVk7WUFDWixhQUFhO1lBQ2IsbUJBQW1CO1lBQ25CLHFCQUFxQjtZQUNyQixrQkFBa0I7WUFDbEIsV0FBVztZQUNYLGVBQWU7OzRGQUdWLGlCQUFpQjtrQkFqQjdCLFFBQVE7bUJBQUM7b0JBQ04sWUFBWSxFQUFFO3dCQUNWLGtCQUFrQjtxQkFDckI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNMLGtCQUFrQjtxQkFDckI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNMLFlBQVk7d0JBQ1osYUFBYTt3QkFDYixtQkFBbUI7d0JBQ25CLHFCQUFxQjt3QkFDckIsa0JBQWtCO3dCQUNsQixXQUFXO3dCQUNYLGVBQWU7cUJBQ2xCO2lCQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgRm9ybXNNb2R1bGUsIFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcbmltcG9ydCB7IFByb2dyZXNzU3Bpbm5lck1vZHVsZSB9IGZyb20gJ3ByaW1lbmcvcHJvZ3Jlc3NzcGlubmVyJztcclxuaW1wb3J0IHsgQXV0b0NvbXBsZXRlTW9kdWxlIH0gZnJvbSAncHJpbWVuZy9hdXRvY29tcGxldGUnO1xyXG5pbXBvcnQgeyBXb3Jrc3BhY2VDb21wb25lbnQgfSBmcm9tICcuL3dvcmtzcGFjZS5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBLdkJ1dHRvbnNNb2R1bGUgfSBmcm9tIFwiLi4vYnV0dG9ucy9rdmJ1dHRvbi5tb2R1bGVcIjtcclxuaW1wb3J0IHsgUHJpbWVOZ01vZHVsZSB9IGZyb20gJy4uL2FwaS9tb2R1bGVzL3ByaW1lbmcubW9kdWxlJztcclxuXHJcblxyXG5cclxuQE5nTW9kdWxlKHtcclxuICAgIGRlY2xhcmF0aW9uczogW1xyXG4gICAgICAgIFdvcmtzcGFjZUNvbXBvbmVudFxyXG4gICAgXSxcclxuICAgIGV4cG9ydHM6IFtcclxuICAgICAgICBXb3Jrc3BhY2VDb21wb25lbnRcclxuICAgIF0sXHJcbiAgICBpbXBvcnRzOiBbXHJcbiAgICAgICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgICAgIFByaW1lTmdNb2R1bGUsXHJcbiAgICAgICAgUmVhY3RpdmVGb3Jtc01vZHVsZSxcclxuICAgICAgICBQcm9ncmVzc1NwaW5uZXJNb2R1bGUsXHJcbiAgICAgICAgQXV0b0NvbXBsZXRlTW9kdWxlLFxyXG4gICAgICAgIEZvcm1zTW9kdWxlLFxyXG4gICAgICAgIEt2QnV0dG9uc01vZHVsZVxyXG4gICAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgS3ZXb3Jrc3BhY2VNb2R1bGUgeyB9XHJcbiJdfQ==
51
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia3Z3b3Jrc3BhY2UubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2Vldm8tY29tcG9uZW50cy9zcmMvbGliL3dvcmtzcGFjZS9rdndvcmtzcGFjZS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ2hFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQzFELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQzNELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUM3RCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDOUQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHlCQUF5QixDQUFDOztBQXNCeEQsTUFBTSxPQUFPLGlCQUFpQjsrR0FBakIsaUJBQWlCO2dIQUFqQixpQkFBaUIsaUJBaEJ0QixrQkFBa0IsYUFNbEIsWUFBWTtZQUNaLGFBQWE7WUFDYixtQkFBbUI7WUFDbkIscUJBQXFCO1lBQ3JCLGtCQUFrQjtZQUNsQixXQUFXO1lBQ1gsZUFBZTtZQUNmLGFBQWEsYUFWYixrQkFBa0I7Z0hBYWIsaUJBQWlCLFlBVnRCLFlBQVk7WUFDWixhQUFhO1lBQ2IsbUJBQW1CO1lBQ25CLHFCQUFxQjtZQUNyQixrQkFBa0I7WUFDbEIsV0FBVztZQUNYLGVBQWU7WUFDZixhQUFhOzs0RkFHUixpQkFBaUI7a0JBbEI3QixRQUFRO21CQUFDO29CQUNOLFlBQVksRUFBRTt3QkFDVixrQkFBa0I7cUJBQ3JCO29CQUNELE9BQU8sRUFBRTt3QkFDTCxrQkFBa0I7cUJBQ3JCO29CQUNELE9BQU8sRUFBRTt3QkFDTCxZQUFZO3dCQUNaLGFBQWE7d0JBQ2IsbUJBQW1CO3dCQUNuQixxQkFBcUI7d0JBQ3JCLGtCQUFrQjt3QkFDbEIsV0FBVzt3QkFDWCxlQUFlO3dCQUNmLGFBQWE7cUJBQ2hCO2lCQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgRm9ybXNNb2R1bGUsIFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcbmltcG9ydCB7IFByb2dyZXNzU3Bpbm5lck1vZHVsZSB9IGZyb20gJ3ByaW1lbmcvcHJvZ3Jlc3NzcGlubmVyJztcclxuaW1wb3J0IHsgQXV0b0NvbXBsZXRlTW9kdWxlIH0gZnJvbSAncHJpbWVuZy9hdXRvY29tcGxldGUnO1xyXG5pbXBvcnQgeyBXb3Jrc3BhY2VDb21wb25lbnQgfSBmcm9tICcuL3dvcmtzcGFjZS5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBLdkJ1dHRvbnNNb2R1bGUgfSBmcm9tIFwiLi4vYnV0dG9ucy9rdmJ1dHRvbi5tb2R1bGVcIjtcclxuaW1wb3J0IHsgUHJpbWVOZ01vZHVsZSB9IGZyb20gJy4uL2FwaS9tb2R1bGVzL3ByaW1lbmcubW9kdWxlJztcclxuaW1wb3J0IHsgS3ZUYWJsZU1vZHVsZSB9IGZyb20gJy4uL3RhYmxlL2t2dGFibGUubW9kdWxlJztcclxuXHJcblxyXG5cclxuQE5nTW9kdWxlKHtcclxuICAgIGRlY2xhcmF0aW9uczogW1xyXG4gICAgICAgIFdvcmtzcGFjZUNvbXBvbmVudFxyXG4gICAgXSxcclxuICAgIGV4cG9ydHM6IFtcclxuICAgICAgICBXb3Jrc3BhY2VDb21wb25lbnRcclxuICAgIF0sXHJcbiAgICBpbXBvcnRzOiBbXHJcbiAgICAgICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgICAgIFByaW1lTmdNb2R1bGUsXHJcbiAgICAgICAgUmVhY3RpdmVGb3Jtc01vZHVsZSxcclxuICAgICAgICBQcm9ncmVzc1NwaW5uZXJNb2R1bGUsXHJcbiAgICAgICAgQXV0b0NvbXBsZXRlTW9kdWxlLFxyXG4gICAgICAgIEZvcm1zTW9kdWxlLFxyXG4gICAgICAgIEt2QnV0dG9uc01vZHVsZSxcclxuICAgICAgICBLdlRhYmxlTW9kdWxlXHJcbiAgICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBLdldvcmtzcGFjZU1vZHVsZSB7IH1cclxuIl19