cfc-ds
Version:
Design System do Conselho Federal de Contabilidade baseado no govbr-ds
221 lines • 42.7 kB
JavaScript
import { Component, EventEmitter, Input, Output, ContentChildren, } from '@angular/core';
import { ColumnTemplateDirective } from '../../directives/column-template.directive';
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
import * as i2 from "../icon/icon.component";
export class SortEvent {
key;
direction;
}
export class SimpleColumn {
key;
field;
label;
sortable = false;
customCell = false;
width;
constructor(key, label) {
this.key = key;
this.label = label;
this.field = key;
}
static fromArray(array) {
return array.map(item => new SimpleColumn(item.key, item.label).withCustomCell(item.customCell));
}
static column(key, label) {
return new SimpleColumn(key, label);
}
static custom(key, label) {
return new SimpleColumn(key, label).withCustomCell(true);
}
static sortable(key, label, field = 'id') {
return new SimpleColumn(key, label).withSortable(true).withField(field);
}
static action() {
return new SimpleColumn('actions', 'Ações').withCustomCell(true).withSortable(false);
}
withField(field) {
this.field = field;
return this;
}
withSortable(sortable = false) {
this.sortable = sortable;
return this;
}
withCustomCell(customCell = false) {
this.customCell = customCell;
return this;
}
withWidth(width) {
this.width = width;
return this;
}
}
export class TableComponent {
columns;
lines;
customTable;
pagination = { totalElements: 0 };
hasCheckbox = false;
noItensMessage = '';
sortable = false;
emptyMessageTitle = 'Nenhum item encontrado';
emptyMessageDescription = 'Não foi possível encontrar nenhum item com os critérios de busca atuais.';
emptyMessageIcon = 'clipboard';
selectedLines = new EventEmitter();
listActions = [];
selectLines = [];
filteredModule;
sort = new EventEmitter();
sortKey = null;
sortDirection = 'asc';
onItensPerPageChange = new EventEmitter();
onPageChange = new EventEmitter();
templates;
internalTemplates;
get allTemplates() {
return [...this.internalTemplates, ...(this.templates || [])];
}
ngOnInit() {
}
ngAfterViewInit() {
this.initializeTable();
}
initializeTable() {
const tableList = [];
const tables = Array.from(window.document.querySelectorAll('.br-table'));
for (const [index, brTable] of tables.entries()) {
tableList.push(new window.core.BRTable('br-table', brTable, index));
}
}
getNestedValue(obj, path) {
return path.split('.').reduce((acc, part) => acc && acc[part], obj);
}
selectAllCheckbox() {
const mainCheckbox = document.querySelector('.checked-all');
const checkboxes = document.querySelectorAll('.checkbox-item');
const bar = document.querySelector('.selected-bar');
const countElement = document.querySelector('.count');
const textElement = document.querySelector('.text');
if (mainCheckbox.checked) {
if (countElement) {
countElement.innerHTML = String(checkboxes.length);
}
if (textElement) {
textElement.innerHTML = String('itens selecionados');
}
if (bar) {
bar.classList.add('show');
}
}
else {
if (countElement) {
countElement.innerHTML = String(0);
}
if (bar) {
bar.classList.remove('show');
}
}
checkboxes.forEach((checkbox) => {
if (checkbox instanceof HTMLInputElement) {
checkbox.checked = mainCheckbox.checked;
const tr = checkbox.closest('tr');
if (tr) {
tr.classList.toggle('is-selected', checkbox.checked);
}
}
});
if (this.selectLines.length > 0) {
this.selectLines = [];
}
this.lines.forEach((line) => {
if (mainCheckbox.checked) {
this.selectLines.push(line);
}
else {
const itemIndex = this.selectLines.indexOf(line);
this.selectLines.splice(itemIndex, 1);
}
});
console.log(this.selectLines);
}
selectCheckbox(line) {
const mainCheckbox = document.querySelector('.checked-all');
const bar = document.querySelector('.selected-bar');
if (bar) {
bar.classList.add('show');
}
mainCheckbox.checked = false;
const itemIndex = this.selectLines.indexOf(line);
if (itemIndex > -1) {
this.selectLines.splice(itemIndex, 1);
}
else {
this.selectLines.push(line);
}
this.selectedLines.emit(this.selectLines);
console.log(this.selectLines);
}
onSort(column) {
if (this.sortKey === column.key) {
this.sortDirection = this.sortDirection === 'asc' ? 'desc' : this.sortDirection === 'desc' ? '' : 'asc';
}
else {
this.sortKey = column.key;
this.sortDirection = 'asc';
}
this.sort.emit({ key: column.key, direction: this.sortDirection });
}
getTemplate(key) {
const template = this.allTemplates.find(t => t.key === key);
return template ? template.templateRef : null;
}
get disabledActions() {
const countElement = document.querySelector('.count');
const countValue = parseInt(countElement?.textContent || '0');
if (countValue >= 2) {
return true;
}
return false;
}
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: TableComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: TableComponent, selector: "cfc-table", inputs: { columns: "columns", lines: "lines", customTable: "customTable", pagination: "pagination", hasCheckbox: "hasCheckbox", noItensMessage: "noItensMessage", sortable: "sortable", emptyMessageTitle: "emptyMessageTitle", emptyMessageDescription: "emptyMessageDescription", emptyMessageIcon: "emptyMessageIcon", templates: "templates" }, outputs: { selectedLines: "selectedLines", sort: "sort", onItensPerPageChange: "onItensPerPageChange", onPageChange: "onPageChange" }, queries: [{ propertyName: "internalTemplates", predicate: ColumnTemplateDirective, descendants: true }], ngImport: i0, template: "<div class=\"br-table\" data-selection=\"data-selection\">\r\n <div class=\"table-header\">\r\n <div class=\"selected-bar\">\r\n <div class=\"info\">\r\n <span class=\"count\">0</span><span class=\"text\">item selecionado</span>\r\n </div>\r\n </div>\r\n </div>\r\n <table>\r\n\r\n <thead>\r\n <tr>\r\n @if(hasCheckbox){\r\n <th class=\"column-checkbox\" scope=\"col\">\r\n <div class=\"br-checkbox hidden-label\">\r\n <input\r\n id=\"check-all-90050\"\r\n name=\"check-all-90050\"\r\n type=\"checkbox\"\r\n aria-label=\"Selecionar tudo\"\r\n data-parent=\"check-01-90050\"\r\n class=\"checked-all\"\r\n (change)=\"selectAllCheckbox()\"\r\n />\r\n <label for=\"check-all-90050\">Selecionar todas as linhas</label>\r\n </div>\r\n </th>\r\n } @for (column of columns; track $index) {\r\n\r\n <th\r\n scope=\"col\"\r\n (click)=\"sortable ? onSort(column) : null\"\r\n [className]=\"column.customCell ? 'sortable' : ''\"\r\n [style.width]=\"column.width\"\r\n >\r\n {{ column.label }}\r\n <span *ngIf=\"column.key === sortKey\">\r\n {{\r\n sortDirection === \"asc\"\r\n ? \"\u2191\"\r\n : sortDirection === \"desc\"\r\n ? \"\u2193\"\r\n : \"\"\r\n }}\r\n </span>\r\n </th>\r\n }\r\n </tr>\r\n </thead>\r\n @if (!!lines && lines.length > 0) {\r\n <tbody>\r\n @for (line of lines; track $index) {\r\n <tr>\r\n @if(hasCheckbox){\r\n <td>\r\n <div class=\"br-checkbox hidden-label\">\r\n <input\r\n [attr.id]=\"'check-line-' + $index + '-90050'\"\r\n [attr.name]=\"'check-line-' + $index + '-90050'\"\r\n type=\"checkbox\"\r\n [attr.aria-label]=\"'Selecionar linha' + $index\"\r\n data-child=\"check-01-90050\"\r\n class=\"checkbox-item\"\r\n (change)=\"selectCheckbox(line)\"\r\n />\r\n <label [attr.for]=\"'check-line-' + $index + '-90050'\"\r\n >Selecionar linha {{ $index }}</label\r\n >\r\n </div>\r\n </td>\r\n }\r\n\r\n @for (column of columns; track $index) {\r\n <td [attr.data-th]=\"column.label + $index\">\r\n\r\n @if(getTemplate(column.key)){\r\n <ng-container>\r\n <ng-template\r\n [ngTemplateOutlet]=\"getTemplate(column.key)\"\r\n [ngTemplateOutletContext]=\"{\r\n line: line,\r\n value: line[column.key],\r\n index: $index,\r\n column: column\r\n }\"\r\n />\r\n </ng-container>\r\n\r\n }\r\n @else if(column.customCell){\r\n<!-- MATEM COMPATIBILIDADE COM A PRIMEIRA VERSAO -->\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n customTable;\r\n context: {\r\n $implicit: line,\r\n item: line,\r\n column: column,\r\n urlActionBase: filteredModule?.urlBase,\r\n disabled: disabledActions\r\n }\r\n \"\r\n ></ng-container>\r\n\r\n } @else {\r\n <ng-container >\r\n {{ getNestedValue(line, column.key) }}\r\n </ng-container>\r\n }\r\n </td>\r\n }\r\n </tr>\r\n }\r\n </tbody>\r\n } @if(!!lines && lines.length === 0 && !!noItensMessage) {\r\n <tr>\r\n <td [colSpan]=\"columns.length\">\r\n {{ noItensMessage }}\r\n </td>\r\n </tr>\r\n }\r\n </table>\r\n @if(!!lines && lines.length === 0) {\r\n <div class=\"empty-state\">\r\n <cfc-icon [iconName]=\"emptyMessageIcon\" size=\"60px\" class=\"mb-3\"></cfc-icon>\r\n <p class=\"text-base text-weight-semi-bold mb-baseh\">{{ emptyMessageTitle }}</p>\r\n <p class=\"m-0\">{{ emptyMessageDescription }}</p>\r\n </div>\r\n }\r\n\r\n</div>\r\n\r\n", styles: [".message{display:flex;flex-direction:column;justify-content:center;align-items:center}.message i{font-size:32px}thead th{background-color:#f0f0f0!important;color:#1351b4;width:auto}thead th[scope=col]{cursor:default}thead th.sortable[scope=col],tbody tr{cursor:pointer}.row-selected{background-color:#1351b4}.row-selected td{color:#fff}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding-top:48px}.br-table table{width:100%;table-layout:auto}.br-table th,.br-table td{width:auto;white-space:nowrap}.br-table th[style*=width],.br-table td[style*=width]{white-space:normal}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.IconComponent, selector: "cfc-icon", inputs: ["iconName", "familyName", "className", "size", "color"] }] });
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: TableComponent, decorators: [{
type: Component,
args: [{ selector: 'cfc-table', template: "<div class=\"br-table\" data-selection=\"data-selection\">\r\n <div class=\"table-header\">\r\n <div class=\"selected-bar\">\r\n <div class=\"info\">\r\n <span class=\"count\">0</span><span class=\"text\">item selecionado</span>\r\n </div>\r\n </div>\r\n </div>\r\n <table>\r\n\r\n <thead>\r\n <tr>\r\n @if(hasCheckbox){\r\n <th class=\"column-checkbox\" scope=\"col\">\r\n <div class=\"br-checkbox hidden-label\">\r\n <input\r\n id=\"check-all-90050\"\r\n name=\"check-all-90050\"\r\n type=\"checkbox\"\r\n aria-label=\"Selecionar tudo\"\r\n data-parent=\"check-01-90050\"\r\n class=\"checked-all\"\r\n (change)=\"selectAllCheckbox()\"\r\n />\r\n <label for=\"check-all-90050\">Selecionar todas as linhas</label>\r\n </div>\r\n </th>\r\n } @for (column of columns; track $index) {\r\n\r\n <th\r\n scope=\"col\"\r\n (click)=\"sortable ? onSort(column) : null\"\r\n [className]=\"column.customCell ? 'sortable' : ''\"\r\n [style.width]=\"column.width\"\r\n >\r\n {{ column.label }}\r\n <span *ngIf=\"column.key === sortKey\">\r\n {{\r\n sortDirection === \"asc\"\r\n ? \"\u2191\"\r\n : sortDirection === \"desc\"\r\n ? \"\u2193\"\r\n : \"\"\r\n }}\r\n </span>\r\n </th>\r\n }\r\n </tr>\r\n </thead>\r\n @if (!!lines && lines.length > 0) {\r\n <tbody>\r\n @for (line of lines; track $index) {\r\n <tr>\r\n @if(hasCheckbox){\r\n <td>\r\n <div class=\"br-checkbox hidden-label\">\r\n <input\r\n [attr.id]=\"'check-line-' + $index + '-90050'\"\r\n [attr.name]=\"'check-line-' + $index + '-90050'\"\r\n type=\"checkbox\"\r\n [attr.aria-label]=\"'Selecionar linha' + $index\"\r\n data-child=\"check-01-90050\"\r\n class=\"checkbox-item\"\r\n (change)=\"selectCheckbox(line)\"\r\n />\r\n <label [attr.for]=\"'check-line-' + $index + '-90050'\"\r\n >Selecionar linha {{ $index }}</label\r\n >\r\n </div>\r\n </td>\r\n }\r\n\r\n @for (column of columns; track $index) {\r\n <td [attr.data-th]=\"column.label + $index\">\r\n\r\n @if(getTemplate(column.key)){\r\n <ng-container>\r\n <ng-template\r\n [ngTemplateOutlet]=\"getTemplate(column.key)\"\r\n [ngTemplateOutletContext]=\"{\r\n line: line,\r\n value: line[column.key],\r\n index: $index,\r\n column: column\r\n }\"\r\n />\r\n </ng-container>\r\n\r\n }\r\n @else if(column.customCell){\r\n<!-- MATEM COMPATIBILIDADE COM A PRIMEIRA VERSAO -->\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n customTable;\r\n context: {\r\n $implicit: line,\r\n item: line,\r\n column: column,\r\n urlActionBase: filteredModule?.urlBase,\r\n disabled: disabledActions\r\n }\r\n \"\r\n ></ng-container>\r\n\r\n } @else {\r\n <ng-container >\r\n {{ getNestedValue(line, column.key) }}\r\n </ng-container>\r\n }\r\n </td>\r\n }\r\n </tr>\r\n }\r\n </tbody>\r\n } @if(!!lines && lines.length === 0 && !!noItensMessage) {\r\n <tr>\r\n <td [colSpan]=\"columns.length\">\r\n {{ noItensMessage }}\r\n </td>\r\n </tr>\r\n }\r\n </table>\r\n @if(!!lines && lines.length === 0) {\r\n <div class=\"empty-state\">\r\n <cfc-icon [iconName]=\"emptyMessageIcon\" size=\"60px\" class=\"mb-3\"></cfc-icon>\r\n <p class=\"text-base text-weight-semi-bold mb-baseh\">{{ emptyMessageTitle }}</p>\r\n <p class=\"m-0\">{{ emptyMessageDescription }}</p>\r\n </div>\r\n }\r\n\r\n</div>\r\n\r\n", styles: [".message{display:flex;flex-direction:column;justify-content:center;align-items:center}.message i{font-size:32px}thead th{background-color:#f0f0f0!important;color:#1351b4;width:auto}thead th[scope=col]{cursor:default}thead th.sortable[scope=col],tbody tr{cursor:pointer}.row-selected{background-color:#1351b4}.row-selected td{color:#fff}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding-top:48px}.br-table table{width:100%;table-layout:auto}.br-table th,.br-table td{width:auto;white-space:nowrap}.br-table th[style*=width],.br-table td[style*=width]{white-space:normal}\n"] }]
}], propDecorators: { columns: [{
type: Input
}], lines: [{
type: Input
}], customTable: [{
type: Input
}], pagination: [{
type: Input
}], hasCheckbox: [{
type: Input
}], noItensMessage: [{
type: Input
}], sortable: [{
type: Input
}], emptyMessageTitle: [{
type: Input
}], emptyMessageDescription: [{
type: Input
}], emptyMessageIcon: [{
type: Input
}], selectedLines: [{
type: Output
}], sort: [{
type: Output
}], onItensPerPageChange: [{
type: Output
}], onPageChange: [{
type: Output
}], templates: [{
type: Input
}], internalTemplates: [{
type: ContentChildren,
args: [ColumnTemplateDirective, { descendants: true }]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../../projects/cfc-ds/src/lib/components/table/table.component.ts","../../../../../../projects/cfc-ds/src/lib/components/table/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  TemplateRef,\r\n  QueryList,\r\n  ContentChildren,\r\n} from '@angular/core';\r\nimport { Router } from '@angular/router';\r\nimport { Columns } from '../../models/table.model';\r\nimport { ColumnTemplateDirective } from '../../directives/column-template.directive';\r\n\r\n\r\nexport class SortEvent {\r\n  key!: string;\r\n  direction!: '' | 'asc' | 'desc';\r\n}\r\n\r\nexport class SimpleColumn {\r\n  key: string;\r\n  field: string;\r\n  label: string;\r\n  sortable: boolean = false;\r\n  customCell: boolean = false;\r\n  width?: string;\r\n\r\n  constructor(key: string, label: string) {\r\n    this.key = key;\r\n    this.label = label;\r\n    this.field = key;\r\n  }\r\n\r\n  static fromArray(array: { key: string, label: string, customCell?: boolean }[]): SimpleColumn[] {\r\n    return array.map(item => new SimpleColumn(item.key, item.label).withCustomCell(item.customCell));\r\n  }\r\n\r\n  static column(key: string, label: string): SimpleColumn {\r\n    return new SimpleColumn(key, label);\r\n  }\r\n\r\n  static custom(key: string, label: string): SimpleColumn {\r\n    return new SimpleColumn(key, label).withCustomCell(true);\r\n  }\r\n\r\n  static sortable(key: string, label: string, field: string = 'id'): SimpleColumn {\r\n    return new SimpleColumn(key, label).withSortable(true).withField(field);\r\n  }\r\n\r\n  static action(): SimpleColumn {\r\n    return new SimpleColumn('actions', 'Ações').withCustomCell(true).withSortable(false);\r\n  }\r\n\r\n  withField(field: string): SimpleColumn {\r\n    this.field = field;\r\n    return this;\r\n  }\r\n\r\n  withSortable(sortable: boolean = false): SimpleColumn {\r\n    this.sortable = sortable;\r\n    return this;\r\n  }\r\n\r\n  withCustomCell(customCell: boolean = false): SimpleColumn {\r\n    this.customCell = customCell;\r\n    return this;\r\n  }\r\n\r\n  withWidth(width: string): SimpleColumn {\r\n    this.width = width;\r\n    return this;\r\n  }\r\n}\r\n\r\n@Component({\r\n  selector: 'cfc-table',\r\n  templateUrl: './table.component.html',\r\n  styleUrl: './table.component.scss',\r\n})\r\nexport class TableComponent implements OnInit, AfterViewInit {\r\n  @Input() columns!: Columns[];\r\n  @Input() lines!: any;\r\n  @Input() customTable!: TemplateRef<any>;\r\n  @Input() pagination: any = { totalElements: 0 };\r\n  @Input() hasCheckbox: boolean = false;\r\n  @Input() noItensMessage: string = '';\r\n  @Input() sortable: boolean = false;\r\n  @Input() emptyMessageTitle: string = 'Nenhum item encontrado';\r\n  @Input() emptyMessageDescription: string = 'Não foi possível encontrar nenhum item com os critérios de busca atuais.';\r\n  @Input() emptyMessageIcon: string = 'clipboard';\r\n  @Output() selectedLines = new EventEmitter();\r\n\r\n\r\n  listActions = [];\r\n  selectLines: any[] = [];\r\n  filteredModule: any;\r\n\r\n  @Output() sort = new EventEmitter<SortEvent>();\r\n\r\n  sortKey: string | null = null;\r\n  sortDirection: 'asc' | 'desc' | '' = 'asc';\r\n\r\n  @Output() onItensPerPageChange = new EventEmitter<number>();\r\n  @Output() onPageChange = new EventEmitter<number>();\r\n\r\n  @Input() templates?: QueryList<ColumnTemplateDirective>;\r\n\r\n\r\n  @ContentChildren(ColumnTemplateDirective, { descendants: true })\r\n  internalTemplates!: QueryList<ColumnTemplateDirective>;\r\n\r\n  get allTemplates(): ColumnTemplateDirective[] {\r\n    return [...this.internalTemplates, ...(this.templates || [])];\r\n  }\r\n\r\n  ngOnInit(): void {\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.initializeTable();\r\n  }\r\n\r\n  initializeTable(): void {\r\n    const tableList = [];\r\n    const tables = Array.from(window.document.querySelectorAll('.br-table'));\r\n\r\n    for (const [index, brTable] of tables.entries()) {\r\n      tableList.push(\r\n        new (window as any).core.BRTable('br-table', brTable, index)\r\n      );\r\n    }\r\n  }\r\n\r\n  getNestedValue(obj: any, path: string): any {\r\n    return path.split('.').reduce((acc, part) => acc && acc[part], obj);\r\n  }\r\n\r\n\r\n  selectAllCheckbox() {\r\n    const mainCheckbox = document.querySelector(\r\n      '.checked-all'\r\n    ) as HTMLInputElement;\r\n    const checkboxes = document.querySelectorAll('.checkbox-item');\r\n    const bar = document.querySelector('.selected-bar');\r\n    const countElement = document.querySelector('.count');\r\n    const textElement = document.querySelector('.text');\r\n    if (mainCheckbox.checked) {\r\n      if (countElement) {\r\n        countElement.innerHTML = String(checkboxes.length);\r\n      }\r\n      if (textElement) {\r\n        textElement.innerHTML = String('itens selecionados');\r\n      }\r\n      if (bar) {\r\n        bar.classList.add('show');\r\n      }\r\n    } else {\r\n      if (countElement) {\r\n        countElement.innerHTML = String(0);\r\n      }\r\n      if (bar) {\r\n        bar.classList.remove('show');\r\n      }\r\n    }\r\n\r\n    checkboxes.forEach((checkbox) => {\r\n      if (checkbox instanceof HTMLInputElement) {\r\n        checkbox.checked = mainCheckbox.checked;\r\n        const tr = checkbox.closest('tr');\r\n        if (tr) {\r\n          tr.classList.toggle('is-selected', checkbox.checked);\r\n        }\r\n      }\r\n    });\r\n\r\n    if (this.selectLines.length > 0) {\r\n      this.selectLines = [];\r\n    }\r\n\r\n    this.lines.forEach((line: any) => {\r\n      if (mainCheckbox.checked) {\r\n        this.selectLines.push(line);\r\n      } else {\r\n        const itemIndex = this.selectLines.indexOf(line);\r\n        this.selectLines.splice(itemIndex, 1);\r\n      }\r\n    });\r\n    console.log(this.selectLines);\r\n  }\r\n\r\n  selectCheckbox(line: any) {\r\n    const mainCheckbox = document.querySelector(\r\n      '.checked-all'\r\n    ) as HTMLInputElement;\r\n    const bar = document.querySelector('.selected-bar');\r\n    if (bar) {\r\n      bar.classList.add('show');\r\n    }\r\n    mainCheckbox.checked = false;\r\n    const itemIndex = this.selectLines.indexOf(line);\r\n    if (itemIndex > -1) {\r\n      this.selectLines.splice(itemIndex, 1);\r\n    } else {\r\n      this.selectLines.push(line);\r\n    }\r\n    this.selectedLines.emit(this.selectLines);\r\n    console.log(this.selectLines);\r\n  }\r\n\r\n  onSort(column: Columns): void {\r\n    if (this.sortKey === column.key) {\r\n      this.sortDirection = this.sortDirection === 'asc' ? 'desc' : this.sortDirection === 'desc' ? '' : 'asc';\r\n    } else {\r\n      this.sortKey = column.key;\r\n      this.sortDirection = 'asc';\r\n    }\r\n\r\n    this.sort.emit({ key: column.key, direction: this.sortDirection });\r\n  }\r\n\r\n  getTemplate(key: string): TemplateRef<any> | null {\r\n    const template = this.allTemplates.find(t => t.key === key);\r\n    return template ? template.templateRef : null;\r\n  }\r\n\r\n  get disabledActions() {\r\n    const countElement = document.querySelector('.count');\r\n    const countValue = parseInt(countElement?.textContent || '0');\r\n    if (countValue >= 2) {\r\n      return true;\r\n    }\r\n    return false;\r\n  }\r\n}\r\n","<div class=\"br-table\" data-selection=\"data-selection\">\r\n  <div class=\"table-header\">\r\n    <div class=\"selected-bar\">\r\n      <div class=\"info\">\r\n        <span class=\"count\">0</span><span class=\"text\">item selecionado</span>\r\n      </div>\r\n    </div>\r\n  </div>\r\n  <table>\r\n\r\n    <thead>\r\n      <tr>\r\n        @if(hasCheckbox){\r\n        <th class=\"column-checkbox\" scope=\"col\">\r\n          <div class=\"br-checkbox hidden-label\">\r\n            <input\r\n              id=\"check-all-90050\"\r\n              name=\"check-all-90050\"\r\n              type=\"checkbox\"\r\n              aria-label=\"Selecionar tudo\"\r\n              data-parent=\"check-01-90050\"\r\n              class=\"checked-all\"\r\n              (change)=\"selectAllCheckbox()\"\r\n            />\r\n            <label for=\"check-all-90050\">Selecionar todas as linhas</label>\r\n          </div>\r\n        </th>\r\n        } @for (column of columns; track $index) {\r\n\r\n        <th\r\n          scope=\"col\"\r\n          (click)=\"sortable ? onSort(column) : null\"\r\n          [className]=\"column.customCell ? 'sortable' : ''\"\r\n          [style.width]=\"column.width\"\r\n        >\r\n          {{ column.label }}\r\n          <span *ngIf=\"column.key === sortKey\">\r\n            {{\r\n              sortDirection === \"asc\"\r\n                ? \"↑\"\r\n                : sortDirection === \"desc\"\r\n                ? \"↓\"\r\n                : \"\"\r\n            }}\r\n          </span>\r\n        </th>\r\n        }\r\n      </tr>\r\n    </thead>\r\n     @if (!!lines && lines.length > 0) {\r\n    <tbody>\r\n      @for (line of lines; track $index) {\r\n      <tr>\r\n        @if(hasCheckbox){\r\n        <td>\r\n          <div class=\"br-checkbox hidden-label\">\r\n            <input\r\n              [attr.id]=\"'check-line-' + $index + '-90050'\"\r\n              [attr.name]=\"'check-line-' + $index + '-90050'\"\r\n              type=\"checkbox\"\r\n              [attr.aria-label]=\"'Selecionar linha' + $index\"\r\n              data-child=\"check-01-90050\"\r\n              class=\"checkbox-item\"\r\n              (change)=\"selectCheckbox(line)\"\r\n            />\r\n            <label [attr.for]=\"'check-line-' + $index + '-90050'\"\r\n              >Selecionar linha {{ $index }}</label\r\n            >\r\n          </div>\r\n        </td>\r\n        }\r\n\r\n        @for (column of columns; track $index) {\r\n        <td [attr.data-th]=\"column.label + $index\">\r\n\r\n          @if(getTemplate(column.key)){\r\n            <ng-container>\r\n              <ng-template\r\n                [ngTemplateOutlet]=\"getTemplate(column.key)\"\r\n                [ngTemplateOutletContext]=\"{\r\n                  line: line,\r\n                  value: line[column.key],\r\n                  index: $index,\r\n                  column: column\r\n                }\"\r\n              />\r\n            </ng-container>\r\n\r\n          }\r\n          @else if(column.customCell){\r\n<!-- MATEM COMPATIBILIDADE COM A PRIMEIRA VERSAO -->\r\n            <ng-container\r\n            *ngTemplateOutlet=\"\r\n              customTable;\r\n              context: {\r\n                $implicit: line,\r\n                item: line,\r\n                column: column,\r\n                urlActionBase: filteredModule?.urlBase,\r\n                disabled: disabledActions\r\n              }\r\n            \"\r\n          ></ng-container>\r\n\r\n          } @else {\r\n            <ng-container >\r\n              {{ getNestedValue(line, column.key) }}\r\n            </ng-container>\r\n          }\r\n        </td>\r\n        }\r\n      </tr>\r\n      }\r\n    </tbody>\r\n    } @if(!!lines && lines.length === 0 && !!noItensMessage) {\r\n    <tr>\r\n      <td [colSpan]=\"columns.length\">\r\n        {{ noItensMessage }}\r\n      </td>\r\n    </tr>\r\n    }\r\n  </table>\r\n  @if(!!lines && lines.length === 0) {\r\n   <div class=\"empty-state\">\r\n   <cfc-icon [iconName]=\"emptyMessageIcon\" size=\"60px\" class=\"mb-3\"></cfc-icon>\r\n   <p class=\"text-base text-weight-semi-bold mb-baseh\">{{ emptyMessageTitle }}</p>\r\n   <p class=\"m-0\">{{ emptyMessageDescription }}</p>\r\n   </div>\r\n  }\r\n\r\n</div>\r\n\r\n"]}