@sapphire-ion/framework 1.2.58 → 1.2.59

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.
@@ -75,17 +75,17 @@ export class DefaultTableComponent {
75
75
  });
76
76
  }
77
77
  Redirect(field, item) {
78
- this.itemClick.emit({ item, field });
79
- if (!field) {
78
+ if (field == null) {
80
79
  return;
81
80
  }
82
- else if (field.index == 'ativo') {
81
+ this.itemClick.emit({ item, field });
82
+ if (field.index == 'ativo') {
83
83
  return;
84
84
  }
85
- else if (field.type == 'File') {
85
+ if (field.type == 'File') {
86
86
  return;
87
87
  }
88
- else if (this.itemPath()) {
88
+ if (this.itemPath()) {
89
89
  const id = item['id'];
90
90
  const path = this.itemPath().replace(":id", id.toString());
91
91
  this.router.navigate([`./${path}`], { relativeTo: this.activatedRoute });
@@ -213,4 +213,4 @@ class AvailableTableField {
213
213
  this.descending = descending;
214
214
  }
215
215
  }
216
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"default-table.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/default/default-table/default-table.component.ts","../../../../../../src/lib/components/default/default-table/default-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { formatNumber } from '@angular/common';\r\nimport { Component, computed, effect, Input, input, InputSignal, model, ModelSignal, OnInit, output, OutputEmitterRef, OutputRef, Signal, TemplateRef } from '@angular/core';\r\nimport { ActivatedRoute, Router } from '@angular/router';\r\n\r\nimport { InputDecimalConfiguration } from '../../inputs/input-decimal/input-decimal.configuration';\r\nimport { InputSelectConfiguration } from '../../inputs/input-select/input.select.configuration';\r\nimport { FormatTelefoneCelular } from '../../inputs/input-telefone/input-telefone.component';\r\nimport { StorageService } from '../../../services/web/storage.service';\r\nimport { FormatCpfCnpj } from '../../inputs/input-cpf-cnpj/input-cpf-cnpj.component';\r\nimport { HttpService } from '../../../services/web/http.service'\r\nimport { TableField } from '../../../classes/inputs/table-field';\r\nimport { Comparison, CompileLstTableField } from '../../../classes/comparison/comparison';\r\nimport { FormatCep } from '../../inputs/input-cep/input-cep.component';\r\nimport { InputType } from '../../inputs/input-type';\r\nimport { Utils } from '../../../services/utils.service';\r\n\r\ntype CSSStyleStringGenerator = (index: string, object: any) => string;\r\n\r\n@Component({\r\n  selector: 'default-table',\r\n  templateUrl: './default-table.component.html',\r\n  styleUrls: ['./default-table.component.scss'],\r\n})\r\nexport class DefaultTableComponent<Service extends HttpService, T = any> implements OnInit {\r\n\r\n  @Input() acoesTemplate: TemplateRef<any>;\r\n  /** Template de ações, deve ser um elemento ```<ng-template>``` */\r\n  // acoesTemplate: InputSignal<TemplateRef<any>> = input<TemplateRef<any>>();\r\n\r\n  /** Service a ser utilizado na listagem */\r\n  service: InputSignal<Service> = input<Service>();\r\n\r\n  total: ModelSignal<number> = model<number>(0);\r\n\r\n  /** Número de items máximo (usando two way data binding) */\r\n  limit: ModelSignal<number> = model<number>();\r\n\r\n  /** Valor da pagina, setado = 1 quando troca-se o valor de limite de paginas (usando two way data binding) */\r\n  page: ModelSignal<number> = model<number>(1);\r\n\r\n  /** Propriedade de ordenação (usando two way data binding) */\r\n  orderByProperty: ModelSignal<string | null> = model<string | null>(null);\r\n    \r\n  /** Propriedade de ordenação\r\n   * Se = true  Ordenará de menor ao maior \r\n   * Se = false Ordenará de maior ao menor (usando two way data binding) */\r\n  ascending: ModelSignal<boolean> = model<boolean>(true);\r\n\r\n  /** Filtros (usando two way data binding) */ \r\n  filter: ModelSignal<Comparison[]> = model<Comparison[]>([]);\r\n\r\n  /** Evento emitido quando um dos dados é ativado. Emite o id do dado */  \r\n  ativar : OutputEmitterRef<number> = output<number>();\r\n  refresh: OutputEmitterRef<void> = output<void>();\r\n\r\n\r\n  loading: ModelSignal<boolean> = model<boolean>(false);\r\n\r\n  /** Lista de dados a ser exibidos */\r\n  items: ModelSignal<T[]> = model<T[]>([]);\r\n\r\n  /** Lista de campos a ser exibidos */\r\n  lstTableFields: ModelSignal<TableField[]> = model<TableField[]>([]);\r\n  lstTableFieldsAvailable: Signal<AvailableTableField[]> = computed<AvailableTableField[]>(() => { \r\n    return this.lstTableFields().filter(p => !p.hidden).map(tf => {\r\n      return new AvailableTableField(\r\n        tf, \r\n        this.ascending() && this.orderByProperty() == tf.index, \r\n        !this.ascending() && this.orderByProperty() == tf.index\r\n      );\r\n    });\r\n  });\r\n\r\n  /** Remove os filtros no cabeçalho da tabela  */\r\n  noFilters: InputSignal<boolean> = input<boolean>(false);\r\n\r\n  /** Aplica classes de CSS na coluna de acirdo com o retorno da função passada como parametro  */\r\n  columnClass: InputSignal<CSSStyleStringGenerator | null> = input<CSSStyleStringGenerator | null>(null);\r\n\r\n  /** Aplica style de CSS na coluna de acirco com o retorno da função passada como parametro  */\r\n  columnStyle: InputSignal<CSSStyleStringGenerator | null> = input<CSSStyleStringGenerator | null>(null);\r\n\r\n  /** Remove a paginação da listagem */\r\n  noPagination: InputSignal<boolean> = input<boolean>(false);\r\n\r\n  /** Caminho de redirecionamento do item */\r\n  itemPath: InputSignal<string> = input<string>('view/:id');\r\n  itemClick: OutputEmitterRef<{item: T, field: TableField}> = output<{item: T, field: TableField}>();\r\n\r\n  InputType = InputType;\r\n\r\n  constructor(\r\n    public storageService : StorageService,\r\n    private activatedRoute: ActivatedRoute,\r\n    private router        : Router,\r\n  ) { \r\n    effect(() => {\r\n      for (const tf of this.lstTableFields().filter(p => p.type == InputType.Select)) {\r\n        (tf.configuration as InputSelectConfiguration).loader.Refresh().then(() => this.SetLstRows());\r\n      }\r\n      this.SetLstRows();\r\n    });\r\n  }\r\n\r\n  Redirect(field: TableField | undefined, item: T): void{\r\n    this.itemClick.emit({item, field});\r\n    if(!field){\r\n      return;\r\n    } else\r\n    if(field.index == 'ativo'){\r\n      return;\r\n    }else\r\n    if(field.type  == 'File'){\r\n      return;\r\n    }else\r\n    if(this.itemPath()){\r\n      const id = item['id']; \r\n      const path = this.itemPath().replace(\":id\", id.toString());\r\n      this.router.navigate([`./${path}`], { relativeTo: this.activatedRoute })\r\n    }\r\n  }\r\n\r\n  SetLstRows(){ \r\n    this.lstRows = this.items().map(item => {\r\n      return new DefaultTableRow<T>(\r\n        item, \r\n        item['id'],\r\n        this.GetColumns(item),\r\n        '',\r\n        '',\r\n      );\r\n    });\r\n  }\r\n  \r\n  lstRows: DefaultTableRow<T>[] = []; \r\n\r\n  GetColumns(item: T): DefaultTableColumn[] {\r\n    return this.lstTableFields().filter(p => !p.hidden).map(tf => {\r\n      const value = item[tf.index];\r\n      const column = new DefaultTableColumn(value, tf);\r\n      column.class = this.columnClass() ? this.columnClass()(tf.index, item) : '';\r\n      column.style = this.columnStyle() ? this.columnStyle()(tf.index, item) : '';\r\n      \r\n      if(!value){ \r\n        column.label = '-' \r\n        return column;\r\n      }\r\n      \r\n      if(tf.type == InputType.Bool){\r\n        column.label = \"<bool>\"\r\n      } else\r\n      if(tf.type == InputType.Cep){\r\n        column.label = FormatCep(value);\r\n      } else\r\n      if(tf.type == InputType.Color){\r\n        column.label = value;\r\n      } else\r\n      if([InputType.Cpf, InputType.Cnpj, InputType.CpfCnpj].includes(tf.type)){\r\n        column.label = FormatCpfCnpj(value);\r\n      } else\r\n      if(tf.type == InputType.DateTime){\r\n        column.class += ' font-mono';\r\n        column.label = Utils.DateISOToDDMMYYYYHHMM(value);\r\n      } else\r\n      if(tf.type == InputType.Date){\r\n        column.class += ' font-mono';\r\n        column.label = Utils.DateISOToDDMMYYYY(value);\r\n      } else\r\n      if(tf.type == InputType.Time){\r\n        column.class += ' font-mono';\r\n        column.label = value;\r\n      } else\r\n      if([InputType.Decimal, InputType.Decimal, InputType.Currency, InputType.Number].includes(tf.type)){\r\n        const configuration: InputDecimalConfiguration = tf.configuration;\r\n        column.label = [\r\n          configuration.prefix, \r\n          formatNumber(value as number, 'pt-BR', `1.${configuration.precision}-${configuration.precision}`),\r\n          configuration.sufix, \r\n        ].join(' ');\r\n      } else\r\n      if(tf.type == InputType.File){\r\n        column.label = '<file>';\r\n      } else\r\n      if(tf.type == InputType.Icon){\r\n        column.label = 'icon';\r\n      } else\r\n      if(tf.type == InputType.Select){\r\n        column.label = (tf.configuration as InputSelectConfiguration).loader.GetLabel(value);\r\n        column.loading = !(tf.configuration as InputSelectConfiguration).loader.isLoaded;\r\n      } else\r\n      if([InputType.String, InputType.TextArea].includes(tf.type)){\r\n        column.label = value\r\n      } else\r\n      if([InputType.Telefone, InputType.Celular, InputType.TelefoneCelular].includes(tf.type)){\r\n        column.label = FormatTelefoneCelular(value);\r\n      }\r\n\r\n      return column;\r\n    });\r\n  }\r\n\r\n  ngOnInit() { this.SetLstRows(); }\r\n\r\n  SwitchOrder(tf: TableField): void{\r\n    if(this.orderByProperty() != tf.index){\r\n      this.orderByProperty.set(tf.index);\r\n      this.ascending.set(true);\r\n    } else \r\n    if(this.ascending()){\r\n      this.ascending.set(false);\r\n    } else{ \r\n      this.orderByProperty.set(null); \r\n    }\r\n    this.refresh.emit();\r\n  }\r\n\r\n  ChangeFilter(): void{\r\n    this.filter.set(CompileLstTableField(this.lstTableFields()));\r\n    this.page.set(1);\r\n    this.refresh.emit();\r\n  }\r\n\r\n  Ativar(id: number): void{\r\n    this.ativar.emit(id);\r\n  }\r\n}\r\n\r\nclass DefaultTableRow<T>{\r\n  constructor(\r\n    public item: T,\r\n    public id: number | undefined,\r\n    public lstColumns: DefaultTableColumn[],\r\n    public acoesClass: string = '',\r\n    public acoesStyle: string = '',\r\n  ){}\r\n} \r\n\r\nclass DefaultTableColumn{\r\n  public label: string | null\r\n  public loading: boolean = false;\r\n  public class: string = '';\r\n  public style: string = '';\r\n  constructor(\r\n    public value: any = null,\r\n    public tf: TableField,\r\n  ){}\r\n}\r\n\r\nclass AvailableTableField{\r\n  constructor(\r\n    public tf: TableField,\r\n    public ascending: boolean,\r\n    public descending: boolean,\r\n  ){}\r\n}","<div class=\"size-full rounded-xl flex flex-col overflow-hidden relative\">\r\n    <loading [type]=\"3\" [loading]=\"loading()\"></loading>\r\n    <content-block text=\"Sem Dados\" [value]=\"!(items.length != 0 || loading)\"></content-block>\r\n\r\n     <div class=\"size-full shrink relative overflow-y-auto\">\r\n        <table>\r\n            <thead>\r\n                <tr>\r\n                    @if(acoesTemplate){\r\n                        <th scope=\"col\" class=\"p-2\"> \r\n                            Ações \r\n                        </th>\r\n                    }\r\n\r\n                    @for (tfa of lstTableFieldsAvailable(); track tfa.tf.index) {\r\n                        <th scope=\"col\" class=\"p-2\"> \r\n                            <div class=\"flex gap-2 items-center justify-start th\">\r\n                                @if(!noFilters()){\r\n                                    <th-filter class=\"!text-base\" style=\"text-transform: none !important\" \r\n                                    *ngIf=\"((tfa.tf.type != InputType.File || (tfa.tf.filter && tfa.tf.disabledChange())) && !noFilters())\"\r\n                                        [field]=\"tfa.tf\"\r\n                                        (change)=\"ChangeFilter()\"\r\n                                    ></th-filter>\r\n                                }\r\n\r\n                                {{tfa.tf.header}} \r\n\r\n                                @if((tfa.tf.type != InputType.File || (tfa.tf.filter && tfa.tf.disabledChange())) && !noFilters()){\r\n                                    <a [ngClass]=\"{ 'bg-light/10 !opacity-100': tfa.ascending || tfa.descending }\"\r\n                                        class=\"order h-4 w-5 relative cursor-pointer rounded-lg opacity-0 default-transition\" \r\n                                        (click)=\"SwitchOrder(tfa.tf)\"\r\n                                    >\r\n                                        <ion-icon \r\n                                            [class.text-primary]=\"tfa.ascending\"\r\n                                            class=\"absolute left-0 top-0\" \r\n                                            name=\"arrow-up\"\r\n                                        ></ion-icon> \r\n                                        <ion-icon \r\n                                            [class.text-primary]=\"tfa.descending\"\r\n                                            class=\"absolute right-0 bottom-0\" \r\n                                            name=\"arrow-down\"\r\n                                        ></ion-icon> \r\n                                    </a>\r\n                                }\r\n                            </div>\r\n                        </th>\r\n                    }\r\n                </tr>\r\n            </thead>\r\n            <tbody>\r\n                @for (row of lstRows; track row.id || $index) {\r\n                    <tr [hidden]=\"loading()\">\r\n                        @if(acoesTemplate){\r\n                            <td (click)=\"Redirect(undefined, row.item)\" class=\"whitespace-nowrap py-1 px-3 {{row.acoesClass}}\" [style]=\"row.acoesStyle\" >\r\n                                <ng-container *ngTemplateOutlet=\"acoesTemplate; context: { $implicit: row.item }\"></ng-container>\r\n                            </td>\r\n                        }\r\n\r\n                        @for (col of row.lstColumns; track col.tf.index) {\r\n                            <td class=\"{{col.class}} p-2 cursor-pointer\" (click)=\"Redirect(col.tf, row.item)\" [style]=\"'white-space: var(--ion-table-row-wrap);' + col.style\">\r\n                                @if(col.tf.index == 'ativo') {\r\n                                    <div class=\"size-full flex items-center justify-start\" [routerLink]=\"null\">\r\n                                        <ion-toggle [checked]=\"col.value\" [disabled]=\"loading()\" (ionChange)=\"Ativar(row.id)\" ></ion-toggle>\r\n                                    </div>\r\n                                }\r\n                                @else if (col.tf.type == InputType.Bool){\r\n                                    <div class=\"h-full flex items-center justify-start\">\r\n                                        @if(col.tf.configuration.type == 'toggle') {\r\n                                            <ion-toggle [checked]=\"col.value\" [disabled]=\"true\"></ion-toggle>\r\n                                        }\r\n                                        @else {\r\n                                            <ion-checkbox [checked]=\"col.value\" [disabled]=\"true\"></ion-checkbox>\r\n                                        }\r\n                                    </div>\r\n                                }\r\n                                @else if (col.tf.type == InputType.File) {\r\n                                    <download-button [(ngModel)]=\"col.value\" [configuration]=\"col.tf.configuration\"></download-button>\r\n                                }\r\n                                @else if (col.loading){\r\n                                    <ion-spinner name=\"dots\"></ion-spinner>\r\n                                } @else {\r\n                                    <span [ngClass]=\"col.class\">{{ col.label }}</span>\r\n                                }\r\n                            </td>\r\n                        }\r\n                    </tr>\r\n                    <ng-content select=\"[slot=item-end]\"></ng-content>\r\n                }\r\n            </tbody>\r\n        </table>\r\n     </div>\r\n     @if(!noPagination()){\r\n        <div class=\"shrink-0 z-[100]\">\r\n            <default-pagination\r\n                [page]=\"page()\"\r\n                (pageChange)=\"page.set($event); refresh.emit()\"\r\n                [total]=\"total()\"\r\n                [limit]=\"limit()\"\r\n                [length]=\"items().length\"\r\n                [loading]=\"loading()\"\r\n            ></default-pagination>\r\n        </div>\r\n    }\r\n</div>"]}
216
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"default-table.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/default/default-table/default-table.component.ts","../../../../../../src/lib/components/default/default-table/default-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { formatNumber } from '@angular/common';\r\nimport { Component, computed, effect, Input, input, InputSignal, model, ModelSignal, OnInit, output, OutputEmitterRef, OutputRef, Signal, TemplateRef } from '@angular/core';\r\nimport { ActivatedRoute, Router } from '@angular/router';\r\n\r\nimport { InputDecimalConfiguration } from '../../inputs/input-decimal/input-decimal.configuration';\r\nimport { InputSelectConfiguration } from '../../inputs/input-select/input.select.configuration';\r\nimport { FormatTelefoneCelular } from '../../inputs/input-telefone/input-telefone.component';\r\nimport { StorageService } from '../../../services/web/storage.service';\r\nimport { FormatCpfCnpj } from '../../inputs/input-cpf-cnpj/input-cpf-cnpj.component';\r\nimport { HttpService } from '../../../services/web/http.service'\r\nimport { TableField } from '../../../classes/inputs/table-field';\r\nimport { Comparison, CompileLstTableField } from '../../../classes/comparison/comparison';\r\nimport { FormatCep } from '../../inputs/input-cep/input-cep.component';\r\nimport { InputType } from '../../inputs/input-type';\r\nimport { Utils } from '../../../services/utils.service';\r\n\r\ntype CSSStyleStringGenerator = (index: string, object: any) => string;\r\n\r\n@Component({\r\n  selector: 'default-table',\r\n  templateUrl: './default-table.component.html',\r\n  styleUrls: ['./default-table.component.scss'],\r\n})\r\nexport class DefaultTableComponent<Service extends HttpService, T = any> implements OnInit {\r\n\r\n  @Input() acoesTemplate: TemplateRef<any>;\r\n  /** Template de ações, deve ser um elemento ```<ng-template>``` */\r\n  // acoesTemplate: InputSignal<TemplateRef<any>> = input<TemplateRef<any>>();\r\n\r\n  /** Service a ser utilizado na listagem */\r\n  service: InputSignal<Service> = input<Service>();\r\n\r\n  total: ModelSignal<number> = model<number>(0);\r\n\r\n  /** Número de items máximo (usando two way data binding) */\r\n  limit: ModelSignal<number> = model<number>();\r\n\r\n  /** Valor da pagina, setado = 1 quando troca-se o valor de limite de paginas (usando two way data binding) */\r\n  page: ModelSignal<number> = model<number>(1);\r\n\r\n  /** Propriedade de ordenação (usando two way data binding) */\r\n  orderByProperty: ModelSignal<string | null> = model<string | null>(null);\r\n    \r\n  /** Propriedade de ordenação\r\n   * Se = true  Ordenará de menor ao maior \r\n   * Se = false Ordenará de maior ao menor (usando two way data binding) */\r\n  ascending: ModelSignal<boolean> = model<boolean>(true);\r\n\r\n  /** Filtros (usando two way data binding) */ \r\n  filter: ModelSignal<Comparison[]> = model<Comparison[]>([]);\r\n\r\n  /** Evento emitido quando um dos dados é ativado. Emite o id do dado */  \r\n  ativar : OutputEmitterRef<number> = output<number>();\r\n  refresh: OutputEmitterRef<void> = output<void>();\r\n\r\n\r\n  loading: ModelSignal<boolean> = model<boolean>(false);\r\n\r\n  /** Lista de dados a ser exibidos */\r\n  items: ModelSignal<T[]> = model<T[]>([]);\r\n\r\n  /** Lista de campos a ser exibidos */\r\n  lstTableFields: ModelSignal<TableField[]> = model<TableField[]>([]);\r\n  lstTableFieldsAvailable: Signal<AvailableTableField[]> = computed<AvailableTableField[]>(() => { \r\n    return this.lstTableFields().filter(p => !p.hidden).map(tf => {\r\n      return new AvailableTableField(\r\n        tf, \r\n        this.ascending() && this.orderByProperty() == tf.index, \r\n        !this.ascending() && this.orderByProperty() == tf.index\r\n      );\r\n    });\r\n  });\r\n\r\n  /** Remove os filtros no cabeçalho da tabela  */\r\n  noFilters: InputSignal<boolean> = input<boolean>(false);\r\n\r\n  /** Aplica classes de CSS na coluna de acirdo com o retorno da função passada como parametro  */\r\n  columnClass: InputSignal<CSSStyleStringGenerator | null> = input<CSSStyleStringGenerator | null>(null);\r\n\r\n  /** Aplica style de CSS na coluna de acirco com o retorno da função passada como parametro  */\r\n  columnStyle: InputSignal<CSSStyleStringGenerator | null> = input<CSSStyleStringGenerator | null>(null);\r\n\r\n  /** Remove a paginação da listagem */\r\n  noPagination: InputSignal<boolean> = input<boolean>(false);\r\n\r\n  /** Caminho de redirecionamento do item */\r\n  itemPath: InputSignal<string> = input<string>('view/:id');\r\n  itemClick: OutputEmitterRef<{item: T, field: TableField}> = output<{item: T, field: TableField}>();\r\n\r\n  InputType = InputType;\r\n\r\n  constructor(\r\n    public storageService : StorageService,\r\n    private activatedRoute: ActivatedRoute,\r\n    private router        : Router,\r\n  ) { \r\n    effect(() => {\r\n      for (const tf of this.lstTableFields().filter(p => p.type == InputType.Select)) {\r\n        (tf.configuration as InputSelectConfiguration).loader.Refresh().then(() => this.SetLstRows());\r\n      }\r\n      this.SetLstRows();\r\n    });\r\n  }\r\n\r\nRedirect(field: TableField | undefined, item: T): void {\r\n  if (field == null) {\r\n    return;\r\n  }\r\n  this.itemClick.emit({ item, field });\r\n  if (field.index == 'ativo') {\r\n    return;\r\n  }\r\n  if (field.type == 'File') {\r\n    return;\r\n  }\r\n  if (this.itemPath()) {\r\n    const id = item['id'];\r\n    const path = this.itemPath().replace(\":id\", id.toString());\r\n    this.router.navigate([`./${path}`], { relativeTo: this.activatedRoute })\r\n  }\r\n}\r\n\r\n  SetLstRows(){ \r\n    this.lstRows = this.items().map(item => {\r\n      return new DefaultTableRow<T>(\r\n        item, \r\n        item['id'],\r\n        this.GetColumns(item),\r\n        '',\r\n        '',\r\n      );\r\n    });\r\n  }\r\n  \r\n  lstRows: DefaultTableRow<T>[] = []; \r\n\r\n  GetColumns(item: T): DefaultTableColumn[] {\r\n    return this.lstTableFields().filter(p => !p.hidden).map(tf => {\r\n      const value = item[tf.index];\r\n      const column = new DefaultTableColumn(value, tf);\r\n      column.class = this.columnClass() ? this.columnClass()(tf.index, item) : '';\r\n      column.style = this.columnStyle() ? this.columnStyle()(tf.index, item) : '';\r\n      \r\n      if(!value){ \r\n        column.label = '-' \r\n        return column;\r\n      }\r\n      \r\n      if(tf.type == InputType.Bool){\r\n        column.label = \"<bool>\"\r\n      } else\r\n      if(tf.type == InputType.Cep){\r\n        column.label = FormatCep(value);\r\n      } else\r\n      if(tf.type == InputType.Color){\r\n        column.label = value;\r\n      } else\r\n      if([InputType.Cpf, InputType.Cnpj, InputType.CpfCnpj].includes(tf.type)){\r\n        column.label = FormatCpfCnpj(value);\r\n      } else\r\n      if(tf.type == InputType.DateTime){\r\n        column.class += ' font-mono';\r\n        column.label = Utils.DateISOToDDMMYYYYHHMM(value);\r\n      } else\r\n      if(tf.type == InputType.Date){\r\n        column.class += ' font-mono';\r\n        column.label = Utils.DateISOToDDMMYYYY(value);\r\n      } else\r\n      if(tf.type == InputType.Time){\r\n        column.class += ' font-mono';\r\n        column.label = value;\r\n      } else\r\n      if([InputType.Decimal, InputType.Decimal, InputType.Currency, InputType.Number].includes(tf.type)){\r\n        const configuration: InputDecimalConfiguration = tf.configuration;\r\n        column.label = [\r\n          configuration.prefix, \r\n          formatNumber(value as number, 'pt-BR', `1.${configuration.precision}-${configuration.precision}`),\r\n          configuration.sufix, \r\n        ].join(' ');\r\n      } else\r\n      if(tf.type == InputType.File){\r\n        column.label = '<file>';\r\n      } else\r\n      if(tf.type == InputType.Icon){\r\n        column.label = 'icon';\r\n      } else\r\n      if(tf.type == InputType.Select){\r\n        column.label = (tf.configuration as InputSelectConfiguration).loader.GetLabel(value);\r\n        column.loading = !(tf.configuration as InputSelectConfiguration).loader.isLoaded;\r\n      } else\r\n      if([InputType.String, InputType.TextArea].includes(tf.type)){\r\n        column.label = value\r\n      } else\r\n      if([InputType.Telefone, InputType.Celular, InputType.TelefoneCelular].includes(tf.type)){\r\n        column.label = FormatTelefoneCelular(value);\r\n      }\r\n\r\n      return column;\r\n    });\r\n  }\r\n\r\n  ngOnInit() { this.SetLstRows(); }\r\n\r\n  SwitchOrder(tf: TableField): void{\r\n    if(this.orderByProperty() != tf.index){\r\n      this.orderByProperty.set(tf.index);\r\n      this.ascending.set(true);\r\n    } else \r\n    if(this.ascending()){\r\n      this.ascending.set(false);\r\n    } else{ \r\n      this.orderByProperty.set(null); \r\n    }\r\n    this.refresh.emit();\r\n  }\r\n\r\n  ChangeFilter(): void{\r\n    this.filter.set(CompileLstTableField(this.lstTableFields()));\r\n    this.page.set(1);\r\n    this.refresh.emit();\r\n  }\r\n\r\n  Ativar(id: number): void{\r\n    this.ativar.emit(id);\r\n  }\r\n}\r\n\r\nclass DefaultTableRow<T>{\r\n  constructor(\r\n    public item: T,\r\n    public id: number | undefined,\r\n    public lstColumns: DefaultTableColumn[],\r\n    public acoesClass: string = '',\r\n    public acoesStyle: string = '',\r\n  ){}\r\n} \r\n\r\nclass DefaultTableColumn{\r\n  public label: string | null\r\n  public loading: boolean = false;\r\n  public class: string = '';\r\n  public style: string = '';\r\n  constructor(\r\n    public value: any = null,\r\n    public tf: TableField,\r\n  ){}\r\n}\r\n\r\nclass AvailableTableField{\r\n  constructor(\r\n    public tf: TableField,\r\n    public ascending: boolean,\r\n    public descending: boolean,\r\n  ){}\r\n}","<div class=\"size-full rounded-xl flex flex-col overflow-hidden relative\">\r\n    <loading [type]=\"3\" [loading]=\"loading()\"></loading>\r\n    <content-block text=\"Sem Dados\" [value]=\"!(items.length != 0 || loading)\"></content-block>\r\n\r\n     <div class=\"size-full shrink relative overflow-y-auto\">\r\n        <table>\r\n            <thead>\r\n                <tr>\r\n                    @if(acoesTemplate){\r\n                        <th scope=\"col\" class=\"p-2\"> \r\n                            Ações \r\n                        </th>\r\n                    }\r\n\r\n                    @for (tfa of lstTableFieldsAvailable(); track tfa.tf.index) {\r\n                        <th scope=\"col\" class=\"p-2\"> \r\n                            <div class=\"flex gap-2 items-center justify-start th\">\r\n                                @if(!noFilters()){\r\n                                    <th-filter class=\"!text-base\" style=\"text-transform: none !important\" \r\n                                    *ngIf=\"((tfa.tf.type != InputType.File || (tfa.tf.filter && tfa.tf.disabledChange())) && !noFilters())\"\r\n                                        [field]=\"tfa.tf\"\r\n                                        (change)=\"ChangeFilter()\"\r\n                                    ></th-filter>\r\n                                }\r\n\r\n                                {{tfa.tf.header}} \r\n\r\n                                @if((tfa.tf.type != InputType.File || (tfa.tf.filter && tfa.tf.disabledChange())) && !noFilters()){\r\n                                    <a [ngClass]=\"{ 'bg-light/10 !opacity-100': tfa.ascending || tfa.descending }\"\r\n                                        class=\"order h-4 w-5 relative cursor-pointer rounded-lg opacity-0 default-transition\" \r\n                                        (click)=\"SwitchOrder(tfa.tf)\"\r\n                                    >\r\n                                        <ion-icon \r\n                                            [class.text-primary]=\"tfa.ascending\"\r\n                                            class=\"absolute left-0 top-0\" \r\n                                            name=\"arrow-up\"\r\n                                        ></ion-icon> \r\n                                        <ion-icon \r\n                                            [class.text-primary]=\"tfa.descending\"\r\n                                            class=\"absolute right-0 bottom-0\" \r\n                                            name=\"arrow-down\"\r\n                                        ></ion-icon> \r\n                                    </a>\r\n                                }\r\n                            </div>\r\n                        </th>\r\n                    }\r\n                </tr>\r\n            </thead>\r\n            <tbody>\r\n                @for (row of lstRows; track row.id || $index) {\r\n                    <tr [hidden]=\"loading()\">\r\n                        @if(acoesTemplate){\r\n                            <td (click)=\"Redirect(undefined, row.item)\" class=\"whitespace-nowrap py-1 px-3 {{row.acoesClass}}\" [style]=\"row.acoesStyle\" >\r\n                                <ng-container *ngTemplateOutlet=\"acoesTemplate; context: { $implicit: row.item }\"></ng-container>\r\n                            </td>\r\n                        }\r\n\r\n                        @for (col of row.lstColumns; track col.tf.index) {\r\n                            <td class=\"{{col.class}} p-2 cursor-pointer\" (click)=\"Redirect(col.tf, row.item)\" [style]=\"'white-space: var(--ion-table-row-wrap);' + col.style\">\r\n                                @if(col.tf.index == 'ativo') {\r\n                                    <div class=\"size-full flex items-center justify-start\" [routerLink]=\"null\">\r\n                                        <ion-toggle [checked]=\"col.value\" [disabled]=\"loading()\" (ionChange)=\"Ativar(row.id)\" ></ion-toggle>\r\n                                    </div>\r\n                                }\r\n                                @else if (col.tf.type == InputType.Bool){\r\n                                    <div class=\"h-full flex items-center justify-start\">\r\n                                        @if(col.tf.configuration.type == 'toggle') {\r\n                                            <ion-toggle [checked]=\"col.value\" [disabled]=\"true\"></ion-toggle>\r\n                                        }\r\n                                        @else {\r\n                                            <ion-checkbox [checked]=\"col.value\" [disabled]=\"true\"></ion-checkbox>\r\n                                        }\r\n                                    </div>\r\n                                }\r\n                                @else if (col.tf.type == InputType.File) {\r\n                                    <download-button [(ngModel)]=\"col.value\" [configuration]=\"col.tf.configuration\"></download-button>\r\n                                }\r\n                                @else if (col.loading){\r\n                                    <ion-spinner name=\"dots\"></ion-spinner>\r\n                                } @else {\r\n                                    <span [ngClass]=\"col.class\">{{ col.label }}</span>\r\n                                }\r\n                            </td>\r\n                        }\r\n                    </tr>\r\n                    <ng-content select=\"[slot=item-end]\"></ng-content>\r\n                }\r\n            </tbody>\r\n        </table>\r\n     </div>\r\n     @if(!noPagination()){\r\n        <div class=\"shrink-0 z-[100]\">\r\n            <default-pagination\r\n                [page]=\"page()\"\r\n                (pageChange)=\"page.set($event); refresh.emit()\"\r\n                [total]=\"total()\"\r\n                [limit]=\"limit()\"\r\n                [length]=\"items().length\"\r\n                [loading]=\"loading()\"\r\n            ></default-pagination>\r\n        </div>\r\n    }\r\n</div>"]}
@@ -4281,17 +4281,17 @@ class DefaultTableComponent {
4281
4281
  });
4282
4282
  }
4283
4283
  Redirect(field, item) {
4284
- this.itemClick.emit({ item, field });
4285
- if (!field) {
4284
+ if (field == null) {
4286
4285
  return;
4287
4286
  }
4288
- else if (field.index == 'ativo') {
4287
+ this.itemClick.emit({ item, field });
4288
+ if (field.index == 'ativo') {
4289
4289
  return;
4290
4290
  }
4291
- else if (field.type == 'File') {
4291
+ if (field.type == 'File') {
4292
4292
  return;
4293
4293
  }
4294
- else if (this.itemPath()) {
4294
+ if (this.itemPath()) {
4295
4295
  const id = item['id'];
4296
4296
  const path = this.itemPath().replace(":id", id.toString());
4297
4297
  this.router.navigate([`./${path}`], { relativeTo: this.activatedRoute });