keevo-components 1.8.194 → 1.8.196
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-button/kv-button.component.mjs +2 -2
- package/esm2022/lib/components/kv-inputs/kv-check/kv-check.component.mjs +2 -2
- package/esm2022/lib/components/kv-inputs/kv-radio-group/kv-radio-group.component.mjs +2 -2
- package/esm2022/lib/components/kv-inputs/kv-switch/kv-switch.component.mjs +2 -2
- package/esm2022/lib/components/kv-progress-bar/kv-progress-bar.component.mjs +3 -3
- package/esm2022/lib/components/kv-table/kv-table.component.mjs +2 -2
- package/esm2022/lib/components/kv-table-edit/kv-table-edit.component.mjs +3 -1
- package/esm2022/lib/components/kv-table-expandable/kv-table-expandable.component.mjs +2 -2
- package/esm2022/lib/components/kv-tree-table/kv-tree-table.component.mjs +2 -2
- package/fesm2022/keevo-components.mjs +18 -16
- package/fesm2022/keevo-components.mjs.map +1 -1
- package/lib/components/kv-table-edit/kv-table-edit.component.d.ts +1 -0
- package/package.json +1 -1
|
@@ -128,6 +128,8 @@ export class KvTableEditComponent extends BasecomponentTable {
|
|
|
128
128
|
];
|
|
129
129
|
// Subscreve-se ao sujeito onSaveTimer$
|
|
130
130
|
}
|
|
131
|
+
adjustTableSize() {
|
|
132
|
+
}
|
|
131
133
|
ngOnDestroy() {
|
|
132
134
|
// Completa o sujeito onDestroy$
|
|
133
135
|
this.onDestroy$.next();
|
|
@@ -285,4 +287,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
|
|
|
285
287
|
}], filterField: [{
|
|
286
288
|
type: Output
|
|
287
289
|
}] } });
|
|
288
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-table-edit.component.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/components/kv-table-edit/kv-table-edit.component.ts","../../../../../../projects/keevo-components/src/lib/components/kv-table-edit/kv-table-edit.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnChanges,\r\n  OnInit,\r\n  Output,\r\n  SimpleChanges} from '@angular/core';\r\n\r\nimport {\r\n  DatePipe,\r\n  DecimalPipe\r\n} from '@angular/common';\r\n\r\nimport {\r\n  MenuItem} from 'primeng/api';\r\n\r\n\r\nimport {\r\n  CpfCnpjPipe,\r\n  NotificationService,\r\n  TelefonePipe,\r\n  ValueOrFn,\r\n  getOrExecute,\r\n  mapToMenuItem\r\n} from '../../../public-api';\r\n\r\nimport { TableEditConfigColumn } from '../../api/components/table/tableedit.config.column';\r\nimport TableEditConfig from '../../api/components/table/tabledit.config';\r\nimport { Subject, Subscription, takeUntil, timer } from 'rxjs';\r\nimport { BasecomponentTable } from '../../api/base-components/base-component-table';\r\n\r\n@Component({\r\n  selector: 'kv-table-edit',\r\n  templateUrl: './kv-table-edit.component.html',\r\n  styleUrls: ['./kv-table-edit.component.scss']\r\n})\r\nexport class KvTableEditComponent extends BasecomponentTable implements OnInit, OnChanges {\r\n\r\n\r\n  override config!: TableEditConfig;\r\n\r\n  @Input() enableSizes: boolean = false;\r\n  @Input() editMode: 'row' | 'cell' = 'cell';\r\n  private itemsParaSalvamento: any[] = []\r\n  protected itemInitialState!: any;\r\n\r\n  isEditing: boolean = false;\r\n  isShowSizes: boolean = false;\r\n  clonedDataSource: { [s: string]: any } = {};\r\n  selectedProduct: any = {\r\n    rowData: {},\r\n    editing: false\r\n  };\r\n\r\n  menuItems: MenuItem[] = [];\r\n  //\r\n  itemsContextMenu!: MenuItem[];\r\n\r\n  /**  Emite evento de salvamento da linha */\r\n  @Output() onSave: EventEmitter<any> = new EventEmitter();\r\n  @Output() filterField: EventEmitter<any> = new EventEmitter();\r\n\r\n  constructor(\r\n    datePipe: DatePipe,\r\n    decimalPipe: DecimalPipe,\r\n    cpfCnpjPipe: CpfCnpjPipe,\r\n    telefonePipe: TelefonePipe,\r\n    notificationService: NotificationService\r\n    // capitalizePipe: CapitalizePipe,\r\n  ) {\r\n    super(datePipe, decimalPipe, cpfCnpjPipe, telefonePipe, notificationService);\r\n    this.isRowSelectable = this.isRowSelectable.bind(this);\r\n  }\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  sizes = [\r\n    {\r\n      label: 'Pequeno', class: 'p-datatable-sm', size: 0.83, command: (x: any) => {\r\n        this.selectedSize = { label: 'Pequeno', class: 'p-datatable-sm', size: 0.83 }\r\n      }\r\n    },\r\n    {\r\n      label: 'Médio', class: 'p-datatable-md', size: 1, command: (x: any) => {\r\n        this.selectedSize = { label: 'Médio', class: 'p-datatable-md', size: 1 }\r\n      }\r\n    },\r\n    {\r\n      label: 'Grande', class: 'p-datatable-lg', size: 1.17, command: (x: any) => {\r\n        this.selectedSize = { label: 'Large', class: 'p-datatable-lg', size: 1.17 }\r\n\r\n      }\r\n    },\r\n\r\n    // { name: 'Small', class: 'p-datatable-sm', size:  0.83 },\r\n    // { name: 'Normal', class: 'p-datatable-md', size: 1 },\r\n    // { name: 'Large',  class: 'p-datatable-lg', size: 1.17 }\r\n  ];\r\n\r\n\r\n  //FIXME: Mover para um local adequado\r\n  timerSubscription!: Subscription; // Assinatura do temporizador\r\n  onSaveTimer$: Subject<void> = new Subject<void>(); // Sujeito para controlar o temporizador\r\n  private onDestroy$: Subject<void> = new Subject<void>();\r\n\r\n  override ngOnInit() {\r\n    super.ngOnInit();\r\n\r\n    this.onSaveTimer$.pipe(\r\n      takeUntil(this.onDestroy$)\r\n    ).subscribe(() => {\r\n      // Quando o temporizador terminar, emita o evento onSave com os dados a serem salvos\r\n      this.onRowEditSave();\r\n    });\r\n\r\n\r\n    this.tamanhoTela = window.innerWidth;\r\n\r\n    this.itemsContextMenu = [\r\n      {\r\n        label: 'Editar linha', icon: 'pi pi-fw pi-pencil', command: () => {\r\n          const element = document.getElementById('rowEdit' + this.selectedProduct.rowData[this.config.dataKey]);\r\n          if (element && !this.config.disableEditRowFunction?.(this.selectedProduct.rowData)) {\r\n            element.click()\r\n          } else {\r\n            this.notificationService.toastWarn(\"A edição dessa linha esta desabilitada\")\r\n          }\r\n          this.onRowEditInit(this.selectedProduct)\r\n\r\n        }\r\n      },\r\n      {\r\n        label: 'Cancelar edição', icon: 'pi pi-fw pi-times', command: (data: any) => {\r\n          const element = document.getElementById('rowCancel' + this.selectedProduct.rowData[this.config.dataKey]);\r\n          if (element) {\r\n            element.click();\r\n          } else {\r\n            this.notificationService.toastWarn(\"A edição dessa linha esta desabilitada\")\r\n          }\r\n        }\r\n      },\r\n      {\r\n        label: 'Salvar edição', icon: 'pi pi-fw pi-save', command: (data: any) => {\r\n          const element = document.getElementById('rowSave' + this.selectedProduct.rowData[this.config.dataKey]);\r\n          if (element) {\r\n            element.click(); // Dispara um evento de clique no elemento com ID 'teste'\r\n          } else {\r\n            this.notificationService.toastWarn(\"A edição dessa linha esta desabilitada\")\r\n          }\r\n        }\r\n      },\r\n      {\r\n        label: 'Entrar em modo de edição', icon: 'pi pi-fw pi-pencil', command: () => {\r\n          this.isEditing = true;\r\n        }\r\n      },\r\n      {\r\n        label: 'Sair do modo de edição', icon: 'pi pi-fw pi-pencil', command: () => {\r\n          this.isEditing = false;\r\n          if (this.itemsParaSalvamento.length > 0)\r\n            this.onRowEditSave();\r\n        }\r\n      },\r\n    ];\r\n\r\n\r\n    // Subscreve-se ao sujeito onSaveTimer$\r\n\r\n\r\n  }\r\n  ngOnDestroy(): void {\r\n    // Completa o sujeito onDestroy$\r\n    this.onDestroy$.next();\r\n    this.onDestroy$.complete();\r\n    // Se houver um temporizador em execução, pare-o\r\n    if (this.timerSubscription) {\r\n      this.timerSubscription.unsubscribe();\r\n      // Após parar o temporizador, chame onSave diretamente para salvar os dados\r\n      this.onRowEditSave();\r\n    }\r\n  }\r\n\r\n  ngDoCheck(): void {\r\n    this.itemsContextMenu[0].visible = this.editMode == 'row' && !this.selectedProduct.editing && this.isEditableTable() !== false;\r\n    this.itemsContextMenu[1].visible = this.editMode == 'row' && this.selectedProduct.editing && this.isEditableTable() !== false;\r\n    this.itemsContextMenu[2].visible = this.editMode == 'row' && this.selectedProduct.editing && this.isEditableTable() !== false;\r\n\r\n    this.itemsContextMenu[3].visible = this.editMode == 'cell' && !this.isEditing;\r\n    this.itemsContextMenu[4].visible = this.editMode == 'cell' && this.isEditing;\r\n\r\n\r\n  }\r\n\r\n  dbClickEdit() {\r\n\r\n    const element = document.getElementById('rowEdit' + this.selectedItem[this.config.dataKey]);\r\n    if (element) {\r\n      element.click();\r\n    } else {\r\n      if (this.editMode == 'row')\r\n        this.notificationService.toastWarn(\"A edição dessa linha esta desabilitada\")\r\n    }\r\n  }\r\n\r\n  isRowSelectable(event: any) {\r\n    return !this.isDisabledCheckbox(event.data);\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    //Called before any other lifecycle hook. Use it to inject dependencies, but avoid any serious work here.\r\n    //Add '${implements OnChanges}' to the class.\r\n    if (changes['setConfig'] && this.config) {\r\n\r\n      this.config.columns.forEach((e: TableEditConfigColumn) => {\r\n        if (e.fieldControlType == 'dropdown') {\r\n          this.listarDrop(e.fieldDropDownControl?.fieldControlDropdownService, e)\r\n\r\n        }\r\n      })\r\n    }\r\n  }\r\n  criarMenusModal(data: any) {\r\n    if (this.config.actions && data) {\r\n      for (const action of this.config.actions) {\r\n        const menuInsert = mapToMenuItem(action, data);\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  onRowEditInit(rowData: any) {\r\n    this.clonedDataSource[rowData.id as string] = { ...rowData };\r\n  }\r\n\r\n  onEditInit(event1: any) {\r\n    if (this.isEditing) this.itemInitialState = { ...event1.data }\r\n  }\r\n  onEditComplete(event: any) {\r\n    if (this.isEditing) {\r\n      //Verificamos se e o prmeiro item ou se o novo item ainda e do mesmo objeto. Alem disso verificamos se o campo foi realmente alterado abaixo\r\n      if (\r\n        this.itemsParaSalvamento.length === 0 ||\r\n        this.itemsParaSalvamento[this.itemsParaSalvamento.length - 1].index === event.index\r\n      ) {\r\n        if (event.data[event.field] != this.itemInitialState[event.field]) {\r\n          this.adicionarCelulaParaSalvar(event);\r\n        }\r\n      } else {\r\n        // Se o último item editado não for da mesma linha, emita o evento onSave e adicione o item atual para salvar\r\n        this.onRowEditSave();\r\n        this.adicionarCelulaParaSalvar(event);\r\n      }\r\n    }\r\n\r\n  }\r\n\r\n  adicionarCelulaParaSalvar(item: any) {\r\n    // Adiciona os dados editados ao array para salvamento\r\n    this.itemsParaSalvamento.push(item);\r\n\r\n    // Se houver um temporizador em execução, limpe-o e reinicie\r\n    if (this.timerSubscription) {\r\n      this.timerSubscription.unsubscribe();\r\n    }\r\n\r\n    // Inicia o temporizador para emitir onSave após 5 segundos\r\n    this.timerSubscription = timer(5000).subscribe(() => {\r\n      this.onSaveTimer$.next(); // Emita onSave após 5 segundos\r\n    });\r\n  }\r\n\r\n\r\n  onRowEditSave() {\r\n\r\n    const objetoRefletido: any = { ...this.itemsParaSalvamento[0].data };\r\n    // Reflete as alterações em um objeto\r\n    this.itemsParaSalvamento.forEach(item => {\r\n      const chave = item.field\r\n      const valor = item.data[chave];\r\n      objetoRefletido[chave] = valor;\r\n    });\r\n    this.onSave.emit(objetoRefletido)\r\n    this.itemsParaSalvamento = [];\r\n  }\r\n\r\n\r\n  onRowEditCancel(product: any, index: number) {\r\n    this.dataSource[index] = this.clonedDataSource[product.id as string];\r\n    delete this.clonedDataSource[product.id as string];\r\n  }\r\n\r\n  listarDrop(service: any, col: any, indtodos?: boolean) {\r\n    const column = this.config.columns?.indexOf(col);\r\n    return this.config.columns[column].fieldDropDownControl?.fieldControlDropdownSource\r\n  }\r\n\r\n  retornaDescricaoDrop(rowData: any[], col: TableEditConfigColumn) {\r\n\r\n    const data = col.fieldDropDownControl?.fieldControlDropdownSource\r\n    const idobjeto = col.fieldDropDownControl?.idobjeto\r\n    const descricaoobjeto = col.fieldDropDownControl?.descricaoobjeto\r\n    // @ts-ignore\r\n    const valorAtual = rowData[col.field]\r\n\r\n    if (data && idobjeto && descricaoobjeto)\r\n      return data?.find((item: any) => item[idobjeto] == valorAtual)[descricaoobjeto]\r\n    else return 'Carregando'\r\n  }\r\n\r\n\r\n\r\n  isDisableEditRowFunction(rowData: any): boolean {\r\n    return this.config.disableEditRowFunction ? this.config.disableEditRowFunction(rowData) : false;\r\n  }\r\n\r\n  isDisableEditRowCellFunction(rowData: any, col: any): boolean {\r\n    return col.disableEditRowCellFunction ? col.disableEditRowCellFunction(rowData) : false;\r\n  }\r\n\r\n  isEditableTable(): boolean | null {\r\n    if (!this.config.columns)\r\n      return null;\r\n\r\n    return this.config.columns.some((column: any) => 'fieldControlType' in column);\r\n  }\r\n}\r\n\r\n","<div class=\"card\" id=\"tamanhotabela\" [style.font-size]=\"'1px'\">\r\n  <p-toast></p-toast>\r\n\r\n  <p-panel\r\n    *ngIf=\"filtrosAvancados\"\r\n    header=\"Filtros avançados\"\r\n    [toggleable]=\"true\"\r\n    [collapsed]=\"true\"\r\n    (collapsedChange)=\"collapsed = !collapsed\"\r\n    [style]=\"{ 'margin-bottom': '2px' }\"\r\n  >\r\n    <ng-template pTemplate=\"headericons\">\r\n      <i *ngIf=\"!collapsed\" class=\"pi pi-filter\"></i>\r\n      <!-- Ícone quando o painel está aberto -->\r\n      <i *ngIf=\"collapsed\" class=\"pi pi-minus\"></i>\r\n      <!-- Ícone quando o painel está fechado -->\r\n    </ng-template>\r\n    <ng-content></ng-content>\r\n  </p-panel>\r\n\r\n  <p-contextMenu #cm [model]=\"itemsContextMenu\"></p-contextMenu>\r\n  <p-table\r\n    #te\r\n    [editMode]=\"editMode\"\r\n    (onEditComplete)=\"onEditComplete($event)\"\r\n    (onEditInit)=\"onEditInit($event)\"\r\n    [reorderableColumns]=\"config.reorderableColumns || false\"\r\n    *ngIf=\"config\"\r\n    [value]=\"dataSource\"\r\n    [dataKey]=\"config.dataKey\"\r\n    [columns]=\"config.columns\"\r\n    [scrollable]=\"true\"\r\n    appendTo=\"body\"\r\n    [styleClass]=\"selectedSize.class\"\r\n    [(selection)]=\"selectedItems\"\r\n    [rowSelectable]=\"isRowSelectable\"\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    (selectionChange)=\"selectionChange($event)\"\r\n    [rowHover]=\"true\"\r\n    [totalRecords]=\"totalRecords\"\r\n    [lazy]=\"config.lazy\"\r\n    (onLazyLoad)=\"paginate($event)\"\r\n    [groupRowsBy]=\"config.fieldGroup\"\r\n    paginatorDropdownAppendTo=\"body\"\r\n    [showFirstLastIcon]=\"showFirstLastIcon\"\r\n    [pageLinks]=\"pageLinksOptions\"\r\n    [scrollable]=\"isTableScrollable\"\r\n    [scrollHeight]=\"scrollHeight\"\r\n    [rowTrackBy]=\"rowTrackBy\"\r\n    [(contextMenuSelection)]=\"selectedProduct\"\r\n    [contextMenu]=\"isEditableTable() ? cm : null\"\r\n  >\r\n    <!-- ----------------------------------------------------------------------------------------------------------------------------------- -->\r\n\r\n    <ng-template pTemplate=\"caption\" *ngIf=\"config.enableCation || enableSizes\">\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=\"flex flex-row align-items-center md:col-6 lg:col-4 {{\r\n            tamanhoTela < 768 ? 'col-10' : 'col-12'\r\n          }} mt-1 mb-2 \"\r\n        >\r\n          <span *ngIf=\"config.enableFilter\" class=\"p-input-icon-left\">\r\n            <i class=\"pi pi-search\"></i>\r\n\r\n            <input\r\n              pInputText\r\n              pAutoFocus\r\n              [autofocus]=\"true\"\r\n              type=\"text\"\r\n              (input)=\"onGlobalFilter(te, $event)\"\r\n              placeholder=\"Pesquisar...\"\r\n              class=\"h-2rem\"\r\n            />\r\n          </span>\r\n\r\n          <!-- FIXME: Opção 1  -->\r\n          <!-- <div class=\"sizes-controls ml-2\" *ngIf=\"isShowSizes\">\r\n            <p-selectButton\r\n                [options]=\"sizes\"\r\n                [(ngModel)]=\"selectedSize\"\r\n                [style]=\"{'display': 'flex'}\"\r\n                optionLabel=\"name\"\r\n                />\r\n          </div>\r\n         <button\r\n          id=\"btn-sizes\"\r\n          pButton\r\n          [pTooltip]=\"isShowSizes ? 'Esconder controles de tamanho' : 'Mostrar controles de tamanho'\"\r\n          class=\"actionLoteBtns p-button-raised p-button-text\"\r\n          (click)=\"isShowSizes = !isShowSizes\"\r\n        >\r\n          <span  style=\"font-size: 0.8rem;\" class=\"flex align-items-end\">\r\n          <span  style=\"font-size: 0.7rem;\">\r\n            A\r\n          </span>\r\n            A\r\n          </span>\r\n        </button> -->\r\n\r\n          <!-- FIXME: Opção 2  -->\r\n          <div *ngIf=\"enableSizes\" class=\"sizes-controls ml-2\">\r\n            <!-- <p-splitButton\r\n              label=\"aA\"\r\n              [model]=\"sizes\"\r\n              styleClass=\"teste\"\r\n              [menuStyle]=\"{'font-size': '0.7rem'}\"\r\n\r\n              ngModel\r\n            >\r\n            </p-splitButton> -->\r\n            <!-- <p-button  icon=\"pi pi-ellipsis-v\"/> -->\r\n\r\n            <button\r\n              id=\"actionLoteBtns\"\r\n              pButton\r\n              (click)=\"menu.toggle($event)\"\r\n              class=\"actionLoteBtns p-button-raised p-button-text\"\r\n              style=\"background-color: #1da750; color: #fff; display: flex\"\r\n            >\r\n              <span class=\"text-xs\">A</span>\r\n              <span class=\"text-md\">A</span>\r\n            </button>\r\n\r\n            <p-tieredMenu\r\n              [style]=\"{ 'font-size': '0.7rem' }\"\r\n              styleClass=\"menuSizes\"\r\n              appendTo=\"body\"\r\n              #menu\r\n              [model]=\"sizes\"\r\n              [popup]=\"true\"\r\n            >\r\n              <ng-template let-item pTemplate=\"item\">\r\n                <div\r\n                  class=\"cursor-pointer flex gap-2 align-items-center pl-1 m-2 menu-sizes\"\r\n                  (click)=\"item.command()\"\r\n                >\r\n                  <div\r\n                    *ngIf=\"this.selectedSize.size != item.size\"\r\n                    class=\"tag\"\r\n                    [style.background-color]=\"'#EAEAEA'\"\r\n                  ></div>\r\n                  <div\r\n                    *ngIf=\"this.selectedSize.size == item.size\"\r\n                    class=\"tag\"\r\n                    [style.background-color]=\"'#1DA750'\"\r\n                  ></div>\r\n\r\n                  {{ item.label }}\r\n                </div>\r\n              </ng-template>\r\n            </p-tieredMenu>\r\n          </div>\r\n          <!-- FIXME: Opção 3  -->\r\n          <!-- <div class=\"sizes-controls ml-2\" style=\"transform: translate(0px, -15px);\" >\r\n            <p-speedDial\r\n              [model]=\"sizes\"\r\n              showIcon=\"format_size\"\r\n              [mask]=\"true\"\r\n              direction=\"right\"\r\n              buttonClassName=\"item-circle\"\r\n            >\r\n\r\n\r\n\r\n\r\n            <ng-template let-item pTemplate=\"item\" >\r\n              <div class=\"item-circle cursor-pointer\r\n\r\n              shadow-2 hover:shadow-8\r\n\r\n              \" (click)=\"item.command()\">\r\n                {{item.label}}\r\n              </div>\r\n            </ng-template>\r\n\r\n          </p-speedDial>\r\n          </div> -->\r\n        </div>\r\n\r\n        <span *ngIf=\"isEditing\" class=\"text-aviso\">\r\n          Tabela em modo de edição\r\n        </span>\r\n\r\n        <div class=\"flex flex-row col-1 justify-content-end\">\r\n          <div\r\n            *ngFor=\"let action of config.actionsLote\"\r\n            class=\"btns-options flex flex-row\"\r\n          >\r\n            <button\r\n              id=\"actionLoteBtns\"\r\n              pButton\r\n              *ngIf=\"\r\n                !isEditing &&\r\n                (selectedItems.length > 0 || action.showAcoesLote) &&\r\n                exibirCampo(action, this.action)\r\n              \"\r\n              class=\"actionLoteBtns border-none\"\r\n              style=\"background-color: #1da750\"\r\n              (click)=\"action?.command(); activeItemLote(selectedItems)\"\r\n              [pTooltip]=\"getOrExecute(action.tooltip, selectedItems)\"\r\n              [tooltipPosition]=\"'bottom'\"\r\n              [disabled]=\"getOrExecute(action.disabled, selectedItems)\"\r\n            >\r\n              <span\r\n                class=\"material-symbols-outlined\"\r\n                style=\"color: white\"\r\n              >\r\n                {{ getOrExecute(action.icon, selectedItems) }}\r\n              </span>\r\n            </button>\r\n          </div>\r\n\r\n          <div\r\n            *ngIf=\"isEditableTable()\"\r\n            class=\"btns-options\"\r\n            [style]=\"{ 'margin-right': '7px' }\"\r\n          >\r\n            <button\r\n              (click)=\"this.isEditing = !this.isEditing\"\r\n              id=\"actionLoteBtns\"\r\n              pButton\r\n              style=\"background-color: #1da750; color: #fff\"\r\n              class=\"actionLoteBtns p-button-raised p-button-text\"\r\n            >\r\n              <span class=\"material-symbols-outlined\"> edit_square </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          style=\"width: 4rem; border-left: solid 4px transparent\"\r\n          *ngIf=\"config.enableSelect && !isEditing\"\r\n          [class]=\"selectedSize.class + 'th'\"\r\n        >\r\n          <p-tableHeaderCheckbox\r\n            (click)=\"activeItemLote(selectedItems)\"\r\n          ></p-tableHeaderCheckbox>\r\n        </th>\r\n\r\n        <th\r\n          *ngFor=\"let col of columns\"\r\n          [pSortableColumn]=\"col.field\"\r\n          [pSortableColumnDisabled]=\"col.sortable === false\"\r\n          [style.min-width]=\"col.width * selectedSize.size + 'px'\"\r\n          pReorderableColumn\r\n          [class]=\"selectedSize.class + 'th'\"\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        </th>\r\n        <th\r\n          *ngIf=\"!isEditing && config.actions && config.actions.length > 0\"\r\n        ></th>\r\n        <th\r\n          *ngIf=\"isEditableTable() && this.editMode == 'row'\"\r\n          id=\"th-edit\"\r\n          style=\"width: 20px\"\r\n        >\r\n          Editar\r\n        </th>\r\n      </tr>\r\n    </ng-template>\r\n\r\n    <!-- ----------------------------------------------------------------------------------------------------------------------------------- -->\r\n\r\n    <ng-template\r\n      pTemplate=\"body\"\r\n      let-rowData\r\n      let-editing=\"editing\"\r\n      let-ri=\"rowIndex\"\r\n      let-columns=\"columns\"\r\n      let-rowgroup=\"rowgroup\"\r\n      let-rowspan=\"rowspan\"\r\n    >\r\n      <tr\r\n        [pEditableRow]=\"rowData\"\r\n        [pEditableRowDisabled]=\"false\"\r\n        [pContextMenuRow]=\"{rowData, editing}\"\r\n        [class]=\"selectedSize.class + '-tr'\"\r\n      >\r\n        <td\r\n          *ngIf=\"config.enableSelect && !isEditing\"\r\n          [style]=\"applyStyle(rowData, { field: 'check-box', header: '' })\"\r\n        >\r\n          <!--<p-tableCheckbox *ngIf=\"isVisibleCheckbox(rowData)\"-->\r\n          <p-tableCheckbox\r\n            class=\"check-edit-list\"\r\n            [value]=\"rowData\"\r\n            [disabled]=\"isDisabledCheckbox(rowData)\"\r\n            (click)=\"activeItemLote(selectedItems)\"\r\n          ></p-tableCheckbox>\r\n        </td>\r\n\r\n        <ng-container *ngFor=\"let col of columns; let i = index\">\r\n          <!-- FIXME: Testar a implementação abaixo e mesaclar as duas formas -->\r\n\r\n          <ng-template #templateInput let-rowData=\"rowData\" let-col=\"col\">\r\n            <ng-container *ngIf=\"isEditing; else templatevisualedicao\">\r\n              <ng-container [ngSwitch]=\"col.fieldControlType\">\r\n                <ng-container *ngSwitchCase=\"'text'\">\r\n                  <div [style.width]=\"col.width\" class=\"grid formgrid p-fluid\">\r\n                    <kv-input-text\r\n                      [disabled]=\"isDisableEditRowCellFunction(rowData, col)\"\r\n                      class=\"cellControl col\"\r\n                      [(ngModel)]=\"rowData[col.field]\"\r\n                      [required]=\"col.required ?? true\"\r\n                    ></kv-input-text>\r\n                  </div>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'number'\">\r\n                  <div [style.width]=\"col.width\" class=\"grid formgrid p-fluid\">\r\n                    <kv-input-number\r\n                      [disabled]=\"isDisableEditRowCellFunction(rowData, col)\"\r\n                      class=\"cellControl col\"\r\n                      [(ngModel)]=\"rowData[col.field]\"\r\n                      [required]=\"col.required ?? true\"\r\n                    ></kv-input-number>\r\n                  </div>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'mask'\">\r\n                  <div [style.width]=\"col.width\" class=\"grid formgrid p-fluid\">\r\n                    <kv-input-mask\r\n                      [disabled]=\"isDisableEditRowCellFunction(rowData, col)\"\r\n                      class=\"cellControl col\"\r\n                      [mask]=\"col.mask\"\r\n                      [required]=\"col.required ?? true\"\r\n                      [(ngModel)]=\"rowData[col.field]\"\r\n                    ></kv-input-mask>\r\n                  </div>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'switch'\">\r\n                  <div [style.width]=\"col.width\" class=\"grid formgrid p-fluid\">\r\n                    <kv-switch\r\n                      [disabled]=\"isDisableEditRowCellFunction(rowData, col)\"\r\n                      class=\"cellControl col\"\r\n                      [(ngModel)]=\"rowData[col.field]\"\r\n                    ></kv-switch>\r\n                  </div>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'calendar'\">\r\n                  <div [style.width]=\"col.width\">\r\n                    <div\r\n                      [style.width]=\"col.width\"\r\n                      class=\"grid formgrid p-fluid\"\r\n                    >\r\n                      <kv-input-calendar\r\n                        class=\"cellControl col\"\r\n                        [(ngModel)]=\"rowData[col.field]\"\r\n                      ></kv-input-calendar>\r\n                    </div>\r\n                  </div>\r\n                </ng-container>\r\n                <ng-container *ngSwitchCase=\"'dropdown'\">\r\n                  <div [style.width]=\"col.width\" class=\"grid formgrid p-fluid\">\r\n                    <p-dropdown\r\n                      [disabled]=\"isDisableEditRowCellFunction(rowData, col)\"\r\n                      class=\"cellControl col\"\r\n                      appendTo=\"body\"\r\n                      [panelStyle]=\"{ 'font-size': '0.75rem' }\"\r\n                      [optionLabel]=\"col.fieldDropDownControl.descricaoobjeto\"\r\n                      [optionValue]=\"col.fieldDropDownControl.idobjeto\"\r\n                      [options]=\"\r\n                        col.fieldDropDownControl.fieldControlDropdownSource\r\n                      \"\r\n                      [(ngModel)]=\"rowData[col.field]\"\r\n                    >\r\n                    </p-dropdown>\r\n                  </div>\r\n                </ng-container>\r\n              </ng-container>\r\n            </ng-container>\r\n\r\n            <ng-template #templatevisualedicao>\r\n              <ng-container\r\n                *ngTemplateOutlet=\"\r\n                  templateOutput;\r\n                  context: { rowData: rowData, col: col }\r\n                \"\r\n              ></ng-container>\r\n            </ng-template>\r\n          </ng-template>\r\n\r\n          <ng-template #templateOutput let-rowData=\"rowData\" let-col=\"col\">\r\n            <ng-container [ngSwitch]=\"col.fieldControlType\">\r\n              <ng-container *ngSwitchCase=\"'dropdown'\">\r\n                <ng-container *ngIf=\"rowData[col.field]\">\r\n                  {{ retornaDescricaoDrop(rowData, col) }}\r\n                  <!-- {{rowData[col.field]}} -->\r\n                </ng-container>\r\n              </ng-container>\r\n\r\n              <ng-container *ngSwitchCase=\"'switch'\">\r\n                <kv-switch\r\n                  [(ngModel)]=\"rowData[col.field]\"\r\n                  [disabled]=\"true\"\r\n                ></kv-switch>\r\n              </ng-container>\r\n\r\n              <ng-container *ngSwitchCase=\"'calendar'\">\r\n                {{ rowData[col.field] | date }}\r\n              </ng-container>\r\n\r\n              <ng-container *ngSwitchCase=\"'mask'\">\r\n                {{ rowData[col.field] | mask : col.mask }}\r\n              </ng-container>\r\n\r\n              <ng-container *ngSwitchDefault>\r\n                {{ rowData[col.field] }}\r\n              </ng-container>\r\n            </ng-container>\r\n          </ng-template>\r\n\r\n          <td\r\n            *ngIf=\"editMode == 'cell' && col.fieldControlType\"\r\n            [pEditableColumn]=\"rowData\"\r\n            [pEditableColumnField]=\"col.field\"\r\n            [pEditableColumnRowIndex]=\"rowData[config.dataKey]\"\r\n            [id]=\"'rowTable' + rowData[config.dataKey]\"\r\n            (click)=\"activeItem(rowData)\"\r\n            (dblclick)=\"dbClickEdit()\"\r\n            class=\"rowTable\"\r\n            [style]=\"\r\n              applyStyle(rowData, col) +\r\n              centralizarColunas(col) +\r\n              alignColunas(col)\r\n            \"\r\n            [pTooltip]=\"returnTooltipRow(rowData, col)\"\r\n          >\r\n            <p-cellEditor>\r\n              <ng-container>\r\n                <ng-template pTemplate=\"input\">\r\n                  <ng-container\r\n                    *ngTemplateOutlet=\"\r\n                      templateInput;\r\n                      context: { rowData: rowData, col: col }\r\n                    \"\r\n                  ></ng-container>\r\n                </ng-template>\r\n\r\n                <ng-template pTemplate=\"output\">\r\n                  <ng-container\r\n                    *ngTemplateOutlet=\"\r\n                      templateOutput;\r\n                      context: { rowData: rowData, col: col }\r\n                    \"\r\n                  ></ng-container>\r\n                </ng-template>\r\n              </ng-container>\r\n\r\n              <!-- <ng-template *ngIf=\"!isEditing\" pTemplate=\"input\">\r\n          <ng-container *ngTemplateOutlet=\"templateInput; context: { rowData: rowData, col: col }\"></ng-container>\r\n        </ng-template>\r\n\r\n        <ng-template *ngIf=\"isEditing\" pTemplate=\"output\">\r\n          <ng-container *ngTemplateOutlet=\"templateOutput; context: { rowData: rowData, col: col }\"></ng-container>\r\n        </ng-template> -->\r\n            </p-cellEditor>\r\n          </td>\r\n\r\n          <!-- NOTE: Edição de linha -->\r\n          <!-- ----------------------------------------------------------------------------------------------------------------------------------- -->\r\n          <!-- ----------------------------------------------------------------------------------------------------------------------------------- -->\r\n          <!-- ----------------------------------------------------------------------------------------------------------------------------------- -->\r\n\r\n          <!-- Celula que armazena os controles de edição para os campos -->\r\n          <td\r\n            *ngIf=\"false && col.fieldControlType && editMode == 'row'\"\r\n            [id]=\"'rowTable' + rowData[config.dataKey]\"\r\n            (click)=\"activeItem(rowData)\"\r\n            (dblclick)=\"dbClickEdit()\"\r\n            class=\"rowTable\"\r\n            [style]=\"\r\n              applyStyle(rowData, col) +\r\n              centralizarColunas(col) +\r\n              alignColunas(col)\r\n            \"\r\n            [pTooltip]=\"returnTooltipRow(rowData, col)\"\r\n          >\r\n            <p-cellEditor\r\n              [ngClass]=\"{ switch: col.fieldControlType == 'switch' }\"\r\n            >\r\n              <ng-template pTemplate=\"input\">\r\n                <ng-container\r\n                  *ngTemplateOutlet=\"\r\n                    templateInput;\r\n                    context: { rowData: rowData, col: col }\r\n                  \"\r\n                ></ng-container>\r\n              </ng-template>\r\n\r\n              <ng-template pTemplate=\"output\">\r\n                <ng-container\r\n                  *ngTemplateOutlet=\"\r\n                    templateOutput;\r\n                    context: { rowData: rowData, col: col }\r\n                  \"\r\n                ></ng-container>\r\n              </ng-template>\r\n            </p-cellEditor>\r\n          </td>\r\n\r\n          <!-- ----------------------------------------------------------------------------------------------------------------------------------- -->\r\n          <!-- ----------------------------------------------------------------------------------------------------------------------------------- -->\r\n          <!-- ----------------------------------------------------------------------------------------------------------------------------------- -->\r\n\r\n          <td\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            [pTooltip]=\"returnTooltipRow(rowData, col)\"\r\n          >\r\n            <span class=\"p-column-title\">{{ 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              <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 && !isSwitchField(col)\"\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\r\n              <span\r\n                *ngIf=\"isSwitchField(col)\"\r\n                [class]=\"returnRowClass(rowData, col)\"\r\n              >\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              </span>\r\n            </ng-template>\r\n          </td>\r\n\r\n          <td\r\n            *ngIf=\"\r\n              !rowgroup &&\r\n              !col.grouped &&\r\n              !col.template &&\r\n              !col.fieldControlType\r\n            \"\r\n            [style]=\"\r\n              applyStyle(rowData, col) +\r\n              centralizarColunas(col) +\r\n              alignColunas(col)\r\n            \"\r\n            class=\"rowTable\"\r\n            [pTooltip]=\"returnTooltipRow(rowData, col)\"\r\n          >\r\n            <span class=\"p-column-title\">{{ 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              <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 && !isSwitchField(col)\"\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\r\n              <span\r\n                *ngIf=\"isSwitchField(col)\"\r\n                [class]=\"returnRowClass(rowData, col)\"\r\n              >\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              </span>\r\n            </ng-template>\r\n          </td>\r\n\r\n          <td\r\n            *ngIf=\"col.template && !isEditableTable()\"\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            <span class=\"p-column-title\">{{ col.header }}:</span>\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          </td>\r\n        </ng-container>\r\n\r\n        <!-- ------------------------------------------------------------------------------------------------------------------------------------------- -->\r\n        <!-- Controle de ação  -->\r\n        <td\r\n          [ngClass]=\"{\r\n            'td-tools': isEditableTable() && this.editMode == 'row',\r\n            'td-tools-sticky': !isEditableTable() || this.editMode == 'cell'\r\n          }\"\r\n          *ngIf=\"!isEditing && config.actions && config.actions.length > 0\"\r\n          [style]=\"\r\n            applyStyle(rowData, { field: 'btns-options', header: '' }) +\r\n            'border-right: 1px solid #ddd !important; border-left: 1px solid #ddd !important;'\r\n          \"\r\n        >\r\n          <div class=\"flex flex-row justify-content-end w-full\">\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)\"\r\n          > -->\r\n            <span\r\n              class=\"material-symbols-outlined cursor-pointer icon-more-horiz\"\r\n              style=\"font-size: 1rem; height: 10px; width: 20px\"\r\n              (click)=\"menu.toggle($event); activeItem(rowData)\"\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) }}\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        </td>\r\n\r\n        <!-- <td\r\n      class=\"td-tools\"\r\n      *ngIf=\"!isEditing && config.actions && config.actions.length > 0\"\r\n      [style]=\"applyStyle(rowData, { field: 'btns-options', header: '' })\"\r\n    >\r\n      </td> -->\r\n\r\n        <!-- ------------------------------------------------------------------------------------------------------------------------------------------- -->\r\n        <!-- Controle de edição -->\r\n        <td\r\n          class=\"td-edit\"\r\n          *ngIf=\"this.isEditableTable() && this.editMode == 'row'\"\r\n        >\r\n          <div class=\"flex align-items-center justify-content-center gap-2\">\r\n            <button\r\n              [style.height]=\"'28px'\"\r\n              [id]=\"'rowEdit' + rowData[config.dataKey]\"\r\n              [style.width]=\"'28px'\"\r\n              [disabled]=\"isDisableEditRowFunction(rowData)\"\r\n              *ngIf=\"!editing\"\r\n              pButton\r\n              pRipple\r\n              type=\"button\"\r\n              pInitEditableRow\r\n              icon=\"pi pi-pencil\"\r\n              (click)=\"onRowEditInit(rowData)\"\r\n              class=\"p-button-rounded p-button-text\"\r\n            ></button>\r\n            <!-- <button [style.height]=\"'28px'\" [style.width]=\"'28px'\" [disabled]=\"isDisableEditRowFunction(rowData)\" *ngIf=\"editing\" pButton pRipple type=\"button\" pSaveEditableRow icon=\"pi pi-check\"\r\n              (click)=\"onRowEditSave(rowData, ri)\" [id]=\"'rowSave' + rowData[config.dataKey] \" class=\"p-button-rounded p-button-text p-button-success mr-2\"></button> -->\r\n            <button\r\n              [style.height]=\"'28px'\"\r\n              [style.width]=\"'28px'\"\r\n              [disabled]=\"isDisableEditRowFunction(rowData)\"\r\n              *ngIf=\"editing\"\r\n              pButton\r\n              pRipple\r\n              type=\"button\"\r\n              pCancelEditableRow\r\n              icon=\"pi pi-times\"\r\n              (click)=\"onRowEditCancel(rowData, ri)\"\r\n              [id]=\"'rowCancel' + rowData[config.dataKey]\"\r\n              class=\"p-button-rounded p-button-text p-button-danger\"\r\n            ></button>\r\n          </div>\r\n        </td>\r\n      </tr>\r\n    </ng-template>\r\n  </p-table>\r\n</div>\r\n"]}
|
|
290
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-table-edit.component.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/components/kv-table-edit/kv-table-edit.component.ts","../../../../../../projects/keevo-components/src/lib/components/kv-table-edit/kv-table-edit.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnChanges,\r\n  OnInit,\r\n  Output,\r\n  SimpleChanges} from '@angular/core';\r\n\r\nimport {\r\n  DatePipe,\r\n  DecimalPipe\r\n} from '@angular/common';\r\n\r\nimport {\r\n  MenuItem} from 'primeng/api';\r\n\r\n\r\nimport {\r\n  CpfCnpjPipe,\r\n  NotificationService,\r\n  TelefonePipe,\r\n  ValueOrFn,\r\n  getOrExecute,\r\n  mapToMenuItem\r\n} from '../../../public-api';\r\n\r\nimport { TableEditConfigColumn } from '../../api/components/table/tableedit.config.column';\r\nimport TableEditConfig from '../../api/components/table/tabledit.config';\r\nimport { Subject, Subscription, takeUntil, timer } from 'rxjs';\r\nimport { BasecomponentTable } from '../../api/base-components/base-component-table';\r\n\r\n@Component({\r\n  selector: 'kv-table-edit',\r\n  templateUrl: './kv-table-edit.component.html',\r\n  styleUrls: ['./kv-table-edit.component.scss']\r\n})\r\nexport class KvTableEditComponent extends BasecomponentTable implements OnInit, OnChanges {\r\n\r\n\r\n  override config!: TableEditConfig;\r\n\r\n  @Input() enableSizes: boolean = false;\r\n  @Input() editMode: 'row' | 'cell' = 'cell';\r\n  private itemsParaSalvamento: any[] = []\r\n  protected itemInitialState!: any;\r\n\r\n  isEditing: boolean = false;\r\n  isShowSizes: boolean = false;\r\n  clonedDataSource: { [s: string]: any } = {};\r\n  selectedProduct: any = {\r\n    rowData: {},\r\n    editing: false\r\n  };\r\n\r\n  menuItems: MenuItem[] = [];\r\n  //\r\n  itemsContextMenu!: MenuItem[];\r\n\r\n  /**  Emite evento de salvamento da linha */\r\n  @Output() onSave: EventEmitter<any> = new EventEmitter();\r\n  @Output() filterField: EventEmitter<any> = new EventEmitter();\r\n\r\n  constructor(\r\n    datePipe: DatePipe,\r\n    decimalPipe: DecimalPipe,\r\n    cpfCnpjPipe: CpfCnpjPipe,\r\n    telefonePipe: TelefonePipe,\r\n    notificationService: NotificationService\r\n    // capitalizePipe: CapitalizePipe,\r\n  ) {\r\n    super(datePipe, decimalPipe, cpfCnpjPipe, telefonePipe, notificationService);\r\n    this.isRowSelectable = this.isRowSelectable.bind(this);\r\n  }\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  sizes = [\r\n    {\r\n      label: 'Pequeno', class: 'p-datatable-sm', size: 0.83, command: (x: any) => {\r\n        this.selectedSize = { label: 'Pequeno', class: 'p-datatable-sm', size: 0.83 }\r\n      }\r\n    },\r\n    {\r\n      label: 'Médio', class: 'p-datatable-md', size: 1, command: (x: any) => {\r\n        this.selectedSize = { label: 'Médio', class: 'p-datatable-md', size: 1 }\r\n      }\r\n    },\r\n    {\r\n      label: 'Grande', class: 'p-datatable-lg', size: 1.17, command: (x: any) => {\r\n        this.selectedSize = { label: 'Large', class: 'p-datatable-lg', size: 1.17 }\r\n\r\n      }\r\n    },\r\n\r\n    // { name: 'Small', class: 'p-datatable-sm', size:  0.83 },\r\n    // { name: 'Normal', class: 'p-datatable-md', size: 1 },\r\n    // { name: 'Large',  class: 'p-datatable-lg', size: 1.17 }\r\n  ];\r\n\r\n\r\n  //FIXME: Mover para um local adequado\r\n  timerSubscription!: Subscription; // Assinatura do temporizador\r\n  onSaveTimer$: Subject<void> = new Subject<void>(); // Sujeito para controlar o temporizador\r\n  private onDestroy$: Subject<void> = new Subject<void>();\r\n\r\n  override ngOnInit() {\r\n    super.ngOnInit();\r\n\r\n    this.onSaveTimer$.pipe(\r\n      takeUntil(this.onDestroy$)\r\n    ).subscribe(() => {\r\n      // Quando o temporizador terminar, emita o evento onSave com os dados a serem salvos\r\n      this.onRowEditSave();\r\n    });\r\n\r\n\r\n    this.tamanhoTela = window.innerWidth;\r\n\r\n    this.itemsContextMenu = [\r\n      {\r\n        label: 'Editar linha', icon: 'pi pi-fw pi-pencil', command: () => {\r\n          const element = document.getElementById('rowEdit' + this.selectedProduct.rowData[this.config.dataKey]);\r\n          if (element && !this.config.disableEditRowFunction?.(this.selectedProduct.rowData)) {\r\n            element.click()\r\n          } else {\r\n            this.notificationService.toastWarn(\"A edição dessa linha esta desabilitada\")\r\n          }\r\n          this.onRowEditInit(this.selectedProduct)\r\n\r\n        }\r\n      },\r\n      {\r\n        label: 'Cancelar edição', icon: 'pi pi-fw pi-times', command: (data: any) => {\r\n          const element = document.getElementById('rowCancel' + this.selectedProduct.rowData[this.config.dataKey]);\r\n          if (element) {\r\n            element.click();\r\n          } else {\r\n            this.notificationService.toastWarn(\"A edição dessa linha esta desabilitada\")\r\n          }\r\n        }\r\n      },\r\n      {\r\n        label: 'Salvar edição', icon: 'pi pi-fw pi-save', command: (data: any) => {\r\n          const element = document.getElementById('rowSave' + this.selectedProduct.rowData[this.config.dataKey]);\r\n          if (element) {\r\n            element.click(); // Dispara um evento de clique no elemento com ID 'teste'\r\n          } else {\r\n            this.notificationService.toastWarn(\"A edição dessa linha esta desabilitada\")\r\n          }\r\n        }\r\n      },\r\n      {\r\n        label: 'Entrar em modo de edição', icon: 'pi pi-fw pi-pencil', command: () => {\r\n          this.isEditing = true;\r\n        }\r\n      },\r\n      {\r\n        label: 'Sair do modo de edição', icon: 'pi pi-fw pi-pencil', command: () => {\r\n          this.isEditing = false;\r\n          if (this.itemsParaSalvamento.length > 0)\r\n            this.onRowEditSave();\r\n        }\r\n      },\r\n    ];\r\n\r\n\r\n    // Subscreve-se ao sujeito onSaveTimer$\r\n\r\n\r\n  }\r\n  override adjustTableSize(){\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    // Completa o sujeito onDestroy$\r\n    this.onDestroy$.next();\r\n    this.onDestroy$.complete();\r\n    // Se houver um temporizador em execução, pare-o\r\n    if (this.timerSubscription) {\r\n      this.timerSubscription.unsubscribe();\r\n      // Após parar o temporizador, chame onSave diretamente para salvar os dados\r\n      this.onRowEditSave();\r\n    }\r\n  }\r\n\r\n  ngDoCheck(): void {\r\n    this.itemsContextMenu[0].visible = this.editMode == 'row' && !this.selectedProduct.editing && this.isEditableTable() !== false;\r\n    this.itemsContextMenu[1].visible = this.editMode == 'row' && this.selectedProduct.editing && this.isEditableTable() !== false;\r\n    this.itemsContextMenu[2].visible = this.editMode == 'row' && this.selectedProduct.editing && this.isEditableTable() !== false;\r\n\r\n    this.itemsContextMenu[3].visible = this.editMode == 'cell' && !this.isEditing;\r\n    this.itemsContextMenu[4].visible = this.editMode == 'cell' && this.isEditing;\r\n\r\n\r\n  }\r\n\r\n  dbClickEdit() {\r\n\r\n    const element = document.getElementById('rowEdit' + this.selectedItem[this.config.dataKey]);\r\n    if (element) {\r\n      element.click();\r\n    } else {\r\n      if (this.editMode == 'row')\r\n        this.notificationService.toastWarn(\"A edição dessa linha esta desabilitada\")\r\n    }\r\n  }\r\n\r\n  isRowSelectable(event: any) {\r\n    return !this.isDisabledCheckbox(event.data);\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    //Called before any other lifecycle hook. Use it to inject dependencies, but avoid any serious work here.\r\n    //Add '${implements OnChanges}' to the class.\r\n    if (changes['setConfig'] && this.config) {\r\n\r\n      this.config.columns.forEach((e: TableEditConfigColumn) => {\r\n        if (e.fieldControlType == 'dropdown') {\r\n          this.listarDrop(e.fieldDropDownControl?.fieldControlDropdownService, e)\r\n\r\n        }\r\n      })\r\n    }\r\n  }\r\n  criarMenusModal(data: any) {\r\n    if (this.config.actions && data) {\r\n      for (const action of this.config.actions) {\r\n        const menuInsert = mapToMenuItem(action, data);\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  onRowEditInit(rowData: any) {\r\n    this.clonedDataSource[rowData.id as string] = { ...rowData };\r\n  }\r\n\r\n  onEditInit(event1: any) {\r\n    if (this.isEditing) this.itemInitialState = { ...event1.data }\r\n  }\r\n  onEditComplete(event: any) {\r\n    if (this.isEditing) {\r\n      //Verificamos se e o prmeiro item ou se o novo item ainda e do mesmo objeto. Alem disso verificamos se o campo foi realmente alterado abaixo\r\n      if (\r\n        this.itemsParaSalvamento.length === 0 ||\r\n        this.itemsParaSalvamento[this.itemsParaSalvamento.length - 1].index === event.index\r\n      ) {\r\n        if (event.data[event.field] != this.itemInitialState[event.field]) {\r\n          this.adicionarCelulaParaSalvar(event);\r\n        }\r\n      } else {\r\n        // Se o último item editado não for da mesma linha, emita o evento onSave e adicione o item atual para salvar\r\n        this.onRowEditSave();\r\n        this.adicionarCelulaParaSalvar(event);\r\n      }\r\n    }\r\n\r\n  }\r\n\r\n  adicionarCelulaParaSalvar(item: any) {\r\n    // Adiciona os dados editados ao array para salvamento\r\n    this.itemsParaSalvamento.push(item);\r\n\r\n    // Se houver um temporizador em execução, limpe-o e reinicie\r\n    if (this.timerSubscription) {\r\n      this.timerSubscription.unsubscribe();\r\n    }\r\n\r\n    // Inicia o temporizador para emitir onSave após 5 segundos\r\n    this.timerSubscription = timer(5000).subscribe(() => {\r\n      this.onSaveTimer$.next(); // Emita onSave após 5 segundos\r\n    });\r\n  }\r\n\r\n\r\n  onRowEditSave() {\r\n\r\n    const objetoRefletido: any = { ...this.itemsParaSalvamento[0].data };\r\n    // Reflete as alterações em um objeto\r\n    this.itemsParaSalvamento.forEach(item => {\r\n      const chave = item.field\r\n      const valor = item.data[chave];\r\n      objetoRefletido[chave] = valor;\r\n    });\r\n    this.onSave.emit(objetoRefletido)\r\n    this.itemsParaSalvamento = [];\r\n  }\r\n\r\n\r\n  onRowEditCancel(product: any, index: number) {\r\n    this.dataSource[index] = this.clonedDataSource[product.id as string];\r\n    delete this.clonedDataSource[product.id as string];\r\n  }\r\n\r\n  listarDrop(service: any, col: any, indtodos?: boolean) {\r\n    const column = this.config.columns?.indexOf(col);\r\n    return this.config.columns[column].fieldDropDownControl?.fieldControlDropdownSource\r\n  }\r\n\r\n  retornaDescricaoDrop(rowData: any[], col: TableEditConfigColumn) {\r\n\r\n    const data = col.fieldDropDownControl?.fieldControlDropdownSource\r\n    const idobjeto = col.fieldDropDownControl?.idobjeto\r\n    const descricaoobjeto = col.fieldDropDownControl?.descricaoobjeto\r\n    // @ts-ignore\r\n    const valorAtual = rowData[col.field]\r\n\r\n    if (data && idobjeto && descricaoobjeto)\r\n      return data?.find((item: any) => item[idobjeto] == valorAtual)[descricaoobjeto]\r\n    else return 'Carregando'\r\n  }\r\n\r\n\r\n\r\n  isDisableEditRowFunction(rowData: any): boolean {\r\n    return this.config.disableEditRowFunction ? this.config.disableEditRowFunction(rowData) : false;\r\n  }\r\n\r\n  isDisableEditRowCellFunction(rowData: any, col: any): boolean {\r\n    return col.disableEditRowCellFunction ? col.disableEditRowCellFunction(rowData) : false;\r\n  }\r\n\r\n  isEditableTable(): boolean | null {\r\n    if (!this.config.columns)\r\n      return null;\r\n\r\n    return this.config.columns.some((column: any) => 'fieldControlType' in column);\r\n  }\r\n}\r\n\r\n","<div class=\"card\" id=\"tamanhotabela\" [style.font-size]=\"'1px'\">\r\n  <p-toast></p-toast>\r\n\r\n  <p-panel\r\n    *ngIf=\"filtrosAvancados\"\r\n    header=\"Filtros avançados\"\r\n    [toggleable]=\"true\"\r\n    [collapsed]=\"true\"\r\n    (collapsedChange)=\"collapsed = !collapsed\"\r\n    [style]=\"{ 'margin-bottom': '2px' }\"\r\n  >\r\n    <ng-template pTemplate=\"headericons\">\r\n      <i *ngIf=\"!collapsed\" class=\"pi pi-filter\"></i>\r\n      <!-- Ícone quando o painel está aberto -->\r\n      <i *ngIf=\"collapsed\" class=\"pi pi-minus\"></i>\r\n      <!-- Ícone quando o painel está fechado -->\r\n    </ng-template>\r\n    <ng-content></ng-content>\r\n  </p-panel>\r\n\r\n  <p-contextMenu #cm [model]=\"itemsContextMenu\"></p-contextMenu>\r\n  <p-table\r\n    #te\r\n    [editMode]=\"editMode\"\r\n    (onEditComplete)=\"onEditComplete($event)\"\r\n    (onEditInit)=\"onEditInit($event)\"\r\n    [reorderableColumns]=\"config.reorderableColumns || false\"\r\n    *ngIf=\"config\"\r\n    [value]=\"dataSource\"\r\n    [dataKey]=\"config.dataKey\"\r\n    [columns]=\"config.columns\"\r\n    [scrollable]=\"true\"\r\n    appendTo=\"body\"\r\n    [styleClass]=\"selectedSize.class\"\r\n    [(selection)]=\"selectedItems\"\r\n    [rowSelectable]=\"isRowSelectable\"\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    (selectionChange)=\"selectionChange($event)\"\r\n    [rowHover]=\"true\"\r\n    [totalRecords]=\"totalRecords\"\r\n    [lazy]=\"config.lazy\"\r\n    (onLazyLoad)=\"paginate($event)\"\r\n    [groupRowsBy]=\"config.fieldGroup\"\r\n    paginatorDropdownAppendTo=\"body\"\r\n    [showFirstLastIcon]=\"showFirstLastIcon\"\r\n    [pageLinks]=\"pageLinksOptions\"\r\n    [scrollable]=\"isTableScrollable\"\r\n    [scrollHeight]=\"scrollHeight\"\r\n    [rowTrackBy]=\"rowTrackBy\"\r\n    [(contextMenuSelection)]=\"selectedProduct\"\r\n    [contextMenu]=\"isEditableTable() ? cm : null\"\r\n  >\r\n    <!-- ----------------------------------------------------------------------------------------------------------------------------------- -->\r\n\r\n    <ng-template pTemplate=\"caption\" *ngIf=\"config.enableCation || enableSizes\">\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=\"flex flex-row align-items-center md:col-6 lg:col-4 {{\r\n            tamanhoTela < 768 ? 'col-10' : 'col-12'\r\n          }} mt-1 mb-2 \"\r\n        >\r\n          <span *ngIf=\"config.enableFilter\" class=\"p-input-icon-left\">\r\n            <i class=\"pi pi-search\"></i>\r\n\r\n            <input\r\n              pInputText\r\n              pAutoFocus\r\n              [autofocus]=\"true\"\r\n              type=\"text\"\r\n              (input)=\"onGlobalFilter(te, $event)\"\r\n              placeholder=\"Pesquisar...\"\r\n              class=\"h-2rem\"\r\n            />\r\n          </span>\r\n\r\n          <!-- FIXME: Opção 1  -->\r\n          <!-- <div class=\"sizes-controls ml-2\" *ngIf=\"isShowSizes\">\r\n            <p-selectButton\r\n                [options]=\"sizes\"\r\n                [(ngModel)]=\"selectedSize\"\r\n                [style]=\"{'display': 'flex'}\"\r\n                optionLabel=\"name\"\r\n                />\r\n          </div>\r\n         <button\r\n          id=\"btn-sizes\"\r\n          pButton\r\n          [pTooltip]=\"isShowSizes ? 'Esconder controles de tamanho' : 'Mostrar controles de tamanho'\"\r\n          class=\"actionLoteBtns p-button-raised p-button-text\"\r\n          (click)=\"isShowSizes = !isShowSizes\"\r\n        >\r\n          <span  style=\"font-size: 0.8rem;\" class=\"flex align-items-end\">\r\n          <span  style=\"font-size: 0.7rem;\">\r\n            A\r\n          </span>\r\n            A\r\n          </span>\r\n        </button> -->\r\n\r\n          <!-- FIXME: Opção 2  -->\r\n          <div *ngIf=\"enableSizes\" class=\"sizes-controls ml-2\">\r\n            <!-- <p-splitButton\r\n              label=\"aA\"\r\n              [model]=\"sizes\"\r\n              styleClass=\"teste\"\r\n              [menuStyle]=\"{'font-size': '0.7rem'}\"\r\n\r\n              ngModel\r\n            >\r\n            </p-splitButton> -->\r\n            <!-- <p-button  icon=\"pi pi-ellipsis-v\"/> -->\r\n\r\n            <button\r\n              id=\"actionLoteBtns\"\r\n              pButton\r\n              (click)=\"menu.toggle($event)\"\r\n              class=\"actionLoteBtns p-button-raised p-button-text\"\r\n              style=\"background-color: #1da750; color: #fff; display: flex\"\r\n            >\r\n              <span class=\"text-xs\">A</span>\r\n              <span class=\"text-md\">A</span>\r\n            </button>\r\n\r\n            <p-tieredMenu\r\n              [style]=\"{ 'font-size': '0.7rem' }\"\r\n              styleClass=\"menuSizes\"\r\n              appendTo=\"body\"\r\n              #menu\r\n              [model]=\"sizes\"\r\n              [popup]=\"true\"\r\n            >\r\n              <ng-template let-item pTemplate=\"item\">\r\n                <div\r\n                  class=\"cursor-pointer flex gap-2 align-items-center pl-1 m-2 menu-sizes\"\r\n                  (click)=\"item.command()\"\r\n                >\r\n                  <div\r\n                    *ngIf=\"this.selectedSize.size != item.size\"\r\n                    class=\"tag\"\r\n                    [style.background-color]=\"'#EAEAEA'\"\r\n                  ></div>\r\n                  <div\r\n                    *ngIf=\"this.selectedSize.size == item.size\"\r\n                    class=\"tag\"\r\n                    [style.background-color]=\"'#1DA750'\"\r\n                  ></div>\r\n\r\n                  {{ item.label }}\r\n                </div>\r\n              </ng-template>\r\n            </p-tieredMenu>\r\n          </div>\r\n          <!-- FIXME: Opção 3  -->\r\n          <!-- <div class=\"sizes-controls ml-2\" style=\"transform: translate(0px, -15px);\" >\r\n            <p-speedDial\r\n              [model]=\"sizes\"\r\n              showIcon=\"format_size\"\r\n              [mask]=\"true\"\r\n              direction=\"right\"\r\n              buttonClassName=\"item-circle\"\r\n            >\r\n\r\n\r\n\r\n\r\n            <ng-template let-item pTemplate=\"item\" >\r\n              <div class=\"item-circle cursor-pointer\r\n\r\n              shadow-2 hover:shadow-8\r\n\r\n              \" (click)=\"item.command()\">\r\n                {{item.label}}\r\n              </div>\r\n            </ng-template>\r\n\r\n          </p-speedDial>\r\n          </div> -->\r\n        </div>\r\n\r\n        <span *ngIf=\"isEditing\" class=\"text-aviso\">\r\n          Tabela em modo de edição\r\n        </span>\r\n\r\n        <div class=\"flex flex-row col-1 justify-content-end\">\r\n          <div\r\n            *ngFor=\"let action of config.actionsLote\"\r\n            class=\"btns-options flex flex-row\"\r\n          >\r\n            <button\r\n              id=\"actionLoteBtns\"\r\n              pButton\r\n              *ngIf=\"\r\n                !isEditing &&\r\n                (selectedItems.length > 0 || action.showAcoesLote) &&\r\n                exibirCampo(action, this.action)\r\n              \"\r\n              class=\"actionLoteBtns border-none\"\r\n              style=\"background-color: #1da750\"\r\n              (click)=\"action?.command(); activeItemLote(selectedItems)\"\r\n              [pTooltip]=\"getOrExecute(action.tooltip, selectedItems)\"\r\n              [tooltipPosition]=\"'bottom'\"\r\n              [disabled]=\"getOrExecute(action.disabled, selectedItems)\"\r\n            >\r\n              <span\r\n                class=\"material-symbols-outlined\"\r\n                style=\"color: white\"\r\n              >\r\n                {{ getOrExecute(action.icon, selectedItems) }}\r\n              </span>\r\n            </button>\r\n          </div>\r\n\r\n          <div\r\n            *ngIf=\"isEditableTable()\"\r\n            class=\"btns-options\"\r\n            [style]=\"{ 'margin-right': '7px' }\"\r\n          >\r\n            <button\r\n              (click)=\"this.isEditing = !this.isEditing\"\r\n              id=\"actionLoteBtns\"\r\n              pButton\r\n              style=\"background-color: #1da750; color: #fff\"\r\n              class=\"actionLoteBtns p-button-raised p-button-text\"\r\n            >\r\n              <span class=\"material-symbols-outlined\"> edit_square </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          style=\"width: 4rem; border-left: solid 4px transparent\"\r\n          *ngIf=\"config.enableSelect && !isEditing\"\r\n          [class]=\"selectedSize.class + 'th'\"\r\n        >\r\n          <p-tableHeaderCheckbox\r\n            (click)=\"activeItemLote(selectedItems)\"\r\n          ></p-tableHeaderCheckbox>\r\n        </th>\r\n\r\n        <th\r\n          *ngFor=\"let col of columns\"\r\n          [pSortableColumn]=\"col.field\"\r\n          [pSortableColumnDisabled]=\"col.sortable === false\"\r\n          [style.min-width]=\"col.width * selectedSize.size + 'px'\"\r\n          pReorderableColumn\r\n          [class]=\"selectedSize.class + 'th'\"\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        </th>\r\n        <th\r\n          *ngIf=\"!isEditing && config.actions && config.actions.length > 0\"\r\n        ></th>\r\n        <th\r\n          *ngIf=\"isEditableTable() && this.editMode == 'row'\"\r\n          id=\"th-edit\"\r\n          style=\"width: 20px\"\r\n        >\r\n          Editar\r\n        </th>\r\n      </tr>\r\n    </ng-template>\r\n\r\n    <!-- ----------------------------------------------------------------------------------------------------------------------------------- -->\r\n\r\n    <ng-template\r\n      pTemplate=\"body\"\r\n      let-rowData\r\n      let-editing=\"editing\"\r\n      let-ri=\"rowIndex\"\r\n      let-columns=\"columns\"\r\n      let-rowgroup=\"rowgroup\"\r\n      let-rowspan=\"rowspan\"\r\n    >\r\n      <tr\r\n        [pEditableRow]=\"rowData\"\r\n        [pEditableRowDisabled]=\"false\"\r\n        [pContextMenuRow]=\"{rowData, editing}\"\r\n        [class]=\"selectedSize.class + '-tr'\"\r\n      >\r\n        <td\r\n          *ngIf=\"config.enableSelect && !isEditing\"\r\n          [style]=\"applyStyle(rowData, { field: 'check-box', header: '' })\"\r\n        >\r\n          <!--<p-tableCheckbox *ngIf=\"isVisibleCheckbox(rowData)\"-->\r\n          <p-tableCheckbox\r\n            class=\"check-edit-list\"\r\n            [value]=\"rowData\"\r\n            [disabled]=\"isDisabledCheckbox(rowData)\"\r\n            (click)=\"activeItemLote(selectedItems)\"\r\n          ></p-tableCheckbox>\r\n        </td>\r\n\r\n        <ng-container *ngFor=\"let col of columns; let i = index\">\r\n          <!-- FIXME: Testar a implementação abaixo e mesaclar as duas formas -->\r\n\r\n          <ng-template #templateInput let-rowData=\"rowData\" let-col=\"col\">\r\n            <ng-container *ngIf=\"isEditing; else templatevisualedicao\">\r\n              <ng-container [ngSwitch]=\"col.fieldControlType\">\r\n                <ng-container *ngSwitchCase=\"'text'\">\r\n                  <div [style.width]=\"col.width\" class=\"grid formgrid p-fluid\">\r\n                    <kv-input-text\r\n                      [disabled]=\"isDisableEditRowCellFunction(rowData, col)\"\r\n                      class=\"cellControl col\"\r\n                      [(ngModel)]=\"rowData[col.field]\"\r\n                      [required]=\"col.required ?? true\"\r\n                    ></kv-input-text>\r\n                  </div>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'number'\">\r\n                  <div [style.width]=\"col.width\" class=\"grid formgrid p-fluid\">\r\n                    <kv-input-number\r\n                      [disabled]=\"isDisableEditRowCellFunction(rowData, col)\"\r\n                      class=\"cellControl col\"\r\n                      [(ngModel)]=\"rowData[col.field]\"\r\n                      [required]=\"col.required ?? true\"\r\n                    ></kv-input-number>\r\n                  </div>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'mask'\">\r\n                  <div [style.width]=\"col.width\" class=\"grid formgrid p-fluid\">\r\n                    <kv-input-mask\r\n                      [disabled]=\"isDisableEditRowCellFunction(rowData, col)\"\r\n                      class=\"cellControl col\"\r\n                      [mask]=\"col.mask\"\r\n                      [required]=\"col.required ?? true\"\r\n                      [(ngModel)]=\"rowData[col.field]\"\r\n                    ></kv-input-mask>\r\n                  </div>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'switch'\">\r\n                  <div [style.width]=\"col.width\" class=\"grid formgrid p-fluid\">\r\n                    <kv-switch\r\n                      [disabled]=\"isDisableEditRowCellFunction(rowData, col)\"\r\n                      class=\"cellControl col\"\r\n                      [(ngModel)]=\"rowData[col.field]\"\r\n                    ></kv-switch>\r\n                  </div>\r\n                </ng-container>\r\n\r\n                <ng-container *ngSwitchCase=\"'calendar'\">\r\n                  <div [style.width]=\"col.width\">\r\n                    <div\r\n                      [style.width]=\"col.width\"\r\n                      class=\"grid formgrid p-fluid\"\r\n                    >\r\n                      <kv-input-calendar\r\n                        class=\"cellControl col\"\r\n                        [(ngModel)]=\"rowData[col.field]\"\r\n                      ></kv-input-calendar>\r\n                    </div>\r\n                  </div>\r\n                </ng-container>\r\n                <ng-container *ngSwitchCase=\"'dropdown'\">\r\n                  <div [style.width]=\"col.width\" class=\"grid formgrid p-fluid\">\r\n                    <p-dropdown\r\n                      [disabled]=\"isDisableEditRowCellFunction(rowData, col)\"\r\n                      class=\"cellControl col\"\r\n                      appendTo=\"body\"\r\n                      [panelStyle]=\"{ 'font-size': '0.75rem' }\"\r\n                      [optionLabel]=\"col.fieldDropDownControl.descricaoobjeto\"\r\n                      [optionValue]=\"col.fieldDropDownControl.idobjeto\"\r\n                      [options]=\"\r\n                        col.fieldDropDownControl.fieldControlDropdownSource\r\n                      \"\r\n                      [(ngModel)]=\"rowData[col.field]\"\r\n                    >\r\n                    </p-dropdown>\r\n                  </div>\r\n                </ng-container>\r\n              </ng-container>\r\n            </ng-container>\r\n\r\n            <ng-template #templatevisualedicao>\r\n              <ng-container\r\n                *ngTemplateOutlet=\"\r\n                  templateOutput;\r\n                  context: { rowData: rowData, col: col }\r\n                \"\r\n              ></ng-container>\r\n            </ng-template>\r\n          </ng-template>\r\n\r\n          <ng-template #templateOutput let-rowData=\"rowData\" let-col=\"col\">\r\n            <ng-container [ngSwitch]=\"col.fieldControlType\">\r\n              <ng-container *ngSwitchCase=\"'dropdown'\">\r\n                <ng-container *ngIf=\"rowData[col.field]\">\r\n                  {{ retornaDescricaoDrop(rowData, col) }}\r\n                  <!-- {{rowData[col.field]}} -->\r\n                </ng-container>\r\n              </ng-container>\r\n\r\n              <ng-container *ngSwitchCase=\"'switch'\">\r\n                <kv-switch\r\n                  [(ngModel)]=\"rowData[col.field]\"\r\n                  [disabled]=\"true\"\r\n                ></kv-switch>\r\n              </ng-container>\r\n\r\n              <ng-container *ngSwitchCase=\"'calendar'\">\r\n                {{ rowData[col.field] | date }}\r\n              </ng-container>\r\n\r\n              <ng-container *ngSwitchCase=\"'mask'\">\r\n                {{ rowData[col.field] | mask : col.mask }}\r\n              </ng-container>\r\n\r\n              <ng-container *ngSwitchDefault>\r\n                {{ rowData[col.field] }}\r\n              </ng-container>\r\n            </ng-container>\r\n          </ng-template>\r\n\r\n          <td\r\n            *ngIf=\"editMode == 'cell' && col.fieldControlType\"\r\n            [pEditableColumn]=\"rowData\"\r\n            [pEditableColumnField]=\"col.field\"\r\n            [pEditableColumnRowIndex]=\"rowData[config.dataKey]\"\r\n            [id]=\"'rowTable' + rowData[config.dataKey]\"\r\n            (click)=\"activeItem(rowData)\"\r\n            (dblclick)=\"dbClickEdit()\"\r\n            class=\"rowTable\"\r\n            [style]=\"\r\n              applyStyle(rowData, col) +\r\n              centralizarColunas(col) +\r\n              alignColunas(col)\r\n            \"\r\n            [pTooltip]=\"returnTooltipRow(rowData, col)\"\r\n          >\r\n            <p-cellEditor>\r\n              <ng-container>\r\n                <ng-template pTemplate=\"input\">\r\n                  <ng-container\r\n                    *ngTemplateOutlet=\"\r\n                      templateInput;\r\n                      context: { rowData: rowData, col: col }\r\n                    \"\r\n                  ></ng-container>\r\n                </ng-template>\r\n\r\n                <ng-template pTemplate=\"output\">\r\n                  <ng-container\r\n                    *ngTemplateOutlet=\"\r\n                      templateOutput;\r\n                      context: { rowData: rowData, col: col }\r\n                    \"\r\n                  ></ng-container>\r\n                </ng-template>\r\n              </ng-container>\r\n\r\n              <!-- <ng-template *ngIf=\"!isEditing\" pTemplate=\"input\">\r\n          <ng-container *ngTemplateOutlet=\"templateInput; context: { rowData: rowData, col: col }\"></ng-container>\r\n        </ng-template>\r\n\r\n        <ng-template *ngIf=\"isEditing\" pTemplate=\"output\">\r\n          <ng-container *ngTemplateOutlet=\"templateOutput; context: { rowData: rowData, col: col }\"></ng-container>\r\n        </ng-template> -->\r\n            </p-cellEditor>\r\n          </td>\r\n\r\n          <!-- NOTE: Edição de linha -->\r\n          <!-- ----------------------------------------------------------------------------------------------------------------------------------- -->\r\n          <!-- ----------------------------------------------------------------------------------------------------------------------------------- -->\r\n          <!-- ----------------------------------------------------------------------------------------------------------------------------------- -->\r\n\r\n          <!-- Celula que armazena os controles de edição para os campos -->\r\n          <td\r\n            *ngIf=\"false && col.fieldControlType && editMode == 'row'\"\r\n            [id]=\"'rowTable' + rowData[config.dataKey]\"\r\n            (click)=\"activeItem(rowData)\"\r\n            (dblclick)=\"dbClickEdit()\"\r\n            class=\"rowTable\"\r\n            [style]=\"\r\n              applyStyle(rowData, col) +\r\n              centralizarColunas(col) +\r\n              alignColunas(col)\r\n            \"\r\n            [pTooltip]=\"returnTooltipRow(rowData, col)\"\r\n          >\r\n            <p-cellEditor\r\n              [ngClass]=\"{ switch: col.fieldControlType == 'switch' }\"\r\n            >\r\n              <ng-template pTemplate=\"input\">\r\n                <ng-container\r\n                  *ngTemplateOutlet=\"\r\n                    templateInput;\r\n                    context: { rowData: rowData, col: col }\r\n                  \"\r\n                ></ng-container>\r\n              </ng-template>\r\n\r\n              <ng-template pTemplate=\"output\">\r\n                <ng-container\r\n                  *ngTemplateOutlet=\"\r\n                    templateOutput;\r\n                    context: { rowData: rowData, col: col }\r\n                  \"\r\n                ></ng-container>\r\n              </ng-template>\r\n            </p-cellEditor>\r\n          </td>\r\n\r\n          <!-- ----------------------------------------------------------------------------------------------------------------------------------- -->\r\n          <!-- ----------------------------------------------------------------------------------------------------------------------------------- -->\r\n          <!-- ----------------------------------------------------------------------------------------------------------------------------------- -->\r\n\r\n          <td\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            [pTooltip]=\"returnTooltipRow(rowData, col)\"\r\n          >\r\n            <span class=\"p-column-title\">{{ 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              <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 && !isSwitchField(col)\"\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\r\n              <span\r\n                *ngIf=\"isSwitchField(col)\"\r\n                [class]=\"returnRowClass(rowData, col)\"\r\n              >\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              </span>\r\n            </ng-template>\r\n          </td>\r\n\r\n          <td\r\n            *ngIf=\"\r\n              !rowgroup &&\r\n              !col.grouped &&\r\n              !col.template &&\r\n              !col.fieldControlType\r\n            \"\r\n            [style]=\"\r\n              applyStyle(rowData, col) +\r\n              centralizarColunas(col) +\r\n              alignColunas(col)\r\n            \"\r\n            class=\"rowTable\"\r\n            [pTooltip]=\"returnTooltipRow(rowData, col)\"\r\n          >\r\n            <span class=\"p-column-title\">{{ 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              <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 && !isSwitchField(col)\"\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\r\n              <span\r\n                *ngIf=\"isSwitchField(col)\"\r\n                [class]=\"returnRowClass(rowData, col)\"\r\n              >\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              </span>\r\n            </ng-template>\r\n          </td>\r\n\r\n          <td\r\n            *ngIf=\"col.template && !isEditableTable()\"\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            <span class=\"p-column-title\">{{ col.header }}:</span>\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          </td>\r\n        </ng-container>\r\n\r\n        <!-- ------------------------------------------------------------------------------------------------------------------------------------------- -->\r\n        <!-- Controle de ação  -->\r\n        <td\r\n          [ngClass]=\"{\r\n            'td-tools': isEditableTable() && this.editMode == 'row',\r\n            'td-tools-sticky': !isEditableTable() || this.editMode == 'cell'\r\n          }\"\r\n          *ngIf=\"!isEditing && config.actions && config.actions.length > 0\"\r\n          [style]=\"\r\n            applyStyle(rowData, { field: 'btns-options', header: '' }) +\r\n            'border-right: 1px solid #ddd !important; border-left: 1px solid #ddd !important;'\r\n          \"\r\n        >\r\n          <div class=\"flex flex-row justify-content-end w-full\">\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)\"\r\n          > -->\r\n            <span\r\n              class=\"material-symbols-outlined cursor-pointer icon-more-horiz\"\r\n              style=\"font-size: 1rem; height: 10px; width: 20px\"\r\n              (click)=\"menu.toggle($event); activeItem(rowData)\"\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) }}\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        </td>\r\n\r\n        <!-- <td\r\n      class=\"td-tools\"\r\n      *ngIf=\"!isEditing && config.actions && config.actions.length > 0\"\r\n      [style]=\"applyStyle(rowData, { field: 'btns-options', header: '' })\"\r\n    >\r\n      </td> -->\r\n\r\n        <!-- ------------------------------------------------------------------------------------------------------------------------------------------- -->\r\n        <!-- Controle de edição -->\r\n        <td\r\n          class=\"td-edit\"\r\n          *ngIf=\"this.isEditableTable() && this.editMode == 'row'\"\r\n        >\r\n          <div class=\"flex align-items-center justify-content-center gap-2\">\r\n            <button\r\n              [style.height]=\"'28px'\"\r\n              [id]=\"'rowEdit' + rowData[config.dataKey]\"\r\n              [style.width]=\"'28px'\"\r\n              [disabled]=\"isDisableEditRowFunction(rowData)\"\r\n              *ngIf=\"!editing\"\r\n              pButton\r\n              pRipple\r\n              type=\"button\"\r\n              pInitEditableRow\r\n              icon=\"pi pi-pencil\"\r\n              (click)=\"onRowEditInit(rowData)\"\r\n              class=\"p-button-rounded p-button-text\"\r\n            ></button>\r\n            <!-- <button [style.height]=\"'28px'\" [style.width]=\"'28px'\" [disabled]=\"isDisableEditRowFunction(rowData)\" *ngIf=\"editing\" pButton pRipple type=\"button\" pSaveEditableRow icon=\"pi pi-check\"\r\n              (click)=\"onRowEditSave(rowData, ri)\" [id]=\"'rowSave' + rowData[config.dataKey] \" class=\"p-button-rounded p-button-text p-button-success mr-2\"></button> -->\r\n            <button\r\n              [style.height]=\"'28px'\"\r\n              [style.width]=\"'28px'\"\r\n              [disabled]=\"isDisableEditRowFunction(rowData)\"\r\n              *ngIf=\"editing\"\r\n              pButton\r\n              pRipple\r\n              type=\"button\"\r\n              pCancelEditableRow\r\n              icon=\"pi pi-times\"\r\n              (click)=\"onRowEditCancel(rowData, ri)\"\r\n              [id]=\"'rowCancel' + rowData[config.dataKey]\"\r\n              class=\"p-button-rounded p-button-text p-button-danger\"\r\n            ></button>\r\n          </div>\r\n        </td>\r\n      </tr>\r\n    </ng-template>\r\n  </p-table>\r\n</div>\r\n"]}
|
|
@@ -422,11 +422,11 @@ export class KvTableExpandableComponent {
|
|
|
422
422
|
this.dataSource = [...this.dataSource];
|
|
423
423
|
}
|
|
424
424
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvTableExpandableComponent, deps: [{ token: i1.DatePipe }, { token: i1.DecimalPipe }, { token: i2.CpfCnpjPipe }, { token: i3.TelefonePipe }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
425
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: KvTableExpandableComponent, selector: "kv-table-expandable", inputs: { _templates: ["templates", "_templates"], setConfig: ["config", "setConfig"], filtrosAvancados: "filtrosAvancados", dataSource: "dataSource", selectedItems: "selectedItems", tableCaptalized: "tableCaptalized", applyStyle: "applyStyle", tableSize: "tableSize", paginator: "paginator", rows: "rows", rowsPerPageOptions: "rowsPerPageOptions", totalRecords: "totalRecords", pageLinksOptions: "pageLinksOptions", responsiveLayout: "responsiveLayout", isTableScrollable: "isTableScrollable", scrollHeight: "scrollHeight", rowTrackBy: "rowTrackBy", showFirstLastIcon: "showFirstLastIcon" }, outputs: { filterField: "filterField", onActiveItem: "onActiveItem", onActiveItemLote: "onActiveItemLote", doubleClickEvent: "doubleClickEvent", onSwitchTableChange: "onSwitchTableChange", onPaginate: "onPaginate", onSelectionChange: "onSelectionChange" }, ngImport: i0, template: "<div>\r\n @if (filtrosAvancados) {\r\n <p-panel\r\n header=\"Filtros avan\u00E7ados\"\r\n [toggleable]=\"true\"\r\n [collapsed]=\"true\"\r\n (collapsedChange)=\"collapsed = !collapsed\"\r\n [style]=\"{ 'margin-bottom': '2px' }\"\r\n >\r\n <ng-template pTemplate=\"headericons\">\r\n @if (!collapsed) {\r\n <i class=\"pi pi-filter\"></i>\r\n }\r\n <!-- \u00CDcone quando o painel est\u00E1 aberto -->\r\n @if (collapsed) {\r\n <i class=\"pi pi-minus\"></i>\r\n }\r\n <!-- \u00CDcone quando o painel est\u00E1 fechado -->\r\n </ng-template>\r\n <ng-content></ng-content>\r\n </p-panel>\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 rowGroupMode=\"subheader\"\r\n [groupRowsBy]=\"config.fieldGroup\"\r\n [columns]=\"config.columns\"\r\n [lazy]=\"config.lazy\"\r\n (onLazyLoad)=\"paginate($event)\"\r\n (selectionChange)=\"selectionChange($event)\"\r\n (onSort)=\"onSort($event)\"\r\n [sortField]=\"config.fieldGroup\"\r\n sortMode=\"single\"\r\n [dataKey]=\"config.fieldGroup\"\r\n [expandedRowKeys]=\"expandedRows\"\r\n [paginator]=\"paginator\"\r\n [rows]=\"rows\"\r\n [rowsPerPageOptions]=\"rowsPerPageOptions\"\r\n [totalRecords]=\"totalRecords\"\r\n [globalFilterFields]=\"globalFilterFields\"\r\n [showCurrentPageReport]=\"true\"\r\n currentPageReportTemplate=\"{first} - {last} de {totalRecords}\"\r\n [rowHover]=\"true\"\r\n [pageLinks]=\"pageLinksOptions\"\r\n [responsive]=\"true\"\r\n [responsiveLayout]=\"responsiveLayout ? 'stack' : ''\"\r\n [scrollable]=\"isTableScrollable\"\r\n [scrollHeight]=\"scrollHeight\"\r\n [rowTrackBy]=\"rowTrackBy\"\r\n [showFirstLastIcon]=\"showFirstLastIcon\"\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 align-items-center grid formgrid p-fluid col-12 p-0 m-0\"\r\n [style.background-color]=\"'#EAEAEA'\"\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 tamanhoTela < 768 ? 'col-10' : 'col-12'\r\n }} mt-1 mb-2 \"\r\n >\r\n @if (config.enableFilter) {\r\n <span class=\"p-input-icon-left\">\r\n <i class=\"pi pi-search\"></i>\r\n\r\n <input\r\n pInputText\r\n pAutoFocus\r\n [autofocus]=\"true\"\r\n type=\"text\"\r\n (input)=\"onGlobalFilter(dt, $event)\"\r\n placeholder=\"Pesquisar...\"\r\n class=\"h-2rem\"\r\n />\r\n </span>\r\n }\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\"\r\n (click)=\"onClickEvent($event)\"\r\n > -->\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>\r\n @for (col of columns; track col) {\r\n <div class=\"flex flex-column text-medium w-15rem\">\r\n {{ checkMenuFiltro(col) }}\r\n @if (!dinamicDisableColumn(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 ></p-checkbox>\r\n }\r\n </div>\r\n }\r\n </p-card>\r\n </div>\r\n </div>\r\n\r\n <div class=\"flex flex-row col-1 justify-content-end p-0\">\r\n @for (action of config.actionsLote; track i; let i = $index) {\r\n <div class=\"flex flex-row gap-2 btns-options\">\r\n @if ((selectedItems.length > 0 || action.showAcoesLote) &&\r\n (getOrExecute(action.visible, selectedItems) ?? true)) {\r\n <button\r\n pButton\r\n class=\"w-2rem h-2rem flex align-items-center justify-content-center border-none mr-2 btn-table\"\r\n (click)=\"action?.command(); activeItemLote(selectedItems)\"\r\n [pTooltip]=\"getOrExecute(action.tooltip, selectedItems)\"\r\n [tooltipPosition]=\"\r\n (getOrExecute(action.tooltip, selectedItems)?.length ??\r\n 0 > 7) &&\r\n config.actionsLote &&\r\n i == config.actionsLote.length - 1\r\n ? 'left'\r\n : 'bottom'\r\n \"\r\n [disabled]=\"getOrExecute(action.disabled, selectedItems)\"\r\n >\r\n <span\r\n class=\"material-symbols-outlined md-22\"\r\n style=\"color: white\"\r\n >\r\n {{ getOrExecute(action.icon, selectedItems) }}\r\n </span>\r\n </button>\r\n }\r\n </div>\r\n }\r\n </div>\r\n </div>\r\n </ng-template>\r\n } @if (config.enableSelect){\r\n <ng-template pTemplate=\"header\">\r\n <tr>\r\n <th colspan=\"12\">\r\n <div class=\"w-full\">\r\n <!-- <p-tableHeaderCheckbox\r\n (click)=\"activeItemLote(selectedItems)\"\r\n ></p-tableHeaderCheckbox> -->\r\n <input\r\n type=\"checkbox\"\r\n [checked]=\"isAllSelected()\"\r\n [indeterminate]=\"isAllIndeterminate()\"\r\n (click)=\"selectAll($event)\"\r\n />\r\n </div>\r\n </th>\r\n </tr>\r\n </ng-template>\r\n }\r\n\r\n <ng-template\r\n pTemplate=\"groupheader\"\r\n let-group\r\n let-rowIndex=\"rowIndex\"\r\n let-expanded=\"expanded\"\r\n >\r\n <tr>\r\n <td colspan=\"12\" class=\"groupheader\">\r\n <div class=\"flex flex-row align-items-center w-full\">\r\n <button\r\n type=\"button\"\r\n pButton\r\n pRipple\r\n [pRowToggler]=\"group\"\r\n class=\"p-button-text p-button-rounded p-button-plain mr-2\"\r\n [icon]=\"expanded ? 'pi pi-chevron-down' : 'pi pi-chevron-right'\"\r\n ></button>\r\n @if (config.fieldGroupColorFunction){\r\n <div\r\n class=\"tag\"\r\n [style.background-color]=\"config.fieldGroupColorFunction(group)\"\r\n ></div>\r\n }\r\n <span class=\"font-bold ml-2\">{{\r\n group[config.fieldGroup || 0]\r\n }}</span>\r\n </div>\r\n </td>\r\n </tr>\r\n @if(expanded){\r\n <tr style=\"height: 40px\">\r\n @if (config.enableSelect) {\r\n <th class=\"flex align-items-left pl-2\">\r\n <!-- <p-tableHeaderCheckbox\r\n (click)=\"activeItemLote(selectedItems)\"\r\n ></p-tableHeaderCheckbox> -->\r\n <input\r\n type=\"checkbox\"\r\n [checked]=\"\r\n isAllGroupSelected(\r\n config.fieldGroup || 0,\r\n group[config.fieldGroup || 0]\r\n )\r\n \"\r\n [indeterminate]=\"\r\n isGroupIndeterminate(\r\n config.fieldGroup || 0,\r\n group[config.fieldGroup || 0]\r\n )\r\n \"\r\n (click)=\"\r\n selectGroup(\r\n $event,\r\n config.fieldGroup || 0,\r\n group[config.fieldGroup || 0]\r\n )\r\n \"\r\n />\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 class=\"text-sm\"\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 @if (col.sortable) {\r\n <p-sortIcon\r\n [field]=\"'data.' + col.field\"\r\n style=\"font-size: 10px\"\r\n ></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 }\r\n </ng-template>\r\n\r\n <ng-template pTemplate=\"rowexpansion\" let-group>\r\n <tr\r\n (dblclick)=\"doubleClick($event, group)\"\r\n [ngClass]=\"{ capitalize: tableCaptalized }\"\r\n >\r\n @if (config.enableSelect) {\r\n <td [style]=\"applyStyle(group, { field: 'check-box', header: '' })\">\r\n <!--<p-tableCheckbox *ngIf=\"isVisibleCheckbox(group.data)\"-->\r\n <!-- <p-tableCheckbox\r\n [value]=\"group\"\r\n [disabled]=\"isDisabledCheckbox(group)\"\r\n (click)=\"activeItemLote(selectedItems)\"\r\n ></p-tableCheckbox>\r\n -->\r\n <input\r\n type=\"checkbox\"\r\n [value]=\"group\"\r\n [checked]=\"isSelected(group)\"\r\n (click)=\"selectItem($event, group)\"\r\n />\r\n </td>\r\n } @for (col of columns; track $index) {\r\n <ng-container>\r\n @if (!col.template) {\r\n <td\r\n class=\"rowTable\"\r\n [style]=\"\r\n applyStyle(group, col) +\r\n centralizarColunas(col) +\r\n alignColunas(col)\r\n \"\r\n [pTooltip]=\"returnTooltipRow(group, col)\"\r\n >\r\n <span class=\"p-column-title\">{{ col.header }}:</span>\r\n\r\n <span\r\n *ngIf=\"!isBooleanField(group, col); else booleanField\"\r\n [class]=\"returnRowClass(group, col)\"\r\n >\r\n @if (!isChipField(col) && !col.iconField && !isImageField(col)) {\r\n <span>\r\n @if (col.icon) {\r\n <i [class]=\"col.icon + ' mr-2'\"></i>\r\n }\r\n {{ transformValue(group, col) }}\r\n </span>\r\n } @if (isChipField(col) && !col.iconField) {\r\n <div>\r\n <span\r\n [class]=\"returnClassChip(group, col)\"\r\n [pTooltip]=\"returnTooltipIcon(group, col)\"\r\n >{{ transformValue(group, col) }}</span\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(group, 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(group, col)\"\r\n >\r\n {{ returnClassIcon(group, col) }}\r\n </i>\r\n }\r\n\r\n <ng-template #booleanField>\r\n @if (!col.iconField && !isSwitchField(col)) {\r\n <i\r\n [ngClass]=\"group[col.field] ? 'text-green-500' : 'text-red-500'\"\r\n ><span class=\"material-symbols-outlined\">\r\n {{ group[col.field] ? \"check\" : \"close\" }}\r\n </span>\r\n </i>\r\n } @if (isSwitchField(col)) {\r\n <span [class]=\"returnRowClass(group, col)\">\r\n <kv-switch\r\n (onSwitchChange)=\"onSwitchChange($event, group, col)\"\r\n [disabled]=\"col?.onlyReadField ?? true\"\r\n [switchValue]=\"transformValue(group, col)\"\r\n >\r\n </kv-switch>\r\n </span>\r\n }\r\n </ng-template>\r\n </td>\r\n } @if (col.template) {\r\n <td\r\n [style]=\"\r\n applyStyle(group, col) +\r\n centralizarColunas(col) +\r\n alignColunas(col)\r\n \"\r\n class=\"rowTable\"\r\n >\r\n <span class=\"p-column-title\">{{ col.header }}:</span>\r\n @if (getCustomTemplate(col.template.name)) {\r\n <ng-container\r\n [ngTemplateOutlet]=\"getCustomTemplate(col.template.name)\"\r\n [ngTemplateOutletContext]=\"{ $implicit: group }\"\r\n />\r\n }\r\n </td>\r\n }\r\n </ng-container>\r\n } @if (config.actions && config.actions.length > 0) {\r\n <td [style]=\"applyStyle(group, { field: 'btns-options', header: '' })\">\r\n <div class=\"flex flex-row justify-content-end w-full\">\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(group)\"\r\n > -->\r\n\r\n <span\r\n class=\"material-symbols-outlined cursor-pointer icon-more-horiz\"\r\n style=\"font-size: 25px\"\r\n (click)=\"\r\n returnRowDataActions(group);\r\n menu.toggle($event);\r\n activeItem(group)\r\n \"\r\n >\r\n more_horiz\r\n </span>\r\n\r\n <!-- </button> -->\r\n\r\n <p-tieredMenu\r\n #menu\r\n [popup]=\"true\"\r\n [model]=\"menuItems\"\r\n appendTo=\"body\"\r\n ></p-tieredMenu>\r\n </div>\r\n </td>\r\n }\r\n </tr>\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; border-radius: 10px !important\"\r\n >\r\n <p class=\"font-medium m-0\">Nenhum registro encontrado</p>\r\n </td>\r\n </tr>\r\n </ng-template>\r\n </p-table>\r\n }\r\n</div>\r\n", styles: ["@charset \"UTF-8\";.tag{width:5px;height:20px;border-radius:.25rem}input[type=checkbox]{appearance:none;-webkit-appearance:none;-moz-appearance:none;width:20px;height:20px;border:2px solid #ccc;border-radius:4px;position:relative;cursor:pointer;outline:none;background-color:#fff}input[type=checkbox]:after{content:\"\";position:absolute;left:5px;top:2px;width:5px;height:10px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg);opacity:0;transition:opacity .2s}input[type=checkbox]:checked{background-color:#007bff;border-color:#007bff}input[type=checkbox]:checked:after{opacity:1}::ng-deep .p-datatable.p-datatable-sm .p-datatable-header{padding:0rem}::ng-deep .p-datatable.p-datatable-sm .p-datatable-thead>tr>th{background-color:#eaeaea}::ng-deep .p-panel.p-panel-toggleable .p-panel-header{background-color:#eaeaea}.tr-td:hover{box-shadow:#3c40434d 0 1px 2px,#3c404326 0 2px 6px 2px;background-color:#fff;transition:color .3s,transform .3s;transform:scale(1)}.icon-more-horiz:hover,.icon-more-horiz:focus{color:#5e5e5e;transform:scale(1.2);transition:color .3s,transform .3s;background-color:#eaeaea;border-radius:50%}.btn-table{background-color:#29b92d;padding:12px}.btn-table:hover{background-color:#249a29}.btn-table:active{background-color:#1c801f}.btn-table:disabled{background-color:#29b92d}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i4.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "directive", type: i5.AutoFocus, selector: "[pAutoFocus]", inputs: ["autofocus"] }, { kind: "directive", type: i6.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "autoHide", "fitContent", "hideOnEscape", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "directive", type: i7.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading", "severity", "raised", "rounded", "text", "outlined", "size", "plain"] }, { kind: "component", type: i8.Card, selector: "p-card", inputs: ["header", "subheader", "style", "styleClass"] }, { kind: "component", type: i9.Checkbox, selector: "p-checkbox", inputs: ["value", "name", "disabled", "binary", "label", "ariaLabelledBy", "ariaLabel", "tabindex", "inputId", "style", "styleClass", "labelStyleClass", "formControl", "checkboxIcon", "readonly", "required", "autofocus", "trueValue", "falseValue", "variant"], outputs: ["onChange", "onFocus", "onBlur"] }, { kind: "directive", type: i10.InputText, selector: "[pInputText]", inputs: ["variant"] }, { kind: "component", type: i11.Panel, selector: "p-panel", inputs: ["toggleable", "header", "collapsed", "style", "styleClass", "iconPos", "expandIcon", "collapseIcon", "showHeader", "toggler", "transitionOptions"], outputs: ["collapsedChange", "onBeforeToggle", "onAfterToggle"] }, { kind: "directive", type: i12.Ripple, selector: "[pRipple]" }, { kind: "component", type: i13.TieredMenu, selector: "p-tieredMenu", inputs: ["model", "popup", "style", "styleClass", "appendTo", "autoZIndex", "baseZIndex", "autoDisplay", "showTransitionOptions", "hideTransitionOptions", "id", "ariaLabel", "ariaLabelledBy", "disabled", "tabindex"], outputs: ["onShow", "onHide"] }, { kind: "component", type: i14.Table, selector: "p-table", inputs: ["frozenColumns", "frozenValue", "style", "styleClass", "tableStyle", "tableStyleClass", "paginator", "pageLinks", "rowsPerPageOptions", "alwaysShowPaginator", "paginatorPosition", "paginatorStyleClass", "paginatorDropdownAppendTo", "paginatorDropdownScrollHeight", "currentPageReportTemplate", "showCurrentPageReport", "showJumpToPageDropdown", "showJumpToPageInput", "showFirstLastIcon", "showPageLinks", "defaultSortOrder", "sortMode", "resetPageOnSort", "selectionMode", "selectionPageOnly", "contextMenuSelection", "contextMenuSelectionMode", "dataKey", "metaKeySelection", "rowSelectable", "rowTrackBy", "lazy", "lazyLoadOnInit", "compareSelectionBy", "csvSeparator", "exportFilename", "filters", "globalFilterFields", "filterDelay", "filterLocale", "expandedRowKeys", "editingRowKeys", "rowExpandMode", "scrollable", "scrollDirection", "rowGroupMode", "scrollHeight", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "virtualScrollDelay", "frozenWidth", "responsive", "contextMenu", "resizableColumns", "columnResizeMode", "reorderableColumns", "loading", "loadingIcon", "showLoader", "rowHover", "customSort", "showInitialSortBadge", "autoLayout", "exportFunction", "exportHeader", "stateKey", "stateStorage", "editMode", "groupRowsBy", "groupRowsByOrder", "responsiveLayout", "breakpoint", "paginatorLocale", "value", "columns", "first", "rows", "totalRecords", "sortField", "sortOrder", "multiSortMeta", "selection", "selectAll", "virtualRowHeight"], outputs: ["contextMenuSelectionChange", "selectAllChange", "selectionChange", "onRowSelect", "onRowUnselect", "onPage", "onSort", "onFilter", "onLazyLoad", "onRowExpand", "onRowCollapse", "onContextMenuSelect", "onColResize", "onColReorder", "onRowReorder", "onEditInit", "onEditComplete", "onEditCancel", "onHeaderCheckboxToggle", "sortFunction", "firstChange", "rowsChange", "onStateSave", "onStateRestore"] }, { kind: "directive", type: i14.SortableColumn, selector: "[pSortableColumn]", inputs: ["pSortableColumn", "pSortableColumnDisabled"] }, { kind: "directive", type: i14.RowToggler, selector: "[pRowToggler]", inputs: ["pRowToggler", "pRowTogglerDisabled"] }, { kind: "component", type: i14.SortIcon, selector: "p-sortIcon", inputs: ["field"] }, { kind: "directive", type: i15.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i15.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i16.KvSwitchComponent, selector: "kv-switch", inputs: ["readonly", "switchValue"], outputs: ["onSwitchChange"] }] }); }
|
|
425
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: KvTableExpandableComponent, selector: "kv-table-expandable", inputs: { _templates: ["templates", "_templates"], setConfig: ["config", "setConfig"], filtrosAvancados: "filtrosAvancados", dataSource: "dataSource", selectedItems: "selectedItems", tableCaptalized: "tableCaptalized", applyStyle: "applyStyle", tableSize: "tableSize", paginator: "paginator", rows: "rows", rowsPerPageOptions: "rowsPerPageOptions", totalRecords: "totalRecords", pageLinksOptions: "pageLinksOptions", responsiveLayout: "responsiveLayout", isTableScrollable: "isTableScrollable", scrollHeight: "scrollHeight", rowTrackBy: "rowTrackBy", showFirstLastIcon: "showFirstLastIcon" }, outputs: { filterField: "filterField", onActiveItem: "onActiveItem", onActiveItemLote: "onActiveItemLote", doubleClickEvent: "doubleClickEvent", onSwitchTableChange: "onSwitchTableChange", onPaginate: "onPaginate", onSelectionChange: "onSelectionChange" }, ngImport: i0, template: "<div>\r\n @if (filtrosAvancados) {\r\n <p-panel\r\n header=\"Filtros avan\u00E7ados\"\r\n [toggleable]=\"true\"\r\n [collapsed]=\"true\"\r\n (collapsedChange)=\"collapsed = !collapsed\"\r\n [style]=\"{ 'margin-bottom': '2px' }\"\r\n >\r\n <ng-template pTemplate=\"headericons\">\r\n @if (!collapsed) {\r\n <i class=\"pi pi-filter\"></i>\r\n }\r\n <!-- \u00CDcone quando o painel est\u00E1 aberto -->\r\n @if (collapsed) {\r\n <i class=\"pi pi-minus\"></i>\r\n }\r\n <!-- \u00CDcone quando o painel est\u00E1 fechado -->\r\n </ng-template>\r\n <ng-content></ng-content>\r\n </p-panel>\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 rowGroupMode=\"subheader\"\r\n [groupRowsBy]=\"config.fieldGroup\"\r\n [columns]=\"config.columns\"\r\n [lazy]=\"config.lazy\"\r\n (onLazyLoad)=\"paginate($event)\"\r\n (selectionChange)=\"selectionChange($event)\"\r\n (onSort)=\"onSort($event)\"\r\n [sortField]=\"config.fieldGroup\"\r\n sortMode=\"single\"\r\n [dataKey]=\"config.fieldGroup\"\r\n [expandedRowKeys]=\"expandedRows\"\r\n [paginator]=\"paginator\"\r\n [rows]=\"rows\"\r\n [rowsPerPageOptions]=\"rowsPerPageOptions\"\r\n [totalRecords]=\"totalRecords\"\r\n [globalFilterFields]=\"globalFilterFields\"\r\n [showCurrentPageReport]=\"true\"\r\n currentPageReportTemplate=\"{first} - {last} de {totalRecords}\"\r\n [rowHover]=\"true\"\r\n [pageLinks]=\"pageLinksOptions\"\r\n [responsive]=\"true\"\r\n [responsiveLayout]=\"responsiveLayout ? 'stack' : ''\"\r\n [scrollable]=\"isTableScrollable\"\r\n [scrollHeight]=\"scrollHeight\"\r\n [rowTrackBy]=\"rowTrackBy\"\r\n [showFirstLastIcon]=\"showFirstLastIcon\"\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 align-items-center grid formgrid p-fluid col-12 p-0 m-0\"\r\n [style.background-color]=\"'#EAEAEA'\"\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 tamanhoTela < 768 ? 'col-10' : 'col-12'\r\n }} mt-1 mb-2 \"\r\n >\r\n @if (config.enableFilter) {\r\n <span class=\"p-input-icon-left\">\r\n <i class=\"pi pi-search\"></i>\r\n\r\n <input\r\n pInputText\r\n pAutoFocus\r\n [autofocus]=\"true\"\r\n type=\"text\"\r\n (input)=\"onGlobalFilter(dt, $event)\"\r\n placeholder=\"Pesquisar...\"\r\n class=\"h-2rem\"\r\n />\r\n </span>\r\n }\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\"\r\n (click)=\"onClickEvent($event)\"\r\n > -->\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>\r\n @for (col of columns; track col) {\r\n <div class=\"flex flex-column text-medium w-15rem\">\r\n {{ checkMenuFiltro(col) }}\r\n @if (!dinamicDisableColumn(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 ></p-checkbox>\r\n }\r\n </div>\r\n }\r\n </p-card>\r\n </div>\r\n </div>\r\n\r\n <div class=\"flex flex-row col-1 justify-content-end p-0\">\r\n @for (action of config.actionsLote; track i; let i = $index) {\r\n <div class=\"flex flex-row gap-2 btns-options\">\r\n @if ((selectedItems.length > 0 || action.showAcoesLote) &&\r\n (getOrExecute(action.visible, selectedItems) ?? true)) {\r\n <button\r\n pButton\r\n class=\"w-2rem h-2rem flex align-items-center justify-content-center border-none mr-2 btn-table\"\r\n (click)=\"action?.command(); activeItemLote(selectedItems)\"\r\n [pTooltip]=\"getOrExecute(action.tooltip, selectedItems)\"\r\n [tooltipPosition]=\"\r\n (getOrExecute(action.tooltip, selectedItems)?.length ??\r\n 0 > 7) &&\r\n config.actionsLote &&\r\n i == config.actionsLote.length - 1\r\n ? 'left'\r\n : 'bottom'\r\n \"\r\n [disabled]=\"getOrExecute(action.disabled, selectedItems)\"\r\n >\r\n <span\r\n class=\"material-symbols-outlined md-22\"\r\n style=\"color: white\"\r\n >\r\n {{ getOrExecute(action.icon, selectedItems) }}\r\n </span>\r\n </button>\r\n }\r\n </div>\r\n }\r\n </div>\r\n </div>\r\n </ng-template>\r\n } @if (config.enableSelect){\r\n <ng-template pTemplate=\"header\">\r\n <tr>\r\n <th colspan=\"12\">\r\n <div class=\"w-full\">\r\n <!-- <p-tableHeaderCheckbox\r\n (click)=\"activeItemLote(selectedItems)\"\r\n ></p-tableHeaderCheckbox> -->\r\n <input\r\n type=\"checkbox\"\r\n [checked]=\"isAllSelected()\"\r\n [indeterminate]=\"isAllIndeterminate()\"\r\n (click)=\"selectAll($event)\"\r\n />\r\n </div>\r\n </th>\r\n </tr>\r\n </ng-template>\r\n }\r\n\r\n <ng-template\r\n pTemplate=\"groupheader\"\r\n let-group\r\n let-rowIndex=\"rowIndex\"\r\n let-expanded=\"expanded\"\r\n >\r\n <tr>\r\n <td colspan=\"12\" class=\"groupheader\">\r\n <div class=\"flex flex-row align-items-center w-full\">\r\n <button\r\n type=\"button\"\r\n pButton\r\n pRipple\r\n [pRowToggler]=\"group\"\r\n class=\"p-button-text p-button-rounded p-button-plain mr-2\"\r\n [icon]=\"expanded ? 'pi pi-chevron-down' : 'pi pi-chevron-right'\"\r\n ></button>\r\n @if (config.fieldGroupColorFunction){\r\n <div\r\n class=\"tag\"\r\n [style.background-color]=\"config.fieldGroupColorFunction(group)\"\r\n ></div>\r\n }\r\n <span class=\"font-bold ml-2\">{{\r\n group[config.fieldGroup || 0]\r\n }}</span>\r\n </div>\r\n </td>\r\n </tr>\r\n @if(expanded){\r\n <tr style=\"height: 40px\">\r\n @if (config.enableSelect) {\r\n <th class=\"flex align-items-left pl-2\">\r\n <!-- <p-tableHeaderCheckbox\r\n (click)=\"activeItemLote(selectedItems)\"\r\n ></p-tableHeaderCheckbox> -->\r\n <input\r\n type=\"checkbox\"\r\n [checked]=\"\r\n isAllGroupSelected(\r\n config.fieldGroup || 0,\r\n group[config.fieldGroup || 0]\r\n )\r\n \"\r\n [indeterminate]=\"\r\n isGroupIndeterminate(\r\n config.fieldGroup || 0,\r\n group[config.fieldGroup || 0]\r\n )\r\n \"\r\n (click)=\"\r\n selectGroup(\r\n $event,\r\n config.fieldGroup || 0,\r\n group[config.fieldGroup || 0]\r\n )\r\n \"\r\n />\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 class=\"text-sm\"\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 @if (col.sortable) {\r\n <p-sortIcon\r\n [field]=\"'data.' + col.field\"\r\n style=\"font-size: 10px\"\r\n ></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 }\r\n </ng-template>\r\n\r\n <ng-template pTemplate=\"rowexpansion\" let-group>\r\n <tr\r\n (dblclick)=\"doubleClick($event, group)\"\r\n [ngClass]=\"{ capitalize: tableCaptalized }\"\r\n >\r\n @if (config.enableSelect) {\r\n <td [style]=\"applyStyle(group, { field: 'check-box', header: '' })\">\r\n <!--<p-tableCheckbox *ngIf=\"isVisibleCheckbox(group.data)\"-->\r\n <!-- <p-tableCheckbox\r\n [value]=\"group\"\r\n [disabled]=\"isDisabledCheckbox(group)\"\r\n (click)=\"activeItemLote(selectedItems)\"\r\n ></p-tableCheckbox>\r\n -->\r\n <input\r\n type=\"checkbox\"\r\n [value]=\"group\"\r\n [checked]=\"isSelected(group)\"\r\n (click)=\"selectItem($event, group)\"\r\n />\r\n </td>\r\n } @for (col of columns; track $index) {\r\n <ng-container>\r\n @if (!col.template) {\r\n <td\r\n class=\"rowTable\"\r\n [style]=\"\r\n applyStyle(group, col) +\r\n centralizarColunas(col) +\r\n alignColunas(col)\r\n \"\r\n [pTooltip]=\"returnTooltipRow(group, col)\"\r\n >\r\n <span class=\"p-column-title\">{{ col.header }}:</span>\r\n\r\n <span\r\n *ngIf=\"!isBooleanField(group, col); else booleanField\"\r\n [class]=\"returnRowClass(group, col)\"\r\n >\r\n @if (!isChipField(col) && !col.iconField && !isImageField(col)) {\r\n <span>\r\n @if (col.icon) {\r\n <i [class]=\"col.icon + ' mr-2'\"></i>\r\n }\r\n {{ transformValue(group, col) }}\r\n </span>\r\n } @if (isChipField(col) && !col.iconField) {\r\n <div>\r\n <span\r\n [class]=\"returnClassChip(group, col)\"\r\n [pTooltip]=\"returnTooltipIcon(group, col)\"\r\n >{{ transformValue(group, col) }}</span\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(group, 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(group, col)\"\r\n >\r\n {{ returnClassIcon(group, col) }}\r\n </i>\r\n }\r\n\r\n <ng-template #booleanField>\r\n @if (!col.iconField && !isSwitchField(col)) {\r\n <i\r\n [ngClass]=\"group[col.field] ? 'text-green-500' : 'text-red-500'\"\r\n ><span class=\"material-symbols-outlined\">\r\n {{ group[col.field] ? \"check\" : \"close\" }}\r\n </span>\r\n </i>\r\n } @if (isSwitchField(col)) {\r\n <span [class]=\"returnRowClass(group, col)\">\r\n <kv-switch\r\n (onSwitchChange)=\"onSwitchChange($event, group, col)\"\r\n [disabled]=\"col?.onlyReadField ?? true\"\r\n [switchValue]=\"transformValue(group, col)\"\r\n >\r\n </kv-switch>\r\n </span>\r\n }\r\n </ng-template>\r\n </td>\r\n } @if (col.template) {\r\n <td\r\n [style]=\"\r\n applyStyle(group, col) +\r\n centralizarColunas(col) +\r\n alignColunas(col)\r\n \"\r\n class=\"rowTable\"\r\n >\r\n <span class=\"p-column-title\">{{ col.header }}:</span>\r\n @if (getCustomTemplate(col.template.name)) {\r\n <ng-container\r\n [ngTemplateOutlet]=\"getCustomTemplate(col.template.name)\"\r\n [ngTemplateOutletContext]=\"{ $implicit: group }\"\r\n />\r\n }\r\n </td>\r\n }\r\n </ng-container>\r\n } @if (config.actions && config.actions.length > 0) {\r\n <td [style]=\"applyStyle(group, { field: 'btns-options', header: '' })\">\r\n <div class=\"flex flex-row justify-content-end w-full\">\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(group)\"\r\n > -->\r\n\r\n <span\r\n class=\"material-symbols-outlined cursor-pointer icon-more-horiz\"\r\n style=\"font-size: 25px\"\r\n (click)=\"\r\n returnRowDataActions(group);\r\n menu.toggle($event);\r\n activeItem(group)\r\n \"\r\n >\r\n more_horiz\r\n </span>\r\n\r\n <!-- </button> -->\r\n\r\n <p-tieredMenu\r\n #menu\r\n [popup]=\"true\"\r\n [model]=\"menuItems\"\r\n appendTo=\"body\"\r\n ></p-tieredMenu>\r\n </div>\r\n </td>\r\n }\r\n </tr>\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; border-radius: 10px !important\"\r\n >\r\n <p class=\"font-medium m-0\">Nenhum registro encontrado</p>\r\n </td>\r\n </tr>\r\n </ng-template>\r\n </p-table>\r\n }\r\n</div>\r\n", styles: ["@charset \"UTF-8\";.tag{width:5px;height:20px;border-radius:.25rem}input[type=checkbox]{appearance:none;-webkit-appearance:none;-moz-appearance:none;width:20px;height:20px;border:2px solid #ccc;border-radius:4px;position:relative;cursor:pointer;outline:none;background-color:#fff}input[type=checkbox]:after{content:\"\";position:absolute;left:5px;top:2px;width:5px;height:10px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg);opacity:0;transition:opacity .2s}input[type=checkbox]:checked{border-color:#004172;background:#004172}input[type=checkbox]:checked:hover{background-color:#002542}input[type=checkbox]:checked:active{background-color:#002542}input[type=checkbox]:checked:disabled{background-color:#002542;opacity:.4;cursor:auto}input[type=checkbox]:checked:after{opacity:1}::ng-deep .p-datatable.p-datatable-sm .p-datatable-header{padding:0rem}::ng-deep .p-datatable.p-datatable-sm .p-datatable-thead>tr>th{background-color:#eaeaea}::ng-deep .p-panel.p-panel-toggleable .p-panel-header{background-color:#eaeaea}.tr-td:hover{box-shadow:#3c40434d 0 1px 2px,#3c404326 0 2px 6px 2px;background-color:#fff;transition:color .3s,transform .3s;transform:scale(1)}.icon-more-horiz:hover,.icon-more-horiz:focus{color:#5e5e5e;transform:scale(1.2);transition:color .3s,transform .3s;background-color:#eaeaea;border-radius:50%}.btn-table{background-color:#29b92d;padding:12px}.btn-table:hover{background-color:#249a29}.btn-table:active{background-color:#1c801f}.btn-table:disabled{background-color:#29b92d}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i4.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "directive", type: i5.AutoFocus, selector: "[pAutoFocus]", inputs: ["autofocus"] }, { kind: "directive", type: i6.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "autoHide", "fitContent", "hideOnEscape", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "directive", type: i7.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading", "severity", "raised", "rounded", "text", "outlined", "size", "plain"] }, { kind: "component", type: i8.Card, selector: "p-card", inputs: ["header", "subheader", "style", "styleClass"] }, { kind: "component", type: i9.Checkbox, selector: "p-checkbox", inputs: ["value", "name", "disabled", "binary", "label", "ariaLabelledBy", "ariaLabel", "tabindex", "inputId", "style", "styleClass", "labelStyleClass", "formControl", "checkboxIcon", "readonly", "required", "autofocus", "trueValue", "falseValue", "variant"], outputs: ["onChange", "onFocus", "onBlur"] }, { kind: "directive", type: i10.InputText, selector: "[pInputText]", inputs: ["variant"] }, { kind: "component", type: i11.Panel, selector: "p-panel", inputs: ["toggleable", "header", "collapsed", "style", "styleClass", "iconPos", "expandIcon", "collapseIcon", "showHeader", "toggler", "transitionOptions"], outputs: ["collapsedChange", "onBeforeToggle", "onAfterToggle"] }, { kind: "directive", type: i12.Ripple, selector: "[pRipple]" }, { kind: "component", type: i13.TieredMenu, selector: "p-tieredMenu", inputs: ["model", "popup", "style", "styleClass", "appendTo", "autoZIndex", "baseZIndex", "autoDisplay", "showTransitionOptions", "hideTransitionOptions", "id", "ariaLabel", "ariaLabelledBy", "disabled", "tabindex"], outputs: ["onShow", "onHide"] }, { kind: "component", type: i14.Table, selector: "p-table", inputs: ["frozenColumns", "frozenValue", "style", "styleClass", "tableStyle", "tableStyleClass", "paginator", "pageLinks", "rowsPerPageOptions", "alwaysShowPaginator", "paginatorPosition", "paginatorStyleClass", "paginatorDropdownAppendTo", "paginatorDropdownScrollHeight", "currentPageReportTemplate", "showCurrentPageReport", "showJumpToPageDropdown", "showJumpToPageInput", "showFirstLastIcon", "showPageLinks", "defaultSortOrder", "sortMode", "resetPageOnSort", "selectionMode", "selectionPageOnly", "contextMenuSelection", "contextMenuSelectionMode", "dataKey", "metaKeySelection", "rowSelectable", "rowTrackBy", "lazy", "lazyLoadOnInit", "compareSelectionBy", "csvSeparator", "exportFilename", "filters", "globalFilterFields", "filterDelay", "filterLocale", "expandedRowKeys", "editingRowKeys", "rowExpandMode", "scrollable", "scrollDirection", "rowGroupMode", "scrollHeight", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "virtualScrollDelay", "frozenWidth", "responsive", "contextMenu", "resizableColumns", "columnResizeMode", "reorderableColumns", "loading", "loadingIcon", "showLoader", "rowHover", "customSort", "showInitialSortBadge", "autoLayout", "exportFunction", "exportHeader", "stateKey", "stateStorage", "editMode", "groupRowsBy", "groupRowsByOrder", "responsiveLayout", "breakpoint", "paginatorLocale", "value", "columns", "first", "rows", "totalRecords", "sortField", "sortOrder", "multiSortMeta", "selection", "selectAll", "virtualRowHeight"], outputs: ["contextMenuSelectionChange", "selectAllChange", "selectionChange", "onRowSelect", "onRowUnselect", "onPage", "onSort", "onFilter", "onLazyLoad", "onRowExpand", "onRowCollapse", "onContextMenuSelect", "onColResize", "onColReorder", "onRowReorder", "onEditInit", "onEditComplete", "onEditCancel", "onHeaderCheckboxToggle", "sortFunction", "firstChange", "rowsChange", "onStateSave", "onStateRestore"] }, { kind: "directive", type: i14.SortableColumn, selector: "[pSortableColumn]", inputs: ["pSortableColumn", "pSortableColumnDisabled"] }, { kind: "directive", type: i14.RowToggler, selector: "[pRowToggler]", inputs: ["pRowToggler", "pRowTogglerDisabled"] }, { kind: "component", type: i14.SortIcon, selector: "p-sortIcon", inputs: ["field"] }, { kind: "directive", type: i15.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i15.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i16.KvSwitchComponent, selector: "kv-switch", inputs: ["readonly", "switchValue"], outputs: ["onSwitchChange"] }] }); }
|
|
426
426
|
}
|
|
427
427
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvTableExpandableComponent, decorators: [{
|
|
428
428
|
type: Component,
|
|
429
|
-
args: [{ selector: 'kv-table-expandable', template: "<div>\r\n @if (filtrosAvancados) {\r\n <p-panel\r\n header=\"Filtros avan\u00E7ados\"\r\n [toggleable]=\"true\"\r\n [collapsed]=\"true\"\r\n (collapsedChange)=\"collapsed = !collapsed\"\r\n [style]=\"{ 'margin-bottom': '2px' }\"\r\n >\r\n <ng-template pTemplate=\"headericons\">\r\n @if (!collapsed) {\r\n <i class=\"pi pi-filter\"></i>\r\n }\r\n <!-- \u00CDcone quando o painel est\u00E1 aberto -->\r\n @if (collapsed) {\r\n <i class=\"pi pi-minus\"></i>\r\n }\r\n <!-- \u00CDcone quando o painel est\u00E1 fechado -->\r\n </ng-template>\r\n <ng-content></ng-content>\r\n </p-panel>\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 rowGroupMode=\"subheader\"\r\n [groupRowsBy]=\"config.fieldGroup\"\r\n [columns]=\"config.columns\"\r\n [lazy]=\"config.lazy\"\r\n (onLazyLoad)=\"paginate($event)\"\r\n (selectionChange)=\"selectionChange($event)\"\r\n (onSort)=\"onSort($event)\"\r\n [sortField]=\"config.fieldGroup\"\r\n sortMode=\"single\"\r\n [dataKey]=\"config.fieldGroup\"\r\n [expandedRowKeys]=\"expandedRows\"\r\n [paginator]=\"paginator\"\r\n [rows]=\"rows\"\r\n [rowsPerPageOptions]=\"rowsPerPageOptions\"\r\n [totalRecords]=\"totalRecords\"\r\n [globalFilterFields]=\"globalFilterFields\"\r\n [showCurrentPageReport]=\"true\"\r\n currentPageReportTemplate=\"{first} - {last} de {totalRecords}\"\r\n [rowHover]=\"true\"\r\n [pageLinks]=\"pageLinksOptions\"\r\n [responsive]=\"true\"\r\n [responsiveLayout]=\"responsiveLayout ? 'stack' : ''\"\r\n [scrollable]=\"isTableScrollable\"\r\n [scrollHeight]=\"scrollHeight\"\r\n [rowTrackBy]=\"rowTrackBy\"\r\n [showFirstLastIcon]=\"showFirstLastIcon\"\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 align-items-center grid formgrid p-fluid col-12 p-0 m-0\"\r\n [style.background-color]=\"'#EAEAEA'\"\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 tamanhoTela < 768 ? 'col-10' : 'col-12'\r\n }} mt-1 mb-2 \"\r\n >\r\n @if (config.enableFilter) {\r\n <span class=\"p-input-icon-left\">\r\n <i class=\"pi pi-search\"></i>\r\n\r\n <input\r\n pInputText\r\n pAutoFocus\r\n [autofocus]=\"true\"\r\n type=\"text\"\r\n (input)=\"onGlobalFilter(dt, $event)\"\r\n placeholder=\"Pesquisar...\"\r\n class=\"h-2rem\"\r\n />\r\n </span>\r\n }\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\"\r\n (click)=\"onClickEvent($event)\"\r\n > -->\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>\r\n @for (col of columns; track col) {\r\n <div class=\"flex flex-column text-medium w-15rem\">\r\n {{ checkMenuFiltro(col) }}\r\n @if (!dinamicDisableColumn(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 ></p-checkbox>\r\n }\r\n </div>\r\n }\r\n </p-card>\r\n </div>\r\n </div>\r\n\r\n <div class=\"flex flex-row col-1 justify-content-end p-0\">\r\n @for (action of config.actionsLote; track i; let i = $index) {\r\n <div class=\"flex flex-row gap-2 btns-options\">\r\n @if ((selectedItems.length > 0 || action.showAcoesLote) &&\r\n (getOrExecute(action.visible, selectedItems) ?? true)) {\r\n <button\r\n pButton\r\n class=\"w-2rem h-2rem flex align-items-center justify-content-center border-none mr-2 btn-table\"\r\n (click)=\"action?.command(); activeItemLote(selectedItems)\"\r\n [pTooltip]=\"getOrExecute(action.tooltip, selectedItems)\"\r\n [tooltipPosition]=\"\r\n (getOrExecute(action.tooltip, selectedItems)?.length ??\r\n 0 > 7) &&\r\n config.actionsLote &&\r\n i == config.actionsLote.length - 1\r\n ? 'left'\r\n : 'bottom'\r\n \"\r\n [disabled]=\"getOrExecute(action.disabled, selectedItems)\"\r\n >\r\n <span\r\n class=\"material-symbols-outlined md-22\"\r\n style=\"color: white\"\r\n >\r\n {{ getOrExecute(action.icon, selectedItems) }}\r\n </span>\r\n </button>\r\n }\r\n </div>\r\n }\r\n </div>\r\n </div>\r\n </ng-template>\r\n } @if (config.enableSelect){\r\n <ng-template pTemplate=\"header\">\r\n <tr>\r\n <th colspan=\"12\">\r\n <div class=\"w-full\">\r\n <!-- <p-tableHeaderCheckbox\r\n (click)=\"activeItemLote(selectedItems)\"\r\n ></p-tableHeaderCheckbox> -->\r\n <input\r\n type=\"checkbox\"\r\n [checked]=\"isAllSelected()\"\r\n [indeterminate]=\"isAllIndeterminate()\"\r\n (click)=\"selectAll($event)\"\r\n />\r\n </div>\r\n </th>\r\n </tr>\r\n </ng-template>\r\n }\r\n\r\n <ng-template\r\n pTemplate=\"groupheader\"\r\n let-group\r\n let-rowIndex=\"rowIndex\"\r\n let-expanded=\"expanded\"\r\n >\r\n <tr>\r\n <td colspan=\"12\" class=\"groupheader\">\r\n <div class=\"flex flex-row align-items-center w-full\">\r\n <button\r\n type=\"button\"\r\n pButton\r\n pRipple\r\n [pRowToggler]=\"group\"\r\n class=\"p-button-text p-button-rounded p-button-plain mr-2\"\r\n [icon]=\"expanded ? 'pi pi-chevron-down' : 'pi pi-chevron-right'\"\r\n ></button>\r\n @if (config.fieldGroupColorFunction){\r\n <div\r\n class=\"tag\"\r\n [style.background-color]=\"config.fieldGroupColorFunction(group)\"\r\n ></div>\r\n }\r\n <span class=\"font-bold ml-2\">{{\r\n group[config.fieldGroup || 0]\r\n }}</span>\r\n </div>\r\n </td>\r\n </tr>\r\n @if(expanded){\r\n <tr style=\"height: 40px\">\r\n @if (config.enableSelect) {\r\n <th class=\"flex align-items-left pl-2\">\r\n <!-- <p-tableHeaderCheckbox\r\n (click)=\"activeItemLote(selectedItems)\"\r\n ></p-tableHeaderCheckbox> -->\r\n <input\r\n type=\"checkbox\"\r\n [checked]=\"\r\n isAllGroupSelected(\r\n config.fieldGroup || 0,\r\n group[config.fieldGroup || 0]\r\n )\r\n \"\r\n [indeterminate]=\"\r\n isGroupIndeterminate(\r\n config.fieldGroup || 0,\r\n group[config.fieldGroup || 0]\r\n )\r\n \"\r\n (click)=\"\r\n selectGroup(\r\n $event,\r\n config.fieldGroup || 0,\r\n group[config.fieldGroup || 0]\r\n )\r\n \"\r\n />\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 class=\"text-sm\"\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 @if (col.sortable) {\r\n <p-sortIcon\r\n [field]=\"'data.' + col.field\"\r\n style=\"font-size: 10px\"\r\n ></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 }\r\n </ng-template>\r\n\r\n <ng-template pTemplate=\"rowexpansion\" let-group>\r\n <tr\r\n (dblclick)=\"doubleClick($event, group)\"\r\n [ngClass]=\"{ capitalize: tableCaptalized }\"\r\n >\r\n @if (config.enableSelect) {\r\n <td [style]=\"applyStyle(group, { field: 'check-box', header: '' })\">\r\n <!--<p-tableCheckbox *ngIf=\"isVisibleCheckbox(group.data)\"-->\r\n <!-- <p-tableCheckbox\r\n [value]=\"group\"\r\n [disabled]=\"isDisabledCheckbox(group)\"\r\n (click)=\"activeItemLote(selectedItems)\"\r\n ></p-tableCheckbox>\r\n -->\r\n <input\r\n type=\"checkbox\"\r\n [value]=\"group\"\r\n [checked]=\"isSelected(group)\"\r\n (click)=\"selectItem($event, group)\"\r\n />\r\n </td>\r\n } @for (col of columns; track $index) {\r\n <ng-container>\r\n @if (!col.template) {\r\n <td\r\n class=\"rowTable\"\r\n [style]=\"\r\n applyStyle(group, col) +\r\n centralizarColunas(col) +\r\n alignColunas(col)\r\n \"\r\n [pTooltip]=\"returnTooltipRow(group, col)\"\r\n >\r\n <span class=\"p-column-title\">{{ col.header }}:</span>\r\n\r\n <span\r\n *ngIf=\"!isBooleanField(group, col); else booleanField\"\r\n [class]=\"returnRowClass(group, col)\"\r\n >\r\n @if (!isChipField(col) && !col.iconField && !isImageField(col)) {\r\n <span>\r\n @if (col.icon) {\r\n <i [class]=\"col.icon + ' mr-2'\"></i>\r\n }\r\n {{ transformValue(group, col) }}\r\n </span>\r\n } @if (isChipField(col) && !col.iconField) {\r\n <div>\r\n <span\r\n [class]=\"returnClassChip(group, col)\"\r\n [pTooltip]=\"returnTooltipIcon(group, col)\"\r\n >{{ transformValue(group, col) }}</span\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(group, 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(group, col)\"\r\n >\r\n {{ returnClassIcon(group, col) }}\r\n </i>\r\n }\r\n\r\n <ng-template #booleanField>\r\n @if (!col.iconField && !isSwitchField(col)) {\r\n <i\r\n [ngClass]=\"group[col.field] ? 'text-green-500' : 'text-red-500'\"\r\n ><span class=\"material-symbols-outlined\">\r\n {{ group[col.field] ? \"check\" : \"close\" }}\r\n </span>\r\n </i>\r\n } @if (isSwitchField(col)) {\r\n <span [class]=\"returnRowClass(group, col)\">\r\n <kv-switch\r\n (onSwitchChange)=\"onSwitchChange($event, group, col)\"\r\n [disabled]=\"col?.onlyReadField ?? true\"\r\n [switchValue]=\"transformValue(group, col)\"\r\n >\r\n </kv-switch>\r\n </span>\r\n }\r\n </ng-template>\r\n </td>\r\n } @if (col.template) {\r\n <td\r\n [style]=\"\r\n applyStyle(group, col) +\r\n centralizarColunas(col) +\r\n alignColunas(col)\r\n \"\r\n class=\"rowTable\"\r\n >\r\n <span class=\"p-column-title\">{{ col.header }}:</span>\r\n @if (getCustomTemplate(col.template.name)) {\r\n <ng-container\r\n [ngTemplateOutlet]=\"getCustomTemplate(col.template.name)\"\r\n [ngTemplateOutletContext]=\"{ $implicit: group }\"\r\n />\r\n }\r\n </td>\r\n }\r\n </ng-container>\r\n } @if (config.actions && config.actions.length > 0) {\r\n <td [style]=\"applyStyle(group, { field: 'btns-options', header: '' })\">\r\n <div class=\"flex flex-row justify-content-end w-full\">\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(group)\"\r\n > -->\r\n\r\n <span\r\n class=\"material-symbols-outlined cursor-pointer icon-more-horiz\"\r\n style=\"font-size: 25px\"\r\n (click)=\"\r\n returnRowDataActions(group);\r\n menu.toggle($event);\r\n activeItem(group)\r\n \"\r\n >\r\n more_horiz\r\n </span>\r\n\r\n <!-- </button> -->\r\n\r\n <p-tieredMenu\r\n #menu\r\n [popup]=\"true\"\r\n [model]=\"menuItems\"\r\n appendTo=\"body\"\r\n ></p-tieredMenu>\r\n </div>\r\n </td>\r\n }\r\n </tr>\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; border-radius: 10px !important\"\r\n >\r\n <p class=\"font-medium m-0\">Nenhum registro encontrado</p>\r\n </td>\r\n </tr>\r\n </ng-template>\r\n </p-table>\r\n }\r\n</div>\r\n", styles: ["@charset \"UTF-8\";.tag{width:5px;height:20px;border-radius:.25rem}input[type=checkbox]{appearance:none;-webkit-appearance:none;-moz-appearance:none;width:20px;height:20px;border:2px solid #ccc;border-radius:4px;position:relative;cursor:pointer;outline:none;background-color:#fff}input[type=checkbox]:after{content:\"\";position:absolute;left:5px;top:2px;width:5px;height:10px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg);opacity:0;transition:opacity .2s}input[type=checkbox]:checked{background-color:#007bff;border-color:#007bff}input[type=checkbox]:checked:after{opacity:1}::ng-deep .p-datatable.p-datatable-sm .p-datatable-header{padding:0rem}::ng-deep .p-datatable.p-datatable-sm .p-datatable-thead>tr>th{background-color:#eaeaea}::ng-deep .p-panel.p-panel-toggleable .p-panel-header{background-color:#eaeaea}.tr-td:hover{box-shadow:#3c40434d 0 1px 2px,#3c404326 0 2px 6px 2px;background-color:#fff;transition:color .3s,transform .3s;transform:scale(1)}.icon-more-horiz:hover,.icon-more-horiz:focus{color:#5e5e5e;transform:scale(1.2);transition:color .3s,transform .3s;background-color:#eaeaea;border-radius:50%}.btn-table{background-color:#29b92d;padding:12px}.btn-table:hover{background-color:#249a29}.btn-table:active{background-color:#1c801f}.btn-table:disabled{background-color:#29b92d}\n"] }]
|
|
429
|
+
args: [{ selector: 'kv-table-expandable', template: "<div>\r\n @if (filtrosAvancados) {\r\n <p-panel\r\n header=\"Filtros avan\u00E7ados\"\r\n [toggleable]=\"true\"\r\n [collapsed]=\"true\"\r\n (collapsedChange)=\"collapsed = !collapsed\"\r\n [style]=\"{ 'margin-bottom': '2px' }\"\r\n >\r\n <ng-template pTemplate=\"headericons\">\r\n @if (!collapsed) {\r\n <i class=\"pi pi-filter\"></i>\r\n }\r\n <!-- \u00CDcone quando o painel est\u00E1 aberto -->\r\n @if (collapsed) {\r\n <i class=\"pi pi-minus\"></i>\r\n }\r\n <!-- \u00CDcone quando o painel est\u00E1 fechado -->\r\n </ng-template>\r\n <ng-content></ng-content>\r\n </p-panel>\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 rowGroupMode=\"subheader\"\r\n [groupRowsBy]=\"config.fieldGroup\"\r\n [columns]=\"config.columns\"\r\n [lazy]=\"config.lazy\"\r\n (onLazyLoad)=\"paginate($event)\"\r\n (selectionChange)=\"selectionChange($event)\"\r\n (onSort)=\"onSort($event)\"\r\n [sortField]=\"config.fieldGroup\"\r\n sortMode=\"single\"\r\n [dataKey]=\"config.fieldGroup\"\r\n [expandedRowKeys]=\"expandedRows\"\r\n [paginator]=\"paginator\"\r\n [rows]=\"rows\"\r\n [rowsPerPageOptions]=\"rowsPerPageOptions\"\r\n [totalRecords]=\"totalRecords\"\r\n [globalFilterFields]=\"globalFilterFields\"\r\n [showCurrentPageReport]=\"true\"\r\n currentPageReportTemplate=\"{first} - {last} de {totalRecords}\"\r\n [rowHover]=\"true\"\r\n [pageLinks]=\"pageLinksOptions\"\r\n [responsive]=\"true\"\r\n [responsiveLayout]=\"responsiveLayout ? 'stack' : ''\"\r\n [scrollable]=\"isTableScrollable\"\r\n [scrollHeight]=\"scrollHeight\"\r\n [rowTrackBy]=\"rowTrackBy\"\r\n [showFirstLastIcon]=\"showFirstLastIcon\"\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 align-items-center grid formgrid p-fluid col-12 p-0 m-0\"\r\n [style.background-color]=\"'#EAEAEA'\"\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 tamanhoTela < 768 ? 'col-10' : 'col-12'\r\n }} mt-1 mb-2 \"\r\n >\r\n @if (config.enableFilter) {\r\n <span class=\"p-input-icon-left\">\r\n <i class=\"pi pi-search\"></i>\r\n\r\n <input\r\n pInputText\r\n pAutoFocus\r\n [autofocus]=\"true\"\r\n type=\"text\"\r\n (input)=\"onGlobalFilter(dt, $event)\"\r\n placeholder=\"Pesquisar...\"\r\n class=\"h-2rem\"\r\n />\r\n </span>\r\n }\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\"\r\n (click)=\"onClickEvent($event)\"\r\n > -->\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>\r\n @for (col of columns; track col) {\r\n <div class=\"flex flex-column text-medium w-15rem\">\r\n {{ checkMenuFiltro(col) }}\r\n @if (!dinamicDisableColumn(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 ></p-checkbox>\r\n }\r\n </div>\r\n }\r\n </p-card>\r\n </div>\r\n </div>\r\n\r\n <div class=\"flex flex-row col-1 justify-content-end p-0\">\r\n @for (action of config.actionsLote; track i; let i = $index) {\r\n <div class=\"flex flex-row gap-2 btns-options\">\r\n @if ((selectedItems.length > 0 || action.showAcoesLote) &&\r\n (getOrExecute(action.visible, selectedItems) ?? true)) {\r\n <button\r\n pButton\r\n class=\"w-2rem h-2rem flex align-items-center justify-content-center border-none mr-2 btn-table\"\r\n (click)=\"action?.command(); activeItemLote(selectedItems)\"\r\n [pTooltip]=\"getOrExecute(action.tooltip, selectedItems)\"\r\n [tooltipPosition]=\"\r\n (getOrExecute(action.tooltip, selectedItems)?.length ??\r\n 0 > 7) &&\r\n config.actionsLote &&\r\n i == config.actionsLote.length - 1\r\n ? 'left'\r\n : 'bottom'\r\n \"\r\n [disabled]=\"getOrExecute(action.disabled, selectedItems)\"\r\n >\r\n <span\r\n class=\"material-symbols-outlined md-22\"\r\n style=\"color: white\"\r\n >\r\n {{ getOrExecute(action.icon, selectedItems) }}\r\n </span>\r\n </button>\r\n }\r\n </div>\r\n }\r\n </div>\r\n </div>\r\n </ng-template>\r\n } @if (config.enableSelect){\r\n <ng-template pTemplate=\"header\">\r\n <tr>\r\n <th colspan=\"12\">\r\n <div class=\"w-full\">\r\n <!-- <p-tableHeaderCheckbox\r\n (click)=\"activeItemLote(selectedItems)\"\r\n ></p-tableHeaderCheckbox> -->\r\n <input\r\n type=\"checkbox\"\r\n [checked]=\"isAllSelected()\"\r\n [indeterminate]=\"isAllIndeterminate()\"\r\n (click)=\"selectAll($event)\"\r\n />\r\n </div>\r\n </th>\r\n </tr>\r\n </ng-template>\r\n }\r\n\r\n <ng-template\r\n pTemplate=\"groupheader\"\r\n let-group\r\n let-rowIndex=\"rowIndex\"\r\n let-expanded=\"expanded\"\r\n >\r\n <tr>\r\n <td colspan=\"12\" class=\"groupheader\">\r\n <div class=\"flex flex-row align-items-center w-full\">\r\n <button\r\n type=\"button\"\r\n pButton\r\n pRipple\r\n [pRowToggler]=\"group\"\r\n class=\"p-button-text p-button-rounded p-button-plain mr-2\"\r\n [icon]=\"expanded ? 'pi pi-chevron-down' : 'pi pi-chevron-right'\"\r\n ></button>\r\n @if (config.fieldGroupColorFunction){\r\n <div\r\n class=\"tag\"\r\n [style.background-color]=\"config.fieldGroupColorFunction(group)\"\r\n ></div>\r\n }\r\n <span class=\"font-bold ml-2\">{{\r\n group[config.fieldGroup || 0]\r\n }}</span>\r\n </div>\r\n </td>\r\n </tr>\r\n @if(expanded){\r\n <tr style=\"height: 40px\">\r\n @if (config.enableSelect) {\r\n <th class=\"flex align-items-left pl-2\">\r\n <!-- <p-tableHeaderCheckbox\r\n (click)=\"activeItemLote(selectedItems)\"\r\n ></p-tableHeaderCheckbox> -->\r\n <input\r\n type=\"checkbox\"\r\n [checked]=\"\r\n isAllGroupSelected(\r\n config.fieldGroup || 0,\r\n group[config.fieldGroup || 0]\r\n )\r\n \"\r\n [indeterminate]=\"\r\n isGroupIndeterminate(\r\n config.fieldGroup || 0,\r\n group[config.fieldGroup || 0]\r\n )\r\n \"\r\n (click)=\"\r\n selectGroup(\r\n $event,\r\n config.fieldGroup || 0,\r\n group[config.fieldGroup || 0]\r\n )\r\n \"\r\n />\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 class=\"text-sm\"\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 @if (col.sortable) {\r\n <p-sortIcon\r\n [field]=\"'data.' + col.field\"\r\n style=\"font-size: 10px\"\r\n ></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 }\r\n </ng-template>\r\n\r\n <ng-template pTemplate=\"rowexpansion\" let-group>\r\n <tr\r\n (dblclick)=\"doubleClick($event, group)\"\r\n [ngClass]=\"{ capitalize: tableCaptalized }\"\r\n >\r\n @if (config.enableSelect) {\r\n <td [style]=\"applyStyle(group, { field: 'check-box', header: '' })\">\r\n <!--<p-tableCheckbox *ngIf=\"isVisibleCheckbox(group.data)\"-->\r\n <!-- <p-tableCheckbox\r\n [value]=\"group\"\r\n [disabled]=\"isDisabledCheckbox(group)\"\r\n (click)=\"activeItemLote(selectedItems)\"\r\n ></p-tableCheckbox>\r\n -->\r\n <input\r\n type=\"checkbox\"\r\n [value]=\"group\"\r\n [checked]=\"isSelected(group)\"\r\n (click)=\"selectItem($event, group)\"\r\n />\r\n </td>\r\n } @for (col of columns; track $index) {\r\n <ng-container>\r\n @if (!col.template) {\r\n <td\r\n class=\"rowTable\"\r\n [style]=\"\r\n applyStyle(group, col) +\r\n centralizarColunas(col) +\r\n alignColunas(col)\r\n \"\r\n [pTooltip]=\"returnTooltipRow(group, col)\"\r\n >\r\n <span class=\"p-column-title\">{{ col.header }}:</span>\r\n\r\n <span\r\n *ngIf=\"!isBooleanField(group, col); else booleanField\"\r\n [class]=\"returnRowClass(group, col)\"\r\n >\r\n @if (!isChipField(col) && !col.iconField && !isImageField(col)) {\r\n <span>\r\n @if (col.icon) {\r\n <i [class]=\"col.icon + ' mr-2'\"></i>\r\n }\r\n {{ transformValue(group, col) }}\r\n </span>\r\n } @if (isChipField(col) && !col.iconField) {\r\n <div>\r\n <span\r\n [class]=\"returnClassChip(group, col)\"\r\n [pTooltip]=\"returnTooltipIcon(group, col)\"\r\n >{{ transformValue(group, col) }}</span\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(group, 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(group, col)\"\r\n >\r\n {{ returnClassIcon(group, col) }}\r\n </i>\r\n }\r\n\r\n <ng-template #booleanField>\r\n @if (!col.iconField && !isSwitchField(col)) {\r\n <i\r\n [ngClass]=\"group[col.field] ? 'text-green-500' : 'text-red-500'\"\r\n ><span class=\"material-symbols-outlined\">\r\n {{ group[col.field] ? \"check\" : \"close\" }}\r\n </span>\r\n </i>\r\n } @if (isSwitchField(col)) {\r\n <span [class]=\"returnRowClass(group, col)\">\r\n <kv-switch\r\n (onSwitchChange)=\"onSwitchChange($event, group, col)\"\r\n [disabled]=\"col?.onlyReadField ?? true\"\r\n [switchValue]=\"transformValue(group, col)\"\r\n >\r\n </kv-switch>\r\n </span>\r\n }\r\n </ng-template>\r\n </td>\r\n } @if (col.template) {\r\n <td\r\n [style]=\"\r\n applyStyle(group, col) +\r\n centralizarColunas(col) +\r\n alignColunas(col)\r\n \"\r\n class=\"rowTable\"\r\n >\r\n <span class=\"p-column-title\">{{ col.header }}:</span>\r\n @if (getCustomTemplate(col.template.name)) {\r\n <ng-container\r\n [ngTemplateOutlet]=\"getCustomTemplate(col.template.name)\"\r\n [ngTemplateOutletContext]=\"{ $implicit: group }\"\r\n />\r\n }\r\n </td>\r\n }\r\n </ng-container>\r\n } @if (config.actions && config.actions.length > 0) {\r\n <td [style]=\"applyStyle(group, { field: 'btns-options', header: '' })\">\r\n <div class=\"flex flex-row justify-content-end w-full\">\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(group)\"\r\n > -->\r\n\r\n <span\r\n class=\"material-symbols-outlined cursor-pointer icon-more-horiz\"\r\n style=\"font-size: 25px\"\r\n (click)=\"\r\n returnRowDataActions(group);\r\n menu.toggle($event);\r\n activeItem(group)\r\n \"\r\n >\r\n more_horiz\r\n </span>\r\n\r\n <!-- </button> -->\r\n\r\n <p-tieredMenu\r\n #menu\r\n [popup]=\"true\"\r\n [model]=\"menuItems\"\r\n appendTo=\"body\"\r\n ></p-tieredMenu>\r\n </div>\r\n </td>\r\n }\r\n </tr>\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; border-radius: 10px !important\"\r\n >\r\n <p class=\"font-medium m-0\">Nenhum registro encontrado</p>\r\n </td>\r\n </tr>\r\n </ng-template>\r\n </p-table>\r\n }\r\n</div>\r\n", styles: ["@charset \"UTF-8\";.tag{width:5px;height:20px;border-radius:.25rem}input[type=checkbox]{appearance:none;-webkit-appearance:none;-moz-appearance:none;width:20px;height:20px;border:2px solid #ccc;border-radius:4px;position:relative;cursor:pointer;outline:none;background-color:#fff}input[type=checkbox]:after{content:\"\";position:absolute;left:5px;top:2px;width:5px;height:10px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg);opacity:0;transition:opacity .2s}input[type=checkbox]:checked{border-color:#004172;background:#004172}input[type=checkbox]:checked:hover{background-color:#002542}input[type=checkbox]:checked:active{background-color:#002542}input[type=checkbox]:checked:disabled{background-color:#002542;opacity:.4;cursor:auto}input[type=checkbox]:checked:after{opacity:1}::ng-deep .p-datatable.p-datatable-sm .p-datatable-header{padding:0rem}::ng-deep .p-datatable.p-datatable-sm .p-datatable-thead>tr>th{background-color:#eaeaea}::ng-deep .p-panel.p-panel-toggleable .p-panel-header{background-color:#eaeaea}.tr-td:hover{box-shadow:#3c40434d 0 1px 2px,#3c404326 0 2px 6px 2px;background-color:#fff;transition:color .3s,transform .3s;transform:scale(1)}.icon-more-horiz:hover,.icon-more-horiz:focus{color:#5e5e5e;transform:scale(1.2);transition:color .3s,transform .3s;background-color:#eaeaea;border-radius:50%}.btn-table{background-color:#29b92d;padding:12px}.btn-table:hover{background-color:#249a29}.btn-table:active{background-color:#1c801f}.btn-table:disabled{background-color:#29b92d}\n"] }]
|
|
430
430
|
}], ctorParameters: () => [{ type: i1.DatePipe }, { type: i1.DecimalPipe }, { type: i2.CpfCnpjPipe }, { type: i3.TelefonePipe }], propDecorators: { _templates: [{
|
|
431
431
|
type: Input,
|
|
432
432
|
args: ['templates']
|