keevo-components 1.8.482 → 1.8.483
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.
|
@@ -161,7 +161,7 @@ export class KvTreetableComponent {
|
|
|
161
161
|
this.dataSourceMock = Array.from({ length: this.rows }, () => ({
|
|
162
162
|
...rowItem,
|
|
163
163
|
data: { ...(rowItem.data || {}) },
|
|
164
|
-
children: []
|
|
164
|
+
children: [{ ...(rowItem.data || {}) }]
|
|
165
165
|
}));
|
|
166
166
|
this.dataSource.set(this.dataSourceMock);
|
|
167
167
|
}
|
|
@@ -335,4 +335,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
|
|
|
335
335
|
type: HostListener,
|
|
336
336
|
args: ['window:resize', ['$event']]
|
|
337
337
|
}] } });
|
|
338
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-tree-table.component.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/components/kv-tree-table/kv-tree-table.component.ts","../../../../../../projects/keevo-components/src/lib/components/kv-tree-table/kv-tree-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ContentChildren,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostListener,\r\n  Input,\r\n  Output,\r\n  QueryList,\r\n  TemplateRef,\r\n  ViewChild,\r\n  computed,\r\n  effect,\r\n  input,\r\n  model,\r\n  signal,\r\n  viewChild,\r\n} from '@angular/core';\r\nimport { MenuItem, TreeNode } from 'primeng/api';\r\nimport { TreeTable } from 'primeng/treetable';\r\nimport {\r\n  ValueOrFn,\r\n  getOrExecute,\r\n  mapToMenuItem,\r\n} from '../../api/components/table/kv-menuitem';\r\nimport { TablePaginate } from '../../api/components/table/table.paginate';\r\nimport { TemplateDirective } from '../../api/directives/template/template.directive';\r\nimport { TreeTableConfig } from '../../api/components/tree-table/tree-table.config';\r\nimport { TreeTableKeys } from '../../api/components/tree-table/tree-table-keys';\r\nimport { CdkDragDrop, moveItemInArray } from '@angular/cdk/drag-drop';\r\nimport { TableConfigColumn } from '../../api/components/table/table.config.column';\r\n\r\n@Component({\r\n  selector: 'kv-tree-table',\r\n  templateUrl: './kv-tree-table.component.html',\r\n  styleUrls: ['./kv-tree-table.component.scss'],\r\n})\r\nexport class KvTreetableComponent {\r\n  menuItems: MenuItem[] = [];\r\n  @Input() disableRowNodeSticky: boolean = false;\r\n\r\n  @Input() config!: TreeTableConfig;\r\n  // @Input() dataSource!: any;\r\n  @Input() gridLines: boolean = false;\r\n  @Input() tableCaptalized: boolean = false;\r\n  @Input() selectedItems: any = [];\r\n  @Input() paginator = true;\r\n  @Input() rows = 10;\r\n  @Input() treeTableDraggable = false;\r\n  @Input() transferArrayItem = false;\r\n  @Input() ordenacao!: string;\r\n  @Input() totalRecords!: number;\r\n  @Input() textoEmptyMessage: string = 'Nenhum registro encontrado';\r\n  @Input() childrenRecoil: boolean = true;\r\n  @Input() showHeader: boolean = true;\r\n  @Input() scrollHeight: string = '';\r\n  @Input() indFullPage: boolean = false;\r\n\r\n  dataSource = model<any[]>([]);\r\n  tamanhoTela = signal<number>(0);\r\n  kvTreeTable = viewChild<ElementRef>('kvTreeTable');\r\n  isLoadingSkeleton = input<boolean>(false);\r\n  dataSourceMock: any[] = [];\r\n\r\n  constructor(private elementRef: ElementRef) { }\r\n\r\n  /**\r\n   * @deprecated O valor de pageLinks é atribuído de acordo com o tamanho da tela, essa propriedade não está sendo utilizada\r\n   */\r\n  @Input() pageLinksOptions!: number;\r\n  /**\r\n   * @deprecated O valor de pageLinks é atribuído de acordo com o tamanho da tela, essa propriedade não está sendo utilizada\r\n   */\r\n  @Input() pageLinks!: number;\r\n  /**\r\n   * @deprecated A quantidade de paginitorPageIcons é atribuído de acordo com o tamanho da tela, essa propriedade não está sendo utilizada\r\n   */\r\n  @Input() showFirstLastIcon!: boolean;\r\n\r\n  @Output() onFilter: EventEmitter<any> = new EventEmitter();\r\n  @Output() onPaginate: EventEmitter<any> = new EventEmitter();\r\n  @Output() onActiveItem: EventEmitter<any> = new EventEmitter();\r\n  @Output() onActiveItemLote: EventEmitter<any> = new EventEmitter();\r\n  @Output() doubleClickEvent: EventEmitter<any> = new EventEmitter();\r\n  @Output() onNodeSelect: EventEmitter<any> = new EventEmitter();\r\n  @Output() onNodeUnselect: EventEmitter<any> = new EventEmitter();\r\n  @Output() onDropItem: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  public readonly selectionKeys = model<TreeTableKeys | undefined>(undefined);\r\n\r\n  ngOnInit() {\r\n    this.loadingSkeletonUtilities();\r\n\r\n    this.tamanhoTela.set(window.innerWidth);\r\n    if (this.ordenacao) {\r\n      this.dataSource.set(this.sortTreeNodes(this.dataSource()));\r\n    }\r\n\r\n    if (this.indFullPage)\r\n      this.setMaxHeightTreeTable();\r\n  }\r\n\r\n  @ContentChildren(TemplateDirective) templates!: QueryList<any>;\r\n  @Input('templates') _templates!: any;\r\n\r\n  @ViewChild(TreeTable) pTreeTable!: TreeTable;\r\n  @ViewChild('inputBusca') inputBusca!: ElementRef;\r\n\r\n  isEmptyDataSource = computed(() => {\r\n    return this.dataSource() === this.dataSourceMock;\r\n  });\r\n\r\n  ngOnChanges(changes: any) {\r\n    if (changes['dataSource'])\r\n      this.isEmptyDataSource();\r\n  }\r\n\r\n  @HostListener('window:resize', ['$event'])\r\n  onWindowResize() {\r\n    this.tamanhoTela.set(window.innerWidth);\r\n  }\r\n\r\n  public activeItem(rowData: any) {\r\n    this.onActiveItem.emit(rowData);\r\n  }\r\n\r\n  public activeItemLote(rowData: any) {\r\n    this.onActiveItemLote.emit(rowData);\r\n  }\r\n\r\n  getOrExecute<T>(action: ValueOrFn<T>, data: any): T {\r\n    return getOrExecute(action, data);\r\n  }\r\n\r\n  public onGlobalFilter(table: TreeTable, event: Event) {\r\n    this.onFilter.emit((event.target as HTMLInputElement).value);\r\n    table.filterGlobal((event.target as HTMLInputElement).value, 'contains');\r\n  }\r\n\r\n  public paginate($event: any) {\r\n    if ($event) {\r\n      let paginaInicial =\r\n        ($event?.first > 0 ? $event.first / $event.rows : $event.first) + 1;\r\n      let termoPesquisa = '';\r\n      let ordenacao = '';\r\n\r\n      if ($event.globalFilter) termoPesquisa = $event.globalFilter;\r\n\r\n      if ($event.sortField)\r\n        ordenacao = `${$event.sortField} ${$event.sortOrder === 1 ? 'ASC' : 'DESC'\r\n          }`;\r\n\r\n      const objeto: TablePaginate = {\r\n        paginaInicial: paginaInicial,\r\n        tamanhoPagina: $event.rows,\r\n        termoPesquisa: termoPesquisa,\r\n        ordenacao: ordenacao,\r\n      };\r\n\r\n      this.onPaginate.emit(objeto);\r\n    }\r\n  }\r\n\r\n  loadingSkeletonUtilities() {\r\n    if (this.dataSource().length === 0 && this.isLoadingSkeleton()) {\r\n      let rowItem: any = {};\r\n      this.config?.columns.forEach((col) => {\r\n        rowItem[col.field] = '';\r\n      });\r\n\r\n      this.dataSourceMock = Array.from({ length: this.rows }, () => ({\r\n        ...rowItem,\r\n        data: { ...(rowItem.data || {}) },\r\n        children: []\r\n      }));\r\n\r\n      this.dataSource.set(this.dataSourceMock)\r\n    }\r\n  }\r\n\r\n\r\n  drop(event: CdkDragDrop<any>) {\r\n    const draggedNode = event.item.data;\r\n    const draggedChildData = draggedNode.node.data;\r\n\r\n    if (draggedNode.level === 0) {\r\n      moveItemInArray(this.dataSource(), event.previousIndex, event.currentIndex);\r\n    } else if (draggedNode.level >= 1) {\r\n      const parentNode = draggedNode.node.parent;\r\n\r\n      if (parentNode) {\r\n        const parentChildren = parentNode.children.map(\r\n          (child: any) => child.data\r\n        );\r\n        const previousChildIndex = parentChildren.indexOf(draggedChildData);\r\n\r\n        const relativeCurrentIndex =\r\n          previousChildIndex + (event.currentIndex - event.previousIndex);\r\n\r\n        const targetChildIndex = Math.max(\r\n          0,\r\n          Math.min(parentChildren.length - 1, relativeCurrentIndex)\r\n        );\r\n\r\n        if (previousChildIndex !== -1 && targetChildIndex !== -1) {\r\n          moveItemInArray(\r\n            parentNode.children,\r\n            previousChildIndex,\r\n            targetChildIndex\r\n          );\r\n        }\r\n        const dropInfo: any = {\r\n          previousChildIndex: previousChildIndex + 1,\r\n          targetChildIndex: targetChildIndex + 1,\r\n        };\r\n\r\n        this.onDropItem.emit({ event: event, dropChildInfo: dropInfo });\r\n      }\r\n    }\r\n\r\n    this.dataSource.set([...this.dataSource()]);\r\n\r\n    if (draggedNode.level === 0) {\r\n      this.onDropItem.emit(event);\r\n    }\r\n  }\r\n\r\n  sortTreeNodes(nodes: TreeNode[]): TreeNode[] {\r\n    return nodes\r\n      .sort((a, b) => a.data[this.ordenacao] - b.data[this.ordenacao])\r\n      .map((node) => {\r\n        if (node.children) {\r\n          node.children = this.sortTreeNodes(node.children);\r\n        }\r\n        return node;\r\n      });\r\n  }\r\n\r\n  // calculateTargetChildIndex(\r\n  //   event: CdkDragDrop<any>,\r\n  //   parentChildren: any[],\r\n  //   previousChildIndex: number\r\n  // ): number {\r\n  //   const targetChildIndex =\r\n  //     previousChildIndex + (event.currentIndex - event.previousIndex);\r\n\r\n  //   if (targetChildIndex < 0) {\r\n  //     return 0;\r\n  //   } else if (targetChildIndex >= parentChildren.length) {\r\n  //     return parentChildren.length - 1;\r\n  //   } else {\r\n  //     return targetChildIndex;\r\n  //   }\r\n  // }\r\n\r\n  doubleClick(e: any, rowData: any) {\r\n    let eventDoubleClick = { event: e, rowData: rowData };\r\n\r\n    let array: string[] = [];\r\n    e.target.classList.forEach((x: any) => array.push(x));\r\n\r\n    this.doubleClickEvent.emit(eventDoubleClick);\r\n  }\r\n\r\n  onNodeSelected(event: any) {\r\n    this.onNodeSelect.emit(event);\r\n  }\r\n\r\n  onNodeUnselected(event: any) {\r\n    this.onNodeUnselect.emit(event);\r\n  }\r\n\r\n  getCustomTemplate(templatename: string): TemplateRef<any> {\r\n    return this._templates[templatename];\r\n  }\r\n\r\n  getIcon(icon: string): string {\r\n    return icon.includes('pi-') ? `pi ${icon}` : '';\r\n  }\r\n\r\n  align(col: TableConfigColumn): string {\r\n    if (col.centralize) return 'justify-content-center';\r\n    else if (col.align == 'right') return 'justify-content-end';\r\n    else return '';\r\n  }\r\n\r\n  resetTreeTable() {\r\n    if (this.pTreeTable) this.pTreeTable.reset();\r\n    if (this.inputBusca) this.inputBusca.nativeElement.value = '';\r\n  }\r\n\r\n  setMaxHeightTreeTable() {\r\n    if (this.kvTreeTable()?.nativeElement.offsetHeight) {\r\n      const height = this.kvTreeTable()?.nativeElement.offsetHeight;\r\n      const element = this.elementRef.nativeElement.querySelector('.kv-treetable-container')\r\n      if (element) element.style.maxHeight = `${height}px`\r\n    }\r\n  }\r\n\r\n  criarMenusModal = computed(() => (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  validateActionPosition = computed(() => (rowNode: any) => {\r\n    if (this.config.actionsPai && rowNode.level == 0) return false;\r\n    else return true;\r\n  });\r\n\r\n  isSelectEnabled = computed(() => (rowData: any, rowNode: any) => {\r\n    return this.config.visibleCheckboxFunction\r\n      ? this.config.visibleCheckboxFunction(rowData, rowNode)\r\n      : true\r\n  });\r\n\r\n  isDisabledCheckbox = computed(() => (rowData: any, rowNode: any) => {\r\n    return this.config.disableControlCheckboxFunction\r\n      ? this.config.disableControlCheckboxFunction(rowData, rowNode)\r\n      : false;\r\n  });\r\n\r\n  validateShowTemplate = computed(() => (rowNode: any, col: any) => {\r\n    if (col.templateOnly) {\r\n      if (col.templateOnly === 'pai') {\r\n        return rowNode.level === 0;\r\n      }\r\n      if (col.templateOnly === 'filho') {\r\n        return rowNode.level === 1;\r\n      }\r\n    }\r\n    return true;\r\n  });\r\n\r\n  exibirCampo = computed(() => (field: any, rowData: any) => {\r\n    let visible = field.visible ? field.visible(rowData) : true;\r\n    return visible;\r\n  });\r\n}\r\n\r\n","<div class=\"kv-treetable-container\" #kvTreeTable>\r\n  <p-treeTable\r\n    #tt\r\n    cdkDropList\r\n    class=\"example-list\"\r\n    (cdkDropListDropped)=\"drop($event)\"\r\n    [value]=\"dataSource()\"\r\n    [columns]=\"config.columns\"\r\n    [resizableColumns]=\"true\"\r\n    [tableStyle]=\"{ 'min-width': '50rem' }\"\r\n    [resizableColumns]=\"true\"\r\n    [paginator]=\"paginator\"\r\n    [rows]=\"rows\"\r\n    [totalRecords]=\"totalRecords\"\r\n    [rowsPerPageOptions]=\"[5, 10, 15, 25, 50]\"\r\n    [showFirstLastIcon]=\"tamanhoTela() > 960 ? true : false\"\r\n    [pageLinks]=\"tamanhoTela() > 960 ? 2 : 1\"\r\n    [styleClass]=\"gridLines ? 'p-treetable-gridlines' : ''\"\r\n    [(selection)]=\"selectedItems\"\r\n    [selectionKeys]=\"selectionKeys()\"\r\n    (selectionKeysChange)=\"selectionKeys.set($event)\"\r\n    [lazy]=\"config.lazy\"\r\n    (onLazyLoad)=\"paginate($event)\"\r\n    (onNodeSelect)=\"onNodeSelected($event)\"\r\n    (onNodeUnselect)=\"onNodeUnselected($event)\"\r\n    [showCurrentPageReport]=\"true\"\r\n    currentPageReportTemplate=\"{first} - {last} de {totalRecords}\"\r\n    [scrollHeight]=\"scrollHeight\"\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 m-0 p-1\"\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\">{{ config.title }}</div>\r\n          } @if(config.subtitle) {\r\n          <div class=\"text-sm mb-4 font-medium\">{{ config.subtitle }}</div>\r\n          }\r\n        </div>\r\n\r\n        <div\r\n          class=\"flex flex-row align-items-center col-10 p-0 md:col-6 lg:col-4 justify-content-center {{\r\n            tamanhoTela() < 768 ? '' : 'input-search'\r\n          }}\"\r\n        >\r\n          @if(config.enableFilter) {\r\n\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(tt, $event)\"\r\n              placeholder=\"Pesquisar...\"\r\n              class=\"h-2rem\"\r\n              #inputBusca\r\n            />\r\n          </span>\r\n          }\r\n        </div>\r\n\r\n        <div class=\"flex flex-row col-1 justify-content-end p-0\">\r\n          <div class=\"flex flex-row gap-2 btns-options\">\r\n            @for (action of config.actionsLote; track $index) {\r\n            @if((selectedItems.length > 0 || action.showAcoesLote) &&\r\n            exibirCampo()(action, this.action)) {\r\n            <kv-button\r\n              (onClick)=\"action?.command(); activeItemLote(selectedItems)\"\r\n              [pTooltip]=\"getOrExecute(action.tooltip, selectedItems)\"\r\n              [tooltipPosition]=\"'bottom'\"\r\n              [size]=\"'small'\"\r\n              [disabled]=\"getOrExecute(action.disabled, selectedItems) || false\"\r\n              [icon]=\"getOrExecute(action.icon, selectedItems)\"\r\n              [severity]=\"action.severity || 'tertiary'\"\r\n            />\r\n            } }\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </ng-template>\r\n    } @if(showHeader){\r\n    <ng-template pTemplate=\"header\" let-columns>\r\n      <tr>\r\n        @for(col of columns; track $index){\r\n        <th\r\n          [ttSortableColumn]=\"col.field\"\r\n          [ttSortableColumnDisabled]=\"col.sortable === false\"\r\n          [style.width]=\"col.width\"\r\n        >\r\n          <div>\r\n            <div [ngClass]=\"{ flex: $index == 0, 'gap-3': $index == 0 }\">\r\n              @if($index == 0 && config.enableSelect) {\r\n              <p-treeTableHeaderCheckbox\r\n                (click)=\"activeItemLote(selectedItems)\"\r\n              />\r\n              }\r\n\r\n              <div class=\"flex flex-row align-items-center  {{ align(col) }}\">\r\n                <span class=\"text-xs\">{{ col.header }}</span>\r\n\r\n                @if(col.sortable) {\r\n                <p-treeTableSortIcon [field]=\"col.field\" class=\"pb-1\" />\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                >\r\n                  info\r\n                </span>\r\n                }\r\n              </div>\r\n            </div>\r\n          </div>\r\n        </th>\r\n        @if (config.actions?.length ?? 0 > 0 || config.actionsPai) {\r\n        <th [style.width]=\"5\"></th>\r\n        } }\r\n      </tr>\r\n    </ng-template>\r\n\r\n    <ng-template pTemplate=\"header\" let-columns>\r\n      <tr>\r\n        @for (col of columns; track $index) {\r\n        <th\r\n          [ttSortableColumn]=\"col.field\"\r\n          [ttSortableColumnDisabled]=\"col.sortable === false\"\r\n          [style.width]=\"col.width\"\r\n        >\r\n          <div class=\"flex flex-row align-items-center {{ align(col) }}\">\r\n            <span class=\"text-xs\">{{ col.header }}</span>\r\n\r\n            @if(col.sortable) {\r\n            <p-treeTableSortIcon [field]=\"col.field\" class=\"pb-1\" />\r\n            }\r\n          </div>\r\n        </th>\r\n        } @if (config.actions?.length ?? 0 > 0 || config.actionsPai) {\r\n        <th [style.width]=\"5\"></th>\r\n        }\r\n      </tr>\r\n    </ng-template>\r\n    }\r\n\r\n    <ng-template\r\n      pTemplate=\"body\"\r\n      let-rowNode\r\n      let-rowData=\"rowData\"\r\n      let-columns=\"columns\"\r\n    >\r\n      @if(isEmptyDataSource() && isLoadingSkeleton()) { @for(skeletonRow of\r\n      dataSource(); track $index) {\r\n      <tr>\r\n        @for(col of columns; track $index){\r\n        <td>\r\n          <div\r\n            class=\"flex flex-row align-items-center justify-content-center w-full\"\r\n          >\r\n            @if($index == 0) {\r\n            <p-treeTableToggler [rowNode]=\"rowNode\" />\r\n            }\r\n            <div class=\"flex flex-column w-full\">\r\n              <p-skeleton height=\"1rem\" />\r\n            </div>\r\n          </div>\r\n        </td>\r\n        }\r\n        <td>\r\n          <div class=\"flex justify-content-center\">\r\n            <p-skeleton [style]=\"{ height: '1.5rem', width: '1.5rem' }\" />\r\n          </div>\r\n        </td>\r\n      </tr>\r\n      } } @else { @if(treeTableDraggable) {\r\n      <tr\r\n        cdkDrag\r\n        cdkDragLockAxis=\"y\"\r\n        [cdkDragData]=\"rowNode\"\r\n        [ttRow]=\"rowNode\"\r\n        (dblclick)=\"doubleClick($event, rowData)\"\r\n        [ngClass]=\"{ capitalize: tableCaptalized }\"\r\n      >\r\n        @for(col of columns; track $index){\r\n        <td\r\n          class=\"draggable-cell\"\r\n          [style.position]=\"\r\n            !disableRowNodeSticky && rowNode.level !== 0 ? 'sticky' : null\r\n          \"\r\n        >\r\n          <!-- [style.left.px]=\"\r\n                   childrenRecoil && rowNode.level !== 0 ? rowNode.level * 30 : null\r\n                   \" -->\r\n\r\n          <div class=\"flex flex-row  {{ align(col) }}\">\r\n            @if($index == 0) {\r\n            <div class=\"w-full-h-full flex align-items-center\">\r\n              <span\r\n                class=\"material-symbols-outlined drag-icon\"\r\n                style=\"\r\n                  cursor: grab;\r\n                  font-size: 25px;\r\n                  color: #6b7280;\r\n                  opacity: 0.9;\r\n                \"\r\n                cdkDragHandle\r\n              >\r\n                drag_indicator\r\n              </span>\r\n              <p-treeTableToggler class=\"hiddenVisible\" [rowNode]=\"rowNode\" />\r\n\r\n              @if(config.enableSelect) {\r\n              <p-treeTableCheckbox\r\n                [disabled]=\"isDisabledCheckbox()(rowData, rowNode)\"\r\n                (click)=\"activeItemLote(selectedItems)\"\r\n                [value]=\"rowNode\"\r\n                [ngStyle]=\"{\r\n                  display: isSelectEnabled()(rowData, rowNode)\r\n                    ? 'block'\r\n                    : 'none',\r\n                  'margin-left': config.visibleCheckboxFunction\r\n                    ? '-34px'\r\n                    : '0px'\r\n                }\"\r\n              />\r\n              }\r\n            </div>\r\n            }\r\n\r\n            <div class=\"flex flex-row align-items-center w-full\">\r\n              @if (col.template && validateShowTemplate()(rowNode, col)) {\r\n              <span class=\"w-full\">\r\n                @if(getCustomTemplate(col.template.name)) {\r\n                <ng-container\r\n                  [ngTemplateOutlet]=\"getCustomTemplate(col.template.name)\"\r\n                  [ngTemplateOutletContext]=\"{ $implicit: rowData }\"\r\n                >\r\n                </ng-container>\r\n                }\r\n              </span>\r\n              } @else {\r\n              <div\r\n                class=\"flex flex-row align-items-center {{\r\n                  (col.boolean || col.centralize) && 'justify-content-center'\r\n                }} gap-2 w-full\"\r\n              >\r\n                @if(col.tagColor) {\r\n                <div\r\n                  class=\"tag\"\r\n                  [pTooltip]=\"\r\n                    col.tooltipTag &&\r\n                    col.tooltipTag(rowData, col, rowData[col.field])\r\n                  \"\r\n                  [style.background-color]=\"\r\n                    col.tagColor(rowData, col, rowData[col.field])\r\n                  \"\r\n                ></div>\r\n\r\n                } @if(col.boolean) {\r\n                <i\r\n                  class=\"pi {{\r\n                    rowData[col.field] ? 'pi-check text-green-300' : ''\r\n                  }}\"\r\n                  style=\"font-size: 1rem; font-weight: 700\"\r\n                ></i>\r\n\r\n                } @else {\r\n                <div class=\"flex flex-column\">\r\n                  <span class=\"m-0 text-xs\">{{ rowData[col.field] }}</span>\r\n\r\n                  @if(col.subtitle) {\r\n\r\n                  <p class=\"m-0 text-xs font-semibold\">\r\n                    {{ rowData[col.subtitle] }}\r\n                  </p>\r\n                  }\r\n                </div>\r\n                }\r\n              </div>\r\n              }\r\n            </div>\r\n          </div>\r\n        </td>\r\n        } @if((config.actions?.length ?? 0 > 0) || config.actionsPai) {\r\n        <td\r\n          style=\"border-left: none; text-align: center; width: 0\"\r\n          [style.borderRight]=\"rowNode.level === 0 ? 'none' : ''\"\r\n          [style.borderLeft]=\"rowNode.level === 0 ? 'none' : ''\"\r\n        >\r\n          @if((config.actions?.length ?? 0 > 0) &&\r\n          validateActionPosition()(rowNode)) {\r\n          <div class=\"flex align-items-center justify-content-center\">\r\n            <span\r\n              class=\"material-symbols-outlined cursor-pointer icon-more-horiz\"\r\n              style=\"font-size: 20px; padding: 0.1rem\"\r\n              (click)=\"menu.toggle($event); activeItem(rowData)\"\r\n            >\r\n              more_horiz\r\n            </span>\r\n\r\n            @for(action of config.actions; track $index) {\r\n            {{ criarMenusModal()(rowData) }}\r\n            }\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          } @if(config.actionsPai?.length ?? 0 > 0 && rowNode.level == 0){\r\n          <div class=\"flex justify-content-end align-items-center\">\r\n            @for (actionPai of config.actionsPai; track $index) {\r\n            @if(getOrExecute(actionPai.visible, rowData) ?? true) {\r\n            <kv-button\r\n              (onClick)=\"activeItem(rowData); actionPai.command($event)\"\r\n              [type]=\"'text'\"\r\n              [icon]=\"actionPai.icon\"\r\n              [severity]=\"actionPai.severity || 'tertiary'\"\r\n              [disabled]=\"getOrExecute(actionPai.disabled, rowData) || false\"\r\n              [pTooltip]=\"getOrExecute(actionPai.tooltip, rowData)\"\r\n              [tooltipPosition]=\"'left'\"\r\n            />\r\n\r\n            } }\r\n          </div>\r\n          }\r\n        </td>\r\n        }\r\n      </tr>\r\n      } @else {\r\n      <tr\r\n        [ttRow]=\"rowNode\"\r\n        (dblclick)=\"doubleClick($event, rowData)\"\r\n        [ngClass]=\"{ capitalize: tableCaptalized }\"\r\n      >\r\n        @for(col of columns; track $index){\r\n        <td\r\n          [style.position]=\"rowNode.level !== 0 ? 'sticky' : null\"\r\n          [style.left.px]=\"\r\n            childrenRecoil && rowNode.level !== 0 ? rowNode.level * 30 : null\r\n          \"\r\n          [style.borderRight]=\"rowNode.level === 0 ? 'none' : ''\"\r\n          [style.borderLeft]=\"\r\n            rowNode.level === 0 && col.field != config.columns[0].field\r\n              ? 'none'\r\n              : ''\r\n          \"\r\n        >\r\n          <div class=\"flex flex-row {{ align(col) }}\">\r\n            @if($index == 0) {\r\n            <div class=\"w-full-h-full flex align-items-center\">\r\n              <p-treeTableToggler class=\"hiddenVisible\" [rowNode]=\"rowNode\" />\r\n\r\n              @if(config.enableSelect) {\r\n              <p-treeTableCheckbox\r\n                [disabled]=\"isDisabledCheckbox()(rowData, rowNode)\"\r\n                (click)=\"activeItemLote(selectedItems)\"\r\n                [value]=\"rowNode\"\r\n                [ngStyle]=\"{\r\n                  display: isSelectEnabled()(rowData, rowNode)\r\n                    ? 'block'\r\n                    : 'none',\r\n                  'margin-left': config.visibleCheckboxFunction\r\n                    ? '-34px'\r\n                    : '0px'\r\n                }\"\r\n              />\r\n              }\r\n            </div>\r\n            }\r\n\r\n            <div class=\"flex flex-row align-items-center w-full\">\r\n              @if (col.template && validateShowTemplate()(rowNode, col)) {\r\n              <span class=\"w-full\">\r\n                @if(getCustomTemplate(col.template.name)) {\r\n\r\n                <ng-container\r\n                  [ngTemplateOutlet]=\"getCustomTemplate(col.template.name)\"\r\n                  [ngTemplateOutletContext]=\"{ $implicit: rowData }\"\r\n                >\r\n                </ng-container>\r\n                }\r\n              </span>\r\n              } @else {\r\n              <div\r\n                class=\"flex flex-row align-items-center {{\r\n                  (col.boolean || col.centralize) && 'justify-content-center'\r\n                }} gap-2 w-full\"\r\n              >\r\n                @if(col.tagColor) {\r\n\r\n                <div\r\n                  class=\"tag\"\r\n                  [pTooltip]=\"\r\n                    col.tooltipTag &&\r\n                    col.tooltipTag(rowData, col, rowData[col.field])\r\n                  \"\r\n                  [style.background-color]=\"\r\n                    col.tagColor(rowData, col, rowData[col.field])\r\n                  \"\r\n                ></div>\r\n\r\n                } @if(col.boolean) {\r\n\r\n                <i\r\n                  class=\"pi {{\r\n                    rowData[col.field] ? 'pi-check text-green-300' : ''\r\n                  }}\"\r\n                  style=\"font-size: 1rem; font-weight: 700\"\r\n                ></i>\r\n                } @else {\r\n                <div class=\"flex flex-column\">\r\n                  <span class=\"m-0 text-xs\">{{ rowData[col.field] }}</span>\r\n\r\n                  @if(col.subtitle) {\r\n\r\n                  <p class=\"m-0 text-xs font-semibold\">\r\n                    {{ rowData[col.subtitle] }}\r\n                  </p>\r\n                  }\r\n                </div>\r\n                }\r\n              </div>\r\n              }\r\n            </div>\r\n          </div>\r\n        </td>\r\n        } @if((config.actions?.length ?? 0 > 0) || config.actionsPai) {\r\n        <td style=\"border-left: none; text-align: center; width: 0\">\r\n          @if((config.actions?.length ?? 0 > 0) &&\r\n          validateActionPosition()(rowNode)) {\r\n          <div>\r\n            <span\r\n              class=\"material-symbols-outlined cursor-pointer icon-more-horiz\"\r\n              style=\"font-size: 20px; padding: 0.1rem\"\r\n              (click)=\"menu.toggle($event); activeItem(rowData)\"\r\n            >\r\n              more_horiz\r\n            </span>\r\n\r\n            @for(action of config.actions; track $index) {\r\n            {{ criarMenusModal()(rowData) }}\r\n            }\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          } @if(config.actionsPai?.length ?? 0 > 0 && rowNode.level == 0){\r\n          <div class=\"flex justify-content-end\">\r\n            @for (actionPai of config.actionsPai; track $index) { @if\r\n            (getOrExecute(actionPai.visible, rowData) ?? true) {\r\n            <kv-button\r\n              (onClick)=\"activeItem(rowData); actionPai.command($event)\"\r\n              [type]=\"'text'\"\r\n              [icon]=\"actionPai.icon\"\r\n              [severity]=\"actionPai.severity || 'tertiary'\"\r\n              [disabled]=\"getOrExecute(actionPai.disabled, rowData) || false\"\r\n              [pTooltip]=\"getOrExecute(actionPai.tooltip, rowData)\"\r\n              [tooltipPosition]=\"'left'\"\r\n            />\r\n            } }\r\n          </div>\r\n          }\r\n        </td>\r\n        }\r\n      </tr>\r\n      } }\r\n    </ng-template>\r\n\r\n    <ng-template pTemplate=\"emptymessage\">\r\n      <tr>\r\n        <td\r\n          [attr.colspan]=\"config.columns.length + 1\"\r\n          style=\"text-align: center\"\r\n          class=\"text-sm\"\r\n        >\r\n          {{ textoEmptyMessage }}\r\n        </td>\r\n      </tr>\r\n    </ng-template>\r\n  </p-treeTable>\r\n</div>\r\n"]}
|
|
338
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-tree-table.component.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/components/kv-tree-table/kv-tree-table.component.ts","../../../../../../projects/keevo-components/src/lib/components/kv-tree-table/kv-tree-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ContentChildren,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostListener,\r\n  Input,\r\n  Output,\r\n  QueryList,\r\n  TemplateRef,\r\n  ViewChild,\r\n  computed,\r\n  effect,\r\n  input,\r\n  model,\r\n  signal,\r\n  viewChild,\r\n} from '@angular/core';\r\nimport { MenuItem, TreeNode } from 'primeng/api';\r\nimport { TreeTable } from 'primeng/treetable';\r\nimport {\r\n  ValueOrFn,\r\n  getOrExecute,\r\n  mapToMenuItem,\r\n} from '../../api/components/table/kv-menuitem';\r\nimport { TablePaginate } from '../../api/components/table/table.paginate';\r\nimport { TemplateDirective } from '../../api/directives/template/template.directive';\r\nimport { TreeTableConfig } from '../../api/components/tree-table/tree-table.config';\r\nimport { TreeTableKeys } from '../../api/components/tree-table/tree-table-keys';\r\nimport { CdkDragDrop, moveItemInArray } from '@angular/cdk/drag-drop';\r\nimport { TableConfigColumn } from '../../api/components/table/table.config.column';\r\n\r\n@Component({\r\n  selector: 'kv-tree-table',\r\n  templateUrl: './kv-tree-table.component.html',\r\n  styleUrls: ['./kv-tree-table.component.scss'],\r\n})\r\nexport class KvTreetableComponent {\r\n  menuItems: MenuItem[] = [];\r\n  @Input() disableRowNodeSticky: boolean = false;\r\n\r\n  @Input() config!: TreeTableConfig;\r\n  // @Input() dataSource!: any;\r\n  @Input() gridLines: boolean = false;\r\n  @Input() tableCaptalized: boolean = false;\r\n  @Input() selectedItems: any = [];\r\n  @Input() paginator = true;\r\n  @Input() rows = 10;\r\n  @Input() treeTableDraggable = false;\r\n  @Input() transferArrayItem = false;\r\n  @Input() ordenacao!: string;\r\n  @Input() totalRecords!: number;\r\n  @Input() textoEmptyMessage: string = 'Nenhum registro encontrado';\r\n  @Input() childrenRecoil: boolean = true;\r\n  @Input() showHeader: boolean = true;\r\n  @Input() scrollHeight: string = '';\r\n  @Input() indFullPage: boolean = false;\r\n\r\n  dataSource = model<any[]>([]);\r\n  tamanhoTela = signal<number>(0);\r\n  kvTreeTable = viewChild<ElementRef>('kvTreeTable');\r\n  isLoadingSkeleton = input<boolean>(false);\r\n  dataSourceMock: any[] = [];\r\n\r\n  constructor(private elementRef: ElementRef) { }\r\n\r\n  /**\r\n   * @deprecated O valor de pageLinks é atribuído de acordo com o tamanho da tela, essa propriedade não está sendo utilizada\r\n   */\r\n  @Input() pageLinksOptions!: number;\r\n  /**\r\n   * @deprecated O valor de pageLinks é atribuído de acordo com o tamanho da tela, essa propriedade não está sendo utilizada\r\n   */\r\n  @Input() pageLinks!: number;\r\n  /**\r\n   * @deprecated A quantidade de paginitorPageIcons é atribuído de acordo com o tamanho da tela, essa propriedade não está sendo utilizada\r\n   */\r\n  @Input() showFirstLastIcon!: boolean;\r\n\r\n  @Output() onFilter: EventEmitter<any> = new EventEmitter();\r\n  @Output() onPaginate: EventEmitter<any> = new EventEmitter();\r\n  @Output() onActiveItem: EventEmitter<any> = new EventEmitter();\r\n  @Output() onActiveItemLote: EventEmitter<any> = new EventEmitter();\r\n  @Output() doubleClickEvent: EventEmitter<any> = new EventEmitter();\r\n  @Output() onNodeSelect: EventEmitter<any> = new EventEmitter();\r\n  @Output() onNodeUnselect: EventEmitter<any> = new EventEmitter();\r\n  @Output() onDropItem: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  public readonly selectionKeys = model<TreeTableKeys | undefined>(undefined);\r\n\r\n  ngOnInit() {\r\n    this.loadingSkeletonUtilities();\r\n\r\n    this.tamanhoTela.set(window.innerWidth);\r\n    if (this.ordenacao) {\r\n      this.dataSource.set(this.sortTreeNodes(this.dataSource()));\r\n    }\r\n\r\n    if (this.indFullPage)\r\n      this.setMaxHeightTreeTable();\r\n  }\r\n\r\n  @ContentChildren(TemplateDirective) templates!: QueryList<any>;\r\n  @Input('templates') _templates!: any;\r\n\r\n  @ViewChild(TreeTable) pTreeTable!: TreeTable;\r\n  @ViewChild('inputBusca') inputBusca!: ElementRef;\r\n\r\n  isEmptyDataSource = computed(() => {\r\n    return this.dataSource() === this.dataSourceMock;\r\n  });\r\n\r\n  ngOnChanges(changes: any) {\r\n    if (changes['dataSource'])\r\n      this.isEmptyDataSource();\r\n  }\r\n\r\n  @HostListener('window:resize', ['$event'])\r\n  onWindowResize() {\r\n    this.tamanhoTela.set(window.innerWidth);\r\n  }\r\n\r\n  public activeItem(rowData: any) {\r\n    this.onActiveItem.emit(rowData);\r\n  }\r\n\r\n  public activeItemLote(rowData: any) {\r\n    this.onActiveItemLote.emit(rowData);\r\n  }\r\n\r\n  getOrExecute<T>(action: ValueOrFn<T>, data: any): T {\r\n    return getOrExecute(action, data);\r\n  }\r\n\r\n  public onGlobalFilter(table: TreeTable, event: Event) {\r\n    this.onFilter.emit((event.target as HTMLInputElement).value);\r\n    table.filterGlobal((event.target as HTMLInputElement).value, 'contains');\r\n  }\r\n\r\n  public paginate($event: any) {\r\n    if ($event) {\r\n      let paginaInicial =\r\n        ($event?.first > 0 ? $event.first / $event.rows : $event.first) + 1;\r\n      let termoPesquisa = '';\r\n      let ordenacao = '';\r\n\r\n      if ($event.globalFilter) termoPesquisa = $event.globalFilter;\r\n\r\n      if ($event.sortField)\r\n        ordenacao = `${$event.sortField} ${$event.sortOrder === 1 ? 'ASC' : 'DESC'\r\n          }`;\r\n\r\n      const objeto: TablePaginate = {\r\n        paginaInicial: paginaInicial,\r\n        tamanhoPagina: $event.rows,\r\n        termoPesquisa: termoPesquisa,\r\n        ordenacao: ordenacao,\r\n      };\r\n\r\n      this.onPaginate.emit(objeto);\r\n    }\r\n  }\r\n\r\n  loadingSkeletonUtilities() {\r\n    if (this.dataSource().length === 0 && this.isLoadingSkeleton()) {\r\n      let rowItem: any = {};\r\n      this.config?.columns.forEach((col) => {\r\n        rowItem[col.field] = '';\r\n      });\r\n\r\n      this.dataSourceMock = Array.from({ length: this.rows }, () => ({\r\n        ...rowItem,\r\n        data: { ...(rowItem.data || {}) },\r\n        children: [{ ...(rowItem.data || {}) }]\r\n      }));\r\n\r\n      this.dataSource.set(this.dataSourceMock)\r\n    }\r\n  }\r\n\r\n\r\n  drop(event: CdkDragDrop<any>) {\r\n    const draggedNode = event.item.data;\r\n    const draggedChildData = draggedNode.node.data;\r\n\r\n    if (draggedNode.level === 0) {\r\n      moveItemInArray(this.dataSource(), event.previousIndex, event.currentIndex);\r\n    } else if (draggedNode.level >= 1) {\r\n      const parentNode = draggedNode.node.parent;\r\n\r\n      if (parentNode) {\r\n        const parentChildren = parentNode.children.map(\r\n          (child: any) => child.data\r\n        );\r\n        const previousChildIndex = parentChildren.indexOf(draggedChildData);\r\n\r\n        const relativeCurrentIndex =\r\n          previousChildIndex + (event.currentIndex - event.previousIndex);\r\n\r\n        const targetChildIndex = Math.max(\r\n          0,\r\n          Math.min(parentChildren.length - 1, relativeCurrentIndex)\r\n        );\r\n\r\n        if (previousChildIndex !== -1 && targetChildIndex !== -1) {\r\n          moveItemInArray(\r\n            parentNode.children,\r\n            previousChildIndex,\r\n            targetChildIndex\r\n          );\r\n        }\r\n        const dropInfo: any = {\r\n          previousChildIndex: previousChildIndex + 1,\r\n          targetChildIndex: targetChildIndex + 1,\r\n        };\r\n\r\n        this.onDropItem.emit({ event: event, dropChildInfo: dropInfo });\r\n      }\r\n    }\r\n\r\n    this.dataSource.set([...this.dataSource()]);\r\n\r\n    if (draggedNode.level === 0) {\r\n      this.onDropItem.emit(event);\r\n    }\r\n  }\r\n\r\n  sortTreeNodes(nodes: TreeNode[]): TreeNode[] {\r\n    return nodes\r\n      .sort((a, b) => a.data[this.ordenacao] - b.data[this.ordenacao])\r\n      .map((node) => {\r\n        if (node.children) {\r\n          node.children = this.sortTreeNodes(node.children);\r\n        }\r\n        return node;\r\n      });\r\n  }\r\n\r\n  // calculateTargetChildIndex(\r\n  //   event: CdkDragDrop<any>,\r\n  //   parentChildren: any[],\r\n  //   previousChildIndex: number\r\n  // ): number {\r\n  //   const targetChildIndex =\r\n  //     previousChildIndex + (event.currentIndex - event.previousIndex);\r\n\r\n  //   if (targetChildIndex < 0) {\r\n  //     return 0;\r\n  //   } else if (targetChildIndex >= parentChildren.length) {\r\n  //     return parentChildren.length - 1;\r\n  //   } else {\r\n  //     return targetChildIndex;\r\n  //   }\r\n  // }\r\n\r\n  doubleClick(e: any, rowData: any) {\r\n    let eventDoubleClick = { event: e, rowData: rowData };\r\n\r\n    let array: string[] = [];\r\n    e.target.classList.forEach((x: any) => array.push(x));\r\n\r\n    this.doubleClickEvent.emit(eventDoubleClick);\r\n  }\r\n\r\n  onNodeSelected(event: any) {\r\n    this.onNodeSelect.emit(event);\r\n  }\r\n\r\n  onNodeUnselected(event: any) {\r\n    this.onNodeUnselect.emit(event);\r\n  }\r\n\r\n  getCustomTemplate(templatename: string): TemplateRef<any> {\r\n    return this._templates[templatename];\r\n  }\r\n\r\n  getIcon(icon: string): string {\r\n    return icon.includes('pi-') ? `pi ${icon}` : '';\r\n  }\r\n\r\n  align(col: TableConfigColumn): string {\r\n    if (col.centralize) return 'justify-content-center';\r\n    else if (col.align == 'right') return 'justify-content-end';\r\n    else return '';\r\n  }\r\n\r\n  resetTreeTable() {\r\n    if (this.pTreeTable) this.pTreeTable.reset();\r\n    if (this.inputBusca) this.inputBusca.nativeElement.value = '';\r\n  }\r\n\r\n  setMaxHeightTreeTable() {\r\n    if (this.kvTreeTable()?.nativeElement.offsetHeight) {\r\n      const height = this.kvTreeTable()?.nativeElement.offsetHeight;\r\n      const element = this.elementRef.nativeElement.querySelector('.kv-treetable-container')\r\n      if (element) element.style.maxHeight = `${height}px`\r\n    }\r\n  }\r\n\r\n  criarMenusModal = computed(() => (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  validateActionPosition = computed(() => (rowNode: any) => {\r\n    if (this.config.actionsPai && rowNode.level == 0) return false;\r\n    else return true;\r\n  });\r\n\r\n  isSelectEnabled = computed(() => (rowData: any, rowNode: any) => {\r\n    return this.config.visibleCheckboxFunction\r\n      ? this.config.visibleCheckboxFunction(rowData, rowNode)\r\n      : true\r\n  });\r\n\r\n  isDisabledCheckbox = computed(() => (rowData: any, rowNode: any) => {\r\n    return this.config.disableControlCheckboxFunction\r\n      ? this.config.disableControlCheckboxFunction(rowData, rowNode)\r\n      : false;\r\n  });\r\n\r\n  validateShowTemplate = computed(() => (rowNode: any, col: any) => {\r\n    if (col.templateOnly) {\r\n      if (col.templateOnly === 'pai') {\r\n        return rowNode.level === 0;\r\n      }\r\n      if (col.templateOnly === 'filho') {\r\n        return rowNode.level === 1;\r\n      }\r\n    }\r\n    return true;\r\n  });\r\n\r\n  exibirCampo = computed(() => (field: any, rowData: any) => {\r\n    let visible = field.visible ? field.visible(rowData) : true;\r\n    return visible;\r\n  });\r\n}\r\n\r\n","<div class=\"kv-treetable-container\" #kvTreeTable>\r\n  <p-treeTable\r\n    #tt\r\n    cdkDropList\r\n    class=\"example-list\"\r\n    (cdkDropListDropped)=\"drop($event)\"\r\n    [value]=\"dataSource()\"\r\n    [columns]=\"config.columns\"\r\n    [resizableColumns]=\"true\"\r\n    [tableStyle]=\"{ 'min-width': '50rem' }\"\r\n    [resizableColumns]=\"true\"\r\n    [paginator]=\"paginator\"\r\n    [rows]=\"rows\"\r\n    [totalRecords]=\"totalRecords\"\r\n    [rowsPerPageOptions]=\"[5, 10, 15, 25, 50]\"\r\n    [showFirstLastIcon]=\"tamanhoTela() > 960 ? true : false\"\r\n    [pageLinks]=\"tamanhoTela() > 960 ? 2 : 1\"\r\n    [styleClass]=\"gridLines ? 'p-treetable-gridlines' : ''\"\r\n    [(selection)]=\"selectedItems\"\r\n    [selectionKeys]=\"selectionKeys()\"\r\n    (selectionKeysChange)=\"selectionKeys.set($event)\"\r\n    [lazy]=\"config.lazy\"\r\n    (onLazyLoad)=\"paginate($event)\"\r\n    (onNodeSelect)=\"onNodeSelected($event)\"\r\n    (onNodeUnselect)=\"onNodeUnselected($event)\"\r\n    [showCurrentPageReport]=\"true\"\r\n    currentPageReportTemplate=\"{first} - {last} de {totalRecords}\"\r\n    [scrollHeight]=\"scrollHeight\"\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 m-0 p-1\"\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\">{{ config.title }}</div>\r\n          } @if(config.subtitle) {\r\n          <div class=\"text-sm mb-4 font-medium\">{{ config.subtitle }}</div>\r\n          }\r\n        </div>\r\n\r\n        <div\r\n          class=\"flex flex-row align-items-center col-10 p-0 md:col-6 lg:col-4 justify-content-center {{\r\n            tamanhoTela() < 768 ? '' : 'input-search'\r\n          }}\"\r\n        >\r\n          @if(config.enableFilter) {\r\n\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(tt, $event)\"\r\n              placeholder=\"Pesquisar...\"\r\n              class=\"h-2rem\"\r\n              #inputBusca\r\n            />\r\n          </span>\r\n          }\r\n        </div>\r\n\r\n        <div class=\"flex flex-row col-1 justify-content-end p-0\">\r\n          <div class=\"flex flex-row gap-2 btns-options\">\r\n            @for (action of config.actionsLote; track $index) {\r\n            @if((selectedItems.length > 0 || action.showAcoesLote) &&\r\n            exibirCampo()(action, this.action)) {\r\n            <kv-button\r\n              (onClick)=\"action?.command(); activeItemLote(selectedItems)\"\r\n              [pTooltip]=\"getOrExecute(action.tooltip, selectedItems)\"\r\n              [tooltipPosition]=\"'bottom'\"\r\n              [size]=\"'small'\"\r\n              [disabled]=\"getOrExecute(action.disabled, selectedItems) || false\"\r\n              [icon]=\"getOrExecute(action.icon, selectedItems)\"\r\n              [severity]=\"action.severity || 'tertiary'\"\r\n            />\r\n            } }\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </ng-template>\r\n    } @if(showHeader){\r\n    <ng-template pTemplate=\"header\" let-columns>\r\n      <tr>\r\n        @for(col of columns; track $index){\r\n        <th\r\n          [ttSortableColumn]=\"col.field\"\r\n          [ttSortableColumnDisabled]=\"col.sortable === false\"\r\n          [style.width]=\"col.width\"\r\n        >\r\n          <div>\r\n            <div [ngClass]=\"{ flex: $index == 0, 'gap-3': $index == 0 }\">\r\n              @if($index == 0 && config.enableSelect) {\r\n              <p-treeTableHeaderCheckbox\r\n                (click)=\"activeItemLote(selectedItems)\"\r\n              />\r\n              }\r\n\r\n              <div class=\"flex flex-row align-items-center  {{ align(col) }}\">\r\n                <span class=\"text-xs\">{{ col.header }}</span>\r\n\r\n                @if(col.sortable) {\r\n                <p-treeTableSortIcon [field]=\"col.field\" class=\"pb-1\" />\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                >\r\n                  info\r\n                </span>\r\n                }\r\n              </div>\r\n            </div>\r\n          </div>\r\n        </th>\r\n        @if (config.actions?.length ?? 0 > 0 || config.actionsPai) {\r\n        <th [style.width]=\"5\"></th>\r\n        } }\r\n      </tr>\r\n    </ng-template>\r\n\r\n    <ng-template pTemplate=\"header\" let-columns>\r\n      <tr>\r\n        @for (col of columns; track $index) {\r\n        <th\r\n          [ttSortableColumn]=\"col.field\"\r\n          [ttSortableColumnDisabled]=\"col.sortable === false\"\r\n          [style.width]=\"col.width\"\r\n        >\r\n          <div class=\"flex flex-row align-items-center {{ align(col) }}\">\r\n            <span class=\"text-xs\">{{ col.header }}</span>\r\n\r\n            @if(col.sortable) {\r\n            <p-treeTableSortIcon [field]=\"col.field\" class=\"pb-1\" />\r\n            }\r\n          </div>\r\n        </th>\r\n        } @if (config.actions?.length ?? 0 > 0 || config.actionsPai) {\r\n        <th [style.width]=\"5\"></th>\r\n        }\r\n      </tr>\r\n    </ng-template>\r\n    }\r\n\r\n    <ng-template\r\n      pTemplate=\"body\"\r\n      let-rowNode\r\n      let-rowData=\"rowData\"\r\n      let-columns=\"columns\"\r\n    >\r\n      @if(isEmptyDataSource() && isLoadingSkeleton()) { @for(skeletonRow of\r\n      dataSource(); track $index) {\r\n      <tr>\r\n        @for(col of columns; track $index){\r\n        <td>\r\n          <div\r\n            class=\"flex flex-row align-items-center justify-content-center w-full\"\r\n          >\r\n            @if($index == 0) {\r\n            <p-treeTableToggler [rowNode]=\"rowNode\" />\r\n            }\r\n            <div class=\"flex flex-column w-full\">\r\n              <p-skeleton height=\"1rem\" />\r\n            </div>\r\n          </div>\r\n        </td>\r\n        }\r\n        <td>\r\n          <div class=\"flex justify-content-center\">\r\n            <p-skeleton [style]=\"{ height: '1.5rem', width: '1.5rem' }\" />\r\n          </div>\r\n        </td>\r\n      </tr>\r\n      } } @else { @if(treeTableDraggable) {\r\n      <tr\r\n        cdkDrag\r\n        cdkDragLockAxis=\"y\"\r\n        [cdkDragData]=\"rowNode\"\r\n        [ttRow]=\"rowNode\"\r\n        (dblclick)=\"doubleClick($event, rowData)\"\r\n        [ngClass]=\"{ capitalize: tableCaptalized }\"\r\n      >\r\n        @for(col of columns; track $index){\r\n        <td\r\n          class=\"draggable-cell\"\r\n          [style.position]=\"\r\n            !disableRowNodeSticky && rowNode.level !== 0 ? 'sticky' : null\r\n          \"\r\n        >\r\n          <!-- [style.left.px]=\"\r\n                   childrenRecoil && rowNode.level !== 0 ? rowNode.level * 30 : null\r\n                   \" -->\r\n\r\n          <div class=\"flex flex-row  {{ align(col) }}\">\r\n            @if($index == 0) {\r\n            <div class=\"w-full-h-full flex align-items-center\">\r\n              <span\r\n                class=\"material-symbols-outlined drag-icon\"\r\n                style=\"\r\n                  cursor: grab;\r\n                  font-size: 25px;\r\n                  color: #6b7280;\r\n                  opacity: 0.9;\r\n                \"\r\n                cdkDragHandle\r\n              >\r\n                drag_indicator\r\n              </span>\r\n              <p-treeTableToggler class=\"hiddenVisible\" [rowNode]=\"rowNode\" />\r\n\r\n              @if(config.enableSelect) {\r\n              <p-treeTableCheckbox\r\n                [disabled]=\"isDisabledCheckbox()(rowData, rowNode)\"\r\n                (click)=\"activeItemLote(selectedItems)\"\r\n                [value]=\"rowNode\"\r\n                [ngStyle]=\"{\r\n                  display: isSelectEnabled()(rowData, rowNode)\r\n                    ? 'block'\r\n                    : 'none',\r\n                  'margin-left': config.visibleCheckboxFunction\r\n                    ? '-34px'\r\n                    : '0px'\r\n                }\"\r\n              />\r\n              }\r\n            </div>\r\n            }\r\n\r\n            <div class=\"flex flex-row align-items-center w-full\">\r\n              @if (col.template && validateShowTemplate()(rowNode, col)) {\r\n              <span class=\"w-full\">\r\n                @if(getCustomTemplate(col.template.name)) {\r\n                <ng-container\r\n                  [ngTemplateOutlet]=\"getCustomTemplate(col.template.name)\"\r\n                  [ngTemplateOutletContext]=\"{ $implicit: rowData }\"\r\n                >\r\n                </ng-container>\r\n                }\r\n              </span>\r\n              } @else {\r\n              <div\r\n                class=\"flex flex-row align-items-center {{\r\n                  (col.boolean || col.centralize) && 'justify-content-center'\r\n                }} gap-2 w-full\"\r\n              >\r\n                @if(col.tagColor) {\r\n                <div\r\n                  class=\"tag\"\r\n                  [pTooltip]=\"\r\n                    col.tooltipTag &&\r\n                    col.tooltipTag(rowData, col, rowData[col.field])\r\n                  \"\r\n                  [style.background-color]=\"\r\n                    col.tagColor(rowData, col, rowData[col.field])\r\n                  \"\r\n                ></div>\r\n\r\n                } @if(col.boolean) {\r\n                <i\r\n                  class=\"pi {{\r\n                    rowData[col.field] ? 'pi-check text-green-300' : ''\r\n                  }}\"\r\n                  style=\"font-size: 1rem; font-weight: 700\"\r\n                ></i>\r\n\r\n                } @else {\r\n                <div class=\"flex flex-column\">\r\n                  <span class=\"m-0 text-xs\">{{ rowData[col.field] }}</span>\r\n\r\n                  @if(col.subtitle) {\r\n\r\n                  <p class=\"m-0 text-xs font-semibold\">\r\n                    {{ rowData[col.subtitle] }}\r\n                  </p>\r\n                  }\r\n                </div>\r\n                }\r\n              </div>\r\n              }\r\n            </div>\r\n          </div>\r\n        </td>\r\n        } @if((config.actions?.length ?? 0 > 0) || config.actionsPai) {\r\n        <td\r\n          style=\"border-left: none; text-align: center; width: 0\"\r\n          [style.borderRight]=\"rowNode.level === 0 ? 'none' : ''\"\r\n          [style.borderLeft]=\"rowNode.level === 0 ? 'none' : ''\"\r\n        >\r\n          @if((config.actions?.length ?? 0 > 0) &&\r\n          validateActionPosition()(rowNode)) {\r\n          <div class=\"flex align-items-center justify-content-center\">\r\n            <span\r\n              class=\"material-symbols-outlined cursor-pointer icon-more-horiz\"\r\n              style=\"font-size: 20px; padding: 0.1rem\"\r\n              (click)=\"menu.toggle($event); activeItem(rowData)\"\r\n            >\r\n              more_horiz\r\n            </span>\r\n\r\n            @for(action of config.actions; track $index) {\r\n            {{ criarMenusModal()(rowData) }}\r\n            }\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          } @if(config.actionsPai?.length ?? 0 > 0 && rowNode.level == 0){\r\n          <div class=\"flex justify-content-end align-items-center\">\r\n            @for (actionPai of config.actionsPai; track $index) {\r\n            @if(getOrExecute(actionPai.visible, rowData) ?? true) {\r\n            <kv-button\r\n              (onClick)=\"activeItem(rowData); actionPai.command($event)\"\r\n              [type]=\"'text'\"\r\n              [icon]=\"actionPai.icon\"\r\n              [severity]=\"actionPai.severity || 'tertiary'\"\r\n              [disabled]=\"getOrExecute(actionPai.disabled, rowData) || false\"\r\n              [pTooltip]=\"getOrExecute(actionPai.tooltip, rowData)\"\r\n              [tooltipPosition]=\"'left'\"\r\n            />\r\n\r\n            } }\r\n          </div>\r\n          }\r\n        </td>\r\n        }\r\n      </tr>\r\n      } @else {\r\n      <tr\r\n        [ttRow]=\"rowNode\"\r\n        (dblclick)=\"doubleClick($event, rowData)\"\r\n        [ngClass]=\"{ capitalize: tableCaptalized }\"\r\n      >\r\n        @for(col of columns; track $index){\r\n        <td\r\n          [style.position]=\"rowNode.level !== 0 ? 'sticky' : null\"\r\n          [style.left.px]=\"\r\n            childrenRecoil && rowNode.level !== 0 ? rowNode.level * 30 : null\r\n          \"\r\n          [style.borderRight]=\"rowNode.level === 0 ? 'none' : ''\"\r\n          [style.borderLeft]=\"\r\n            rowNode.level === 0 && col.field != config.columns[0].field\r\n              ? 'none'\r\n              : ''\r\n          \"\r\n        >\r\n          <div class=\"flex flex-row {{ align(col) }}\">\r\n            @if($index == 0) {\r\n            <div class=\"w-full-h-full flex align-items-center\">\r\n              <p-treeTableToggler class=\"hiddenVisible\" [rowNode]=\"rowNode\" />\r\n\r\n              @if(config.enableSelect) {\r\n              <p-treeTableCheckbox\r\n                [disabled]=\"isDisabledCheckbox()(rowData, rowNode)\"\r\n                (click)=\"activeItemLote(selectedItems)\"\r\n                [value]=\"rowNode\"\r\n                [ngStyle]=\"{\r\n                  display: isSelectEnabled()(rowData, rowNode)\r\n                    ? 'block'\r\n                    : 'none',\r\n                  'margin-left': config.visibleCheckboxFunction\r\n                    ? '-34px'\r\n                    : '0px'\r\n                }\"\r\n              />\r\n              }\r\n            </div>\r\n            }\r\n\r\n            <div class=\"flex flex-row align-items-center w-full\">\r\n              @if (col.template && validateShowTemplate()(rowNode, col)) {\r\n              <span class=\"w-full\">\r\n                @if(getCustomTemplate(col.template.name)) {\r\n\r\n                <ng-container\r\n                  [ngTemplateOutlet]=\"getCustomTemplate(col.template.name)\"\r\n                  [ngTemplateOutletContext]=\"{ $implicit: rowData }\"\r\n                >\r\n                </ng-container>\r\n                }\r\n              </span>\r\n              } @else {\r\n              <div\r\n                class=\"flex flex-row align-items-center {{\r\n                  (col.boolean || col.centralize) && 'justify-content-center'\r\n                }} gap-2 w-full\"\r\n              >\r\n                @if(col.tagColor) {\r\n\r\n                <div\r\n                  class=\"tag\"\r\n                  [pTooltip]=\"\r\n                    col.tooltipTag &&\r\n                    col.tooltipTag(rowData, col, rowData[col.field])\r\n                  \"\r\n                  [style.background-color]=\"\r\n                    col.tagColor(rowData, col, rowData[col.field])\r\n                  \"\r\n                ></div>\r\n\r\n                } @if(col.boolean) {\r\n\r\n                <i\r\n                  class=\"pi {{\r\n                    rowData[col.field] ? 'pi-check text-green-300' : ''\r\n                  }}\"\r\n                  style=\"font-size: 1rem; font-weight: 700\"\r\n                ></i>\r\n                } @else {\r\n                <div class=\"flex flex-column\">\r\n                  <span class=\"m-0 text-xs\">{{ rowData[col.field] }}</span>\r\n\r\n                  @if(col.subtitle) {\r\n\r\n                  <p class=\"m-0 text-xs font-semibold\">\r\n                    {{ rowData[col.subtitle] }}\r\n                  </p>\r\n                  }\r\n                </div>\r\n                }\r\n              </div>\r\n              }\r\n            </div>\r\n          </div>\r\n        </td>\r\n        } @if((config.actions?.length ?? 0 > 0) || config.actionsPai) {\r\n        <td style=\"border-left: none; text-align: center; width: 0\">\r\n          @if((config.actions?.length ?? 0 > 0) &&\r\n          validateActionPosition()(rowNode)) {\r\n          <div>\r\n            <span\r\n              class=\"material-symbols-outlined cursor-pointer icon-more-horiz\"\r\n              style=\"font-size: 20px; padding: 0.1rem\"\r\n              (click)=\"menu.toggle($event); activeItem(rowData)\"\r\n            >\r\n              more_horiz\r\n            </span>\r\n\r\n            @for(action of config.actions; track $index) {\r\n            {{ criarMenusModal()(rowData) }}\r\n            }\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          } @if(config.actionsPai?.length ?? 0 > 0 && rowNode.level == 0){\r\n          <div class=\"flex justify-content-end\">\r\n            @for (actionPai of config.actionsPai; track $index) { @if\r\n            (getOrExecute(actionPai.visible, rowData) ?? true) {\r\n            <kv-button\r\n              (onClick)=\"activeItem(rowData); actionPai.command($event)\"\r\n              [type]=\"'text'\"\r\n              [icon]=\"actionPai.icon\"\r\n              [severity]=\"actionPai.severity || 'tertiary'\"\r\n              [disabled]=\"getOrExecute(actionPai.disabled, rowData) || false\"\r\n              [pTooltip]=\"getOrExecute(actionPai.tooltip, rowData)\"\r\n              [tooltipPosition]=\"'left'\"\r\n            />\r\n            } }\r\n          </div>\r\n          }\r\n        </td>\r\n        }\r\n      </tr>\r\n      } }\r\n    </ng-template>\r\n\r\n    <ng-template pTemplate=\"emptymessage\">\r\n      <tr>\r\n        <td\r\n          [attr.colspan]=\"config.columns.length + 1\"\r\n          style=\"text-align: center\"\r\n          class=\"text-sm\"\r\n        >\r\n          {{ textoEmptyMessage }}\r\n        </td>\r\n      </tr>\r\n    </ng-template>\r\n  </p-treeTable>\r\n</div>\r\n"]}
|
|
@@ -2214,7 +2214,7 @@ class KvTreetableComponent {
|
|
|
2214
2214
|
this.dataSourceMock = Array.from({ length: this.rows }, () => ({
|
|
2215
2215
|
...rowItem,
|
|
2216
2216
|
data: { ...(rowItem.data || {}) },
|
|
2217
|
-
children: []
|
|
2217
|
+
children: [{ ...(rowItem.data || {}) }]
|
|
2218
2218
|
}));
|
|
2219
2219
|
this.dataSource.set(this.dataSourceMock);
|
|
2220
2220
|
}
|