@sapphire-ion/framework 1.0.35 → 1.0.37
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/default/default-table/default-table.component.mjs +2 -2
- package/esm2022/lib/components/inputs/input-select/input-select.component.mjs +56 -11
- package/esm2022/lib/components/inputs/input-select/input.select.configuration.mjs +17 -1
- package/esm2022/lib/components/inputs/inputs.module.mjs +8 -4
- package/esm2022/lib/components/popover/sion-popover/sion-popover.component.mjs +11 -40
- package/esm2022/lib/components/popover/sion-popover.module.mjs +5 -4
- package/esm2022/lib/core.module.mjs +12 -7
- package/esm2022/lib/services/modal-focus-trap.service.mjs +62 -0
- package/fesm2022/sapphire-ion-framework.mjs +231 -132
- package/fesm2022/sapphire-ion-framework.mjs.map +1 -1
- package/lib/components/inputs/input-select/input-select.component.d.ts +7 -2
- package/lib/components/inputs/input-select/input.select.configuration.d.ts +13 -0
- package/lib/components/inputs/inputs.module.d.ts +2 -1
- package/lib/components/popover/sion-popover/sion-popover.component.d.ts +4 -9
- package/lib/components/popover/sion-popover.module.d.ts +2 -1
- package/lib/core.module.d.ts +3 -0
- package/lib/services/modal-focus-trap.service.d.ts +13 -0
- package/package.json +1 -1
- package/themes/components/popover/sion-popover/sion-popover.component.scss +5 -3
- package/themes/styles/core.styles.scss +2 -1
- package/themes/styles/ionic/ion-modal.scss +1 -1
|
@@ -130,7 +130,7 @@ export class DefaultTableComponent {
|
|
|
130
130
|
column.class += ' font-mono';
|
|
131
131
|
column.label = value;
|
|
132
132
|
}
|
|
133
|
-
else if ([InputType.Decimal, InputType.Decimal, InputType.Currency].includes(tf.type)) {
|
|
133
|
+
else if ([InputType.Decimal, InputType.Decimal, InputType.Currency, InputType.Number].includes(tf.type)) {
|
|
134
134
|
const configuration = tf.configuration;
|
|
135
135
|
column.label = [
|
|
136
136
|
configuration.prefix,
|
|
@@ -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<T> = output<T>();\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);\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        this.columnClass() ? this.columnClass()('acoes', item) : '',\r\n        this.columnStyle() ? this.columnClass()('acoes', item) : '',\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.DateISOToDDMMYYYYHHMM(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].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-2xl 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                    <th scope=\"col\" class=\"px-3 !h-10\" *ngIf=\"acoesTemplate\"> Ações </th>\r\n                        @for (field of lstTableFields; let i = $index; track i) {\r\n                            @if (!field.hidden) {\r\n                                <th scope=\"col\" class=\"p-2 px-3\" id=\"th-filter-select\">\r\n                                    <div class=\"flex items-center justify-start h-full\" style=\"white-space: var(--ion-table-filter-wrap);\"> \r\n                                        @if(!noFilters){\r\n                                            <th-filter class=\"!text-base\" style=\"text-transform: none !important\" *ngIf=\"(field.type != InputTypeFile) && !(field.filter && field.disabledChange()) && !noFilters\"\r\n                                                [field]=\"field\"\r\n                                                (change)=\"ChangeFilter()\"\r\n                                            ></th-filter>\r\n                                        }\r\n                                        <span>{{field.header}}</span>\r\n\r\n                                        <a *ngIf=\"!(!(field.type != InputTypeFile) && !(field.filter && field.disabledChange())) && !noFilters\" class=\"order-switch h-5 flex items-center justify-center px-1 ml-2 shrink-0 cursor-pointer rounded-2xl\" (click)=\"SwitchOrder(field)\" [ngClass]=\"{ 'ordering-asc' : orderByProperty == field.index && ascending, 'ordering-desc' : orderByProperty == field.index && !ascending}\">\r\n                                            <ion-icon id=\"up\"   name=\"arrow-up\"   class=\"-mt-1\"></ion-icon>\r\n                                            <ion-icon id=\"down\" name=\"arrow-down\" class=\"-ml-1 -mb-1\"></ion-icon>\r\n                                        </a>\r\n                                    </div>\r\n                                </th>\r\n                            }\r\n                        }\r\n                </tr>\r\n            </thead>\r\n            <tbody>\r\n                <tr [hidden]=\"loading\" *ngFor=\"let item of items\">\r\n                    @if(acoesTemplate){\r\n                        <td class=\"whitespace-nowrap py-1 px-3\" [style]=\"GetTdStyle('Acoes', item)\" >\r\n                            <ng-container *ngTemplateOutlet=\"acoesTemplate; context: { $implicit: item }\"></ng-container>\r\n                        </td>\r\n                    }\r\n\r\n                    @for (field of lstTableFields; track $index) {\r\n                        @if (!field.hidden) {\r\n                            <td class=\"px-3 py-2\" \r\n                                [ngClass]=\"GetTdClasses(field, item)\" \r\n                                [style]=\"GetTdStyle(field, item)\" \r\n                                (click)=\"Redirect(field, item)\"\r\n                                style=\"white-space: var(--ion-table-row-wrap);\"\r\n                            >\r\n                                @if (field.index == 'ativo') {\r\n                                    <div class=\"w-full h-full flex items-center justify-start\" [routerLink]=\"null\">\r\n                                        <ion-toggle [checked]=\"item[field.index]\" [disabled]=\"loading\" (ionChange)=\"Ativar(item.id)\" ></ion-toggle>\r\n                                    </div>\r\n                                } @else {\r\n                                    @switch (field.type) {\r\n                                        @case (\"Bool\") {\r\n                                            @if (field.configuration.type == \"toggle\") {\r\n                                                <div class=\"-full h-full flex items-center justify-start\">\r\n                                                    <ion-toggle [checked]=\"item[field.index]\" [disabled]=\"true\"></ion-toggle>\r\n                                                </div>\r\n                                            }\r\n                                            @else {\r\n                                                <div class=\"-full h-full flex items-center justify-start\">\r\n                                                    <ion-checkbox [checked]=\"item[field.index]\" [disabled]=\"true\"></ion-checkbox>\r\n                                                </div>\r\n                                            }\r\n                                        }\r\n                                        @case (\"File\") {\r\n                                            <download-button [(ngModel)]=\"item[field.index]\" [configuration]=\"field.configuration\"></download-button>\r\n                                        }\r\n                                        @case (\"Select\") {\r\n                                            {{GetSelectLabel(item, field)}}\r\n                                        }\r\n                                        @default {\r\n                                            {{GetField(item, field)}} \r\n                                        }\r\n                                    }\r\n                                }\r\n                            </td>\r\n                        }\r\n                    }\r\n                </tr>\r\n\r\n                <ng-content select=\"[slot=item-end]\"></ng-content>\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)=\"EmitPage($event)\"\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> -->\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                                    {{col.label}}\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\r\n    <!-- <div class=\"overflow-y-auto\">\r\n        @for (item of lstRows; track $index) {\r\n            <div class=\"border border-red-500 flex\">\r\n                {{$index}} - \r\n                @for (lbl of item.lstColumns; track $index) {\r\n                    ([{{lbl.label}}])\r\n                }\r\n            </div>\r\n        }\r\n    </div> -->\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":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAe,KAAK,EAAuB,MAAM,EAAuC,WAAW,EAAE,MAAM,eAAe,CAAC;AAC7K,OAAO,EAAE,cAAc,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAIzD,OAAO,EAAE,qBAAqB,EAAE,MAAM,sDAAsD,CAAC;AAC7F,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAC;AACvE,OAAO,EAAE,aAAa,EAAE,MAAM,sDAAsD,CAAC;AAGrF,OAAO,EAAc,oBAAoB,EAAE,MAAM,wCAAwC,CAAC;AAC1F,OAAO,EAAE,SAAS,EAAE,MAAM,4CAA4C,CAAC;AACvE,OAAO,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAC;AACpD,OAAO,EAAE,KAAK,EAAE,MAAM,iCAAiC,CAAC;;;;;;;;;;;;AASxD,MAAM,OAAO,qBAAqB;IAoEhC,YACS,cAA+B,EAC9B,cAA8B,EAC9B,MAAsB;QAFvB,mBAAc,GAAd,cAAc,CAAiB;QAC9B,mBAAc,GAAd,cAAc,CAAgB;QAC9B,WAAM,GAAN,MAAM,CAAgB;QApEhC,kEAAkE;QAClE,4EAA4E;QAE5E,0CAA0C;QAC1C,YAAO,GAAyB,KAAK,EAAW,CAAC;QAEjD,UAAK,GAAwB,KAAK,CAAS,CAAC,CAAC,CAAC;QAE9C,2DAA2D;QAC3D,UAAK,GAAwB,KAAK,EAAU,CAAC;QAE7C,6GAA6G;QAC7G,SAAI,GAAwB,KAAK,CAAS,CAAC,CAAC,CAAC;QAE7C,6DAA6D;QAC7D,oBAAe,GAA+B,KAAK,CAAgB,IAAI,CAAC,CAAC;QAEzE;;iFAEyE;QACzE,cAAS,GAAyB,KAAK,CAAU,IAAI,CAAC,CAAC;QAEvD,4CAA4C;QAC5C,WAAM,GAA8B,KAAK,CAAe,EAAE,CAAC,CAAC;QAE5D,uEAAuE;QACvE,WAAM,GAA8B,MAAM,EAAU,CAAC;QACrD,YAAO,GAA2B,MAAM,EAAQ,CAAC;QAGjD,YAAO,GAAyB,KAAK,CAAU,KAAK,CAAC,CAAC;QAEtD,oCAAoC;QACpC,UAAK,GAAqB,KAAK,CAAM,EAAE,CAAC,CAAC;QAEzC,qCAAqC;QACrC,mBAAc,GAA8B,KAAK,CAAe,EAAE,CAAC,CAAC;QACpE,4BAAuB,GAAkC,QAAQ,CAAwB,GAAG,EAAE;YAC5F,OAAO,IAAI,CAAC,cAAc,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE;gBAC3D,OAAO,IAAI,mBAAmB,CAC5B,EAAE,EACF,IAAI,CAAC,SAAS,EAAE,IAAI,IAAI,CAAC,eAAe,EAAE,IAAI,EAAE,CAAC,KAAK,EACtD,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,IAAI,CAAC,eAAe,EAAE,IAAI,EAAE,CAAC,KAAK,CACxD,CAAC;YACJ,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,gDAAgD;QAChD,cAAS,GAAyB,KAAK,CAAU,KAAK,CAAC,CAAC;QAExD,gGAAgG;QAChG,gBAAW,GAAgD,KAAK,CAAiC,IAAI,CAAC,CAAC;QAEvG,8FAA8F;QAC9F,gBAAW,GAAgD,KAAK,CAAiC,IAAI,CAAC,CAAC;QAEvG,qCAAqC;QACrC,iBAAY,GAAyB,KAAK,CAAU,KAAK,CAAC,CAAC;QAE3D,0CAA0C;QAC1C,aAAQ,GAAwB,KAAK,CAAS,UAAU,CAAC,CAAC;QAC1D,cAAS,GAAwB,MAAM,EAAK,CAAC;QAE7C,cAAS,GAAG,SAAS,CAAC;QA6CtB,YAAO,GAAyB,EAAE,CAAC;QAtCjC,MAAM,CAAC,GAAG,EAAE;YACV,KAAK,MAAM,EAAE,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,IAAI,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC;gBAC9E,EAAE,CAAC,aAA0C,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC;YAChG,CAAC;YACD,IAAI,CAAC,UAAU,EAAE,CAAC;QACpB,CAAC,CAAC,CAAC;IACL,CAAC;IAED,QAAQ,CAAC,KAA6B,EAAE,IAAO;QAC7C,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC1B,IAAG,CAAC,KAAK,EAAC,CAAC;YACT,OAAO;QACT,CAAC;aACD,IAAG,KAAK,CAAC,KAAK,IAAI,OAAO,EAAC,CAAC;YACzB,OAAO;QACT,CAAC;aACD,IAAG,KAAK,CAAC,IAAI,IAAK,MAAM,EAAC,CAAC;YACxB,OAAO;QACT,CAAC;aACD,IAAG,IAAI,CAAC,QAAQ,EAAE,EAAC,CAAC;YAClB,MAAM,EAAE,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC;YACtB,MAAM,IAAI,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,QAAQ,EAAE,CAAC,CAAC;YAC3D,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,KAAK,IAAI,EAAE,CAAC,EAAE,EAAE,UAAU,EAAE,IAAI,CAAC,cAAc,EAAE,CAAC,CAAA;QAC1E,CAAC;IACH,CAAC;IAED,UAAU;QACR,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;YACrC,OAAO,IAAI,eAAe,CACxB,IAAI,EACJ,IAAI,CAAC,IAAI,CAAC,EACV,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EACrB,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,EAC3D,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,CAC5D,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;IAID,UAAU,CAAC,IAAO;QAChB,OAAO,IAAI,CAAC,cAAc,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE;YAC3D,MAAM,KAAK,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC;YAC7B,MAAM,MAAM,GAAG,IAAI,kBAAkB,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;YACjD,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,EAAE,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;YAC5E,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,EAAE,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;YAE5E,IAAG,CAAC,KAAK,EAAC,CAAC;gBACT,MAAM,CAAC,KAAK,GAAG,GAAG,CAAA;gBAClB,OAAO,MAAM,CAAC;YAChB,CAAC;YAED,IAAG,EAAE,CAAC,IAAI,IAAI,SAAS,CAAC,IAAI,EAAC,CAAC;gBAC5B,MAAM,CAAC,KAAK,GAAG,QAAQ,CAAA;YACzB,CAAC;iBACD,IAAG,EAAE,CAAC,IAAI,IAAI,SAAS,CAAC,GAAG,EAAC,CAAC;gBAC3B,MAAM,CAAC,KAAK,GAAG,SAAS,CAAC,KAAK,CAAC,CAAC;YAClC,CAAC;iBACD,IAAG,EAAE,CAAC,IAAI,IAAI,SAAS,CAAC,KAAK,EAAC,CAAC;gBAC7B,MAAM,CAAC,KAAK,GAAG,KAAK,CAAC;YACvB,CAAC;iBACD,IAAG,CAAC,SAAS,CAAC,GAAG,EAAE,SAAS,CAAC,IAAI,EAAE,SAAS,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,IAAI,CAAC,EAAC,CAAC;gBACvE,MAAM,CAAC,KAAK,GAAG,aAAa,CAAC,KAAK,CAAC,CAAC;YACtC,CAAC;iBACD,IAAG,EAAE,CAAC,IAAI,IAAI,SAAS,CAAC,QAAQ,EAAC,CAAC;gBAChC,MAAM,CAAC,KAAK,IAAI,YAAY,CAAC;gBAC7B,MAAM,CAAC,KAAK,GAAG,KAAK,CAAC,qBAAqB,CAAC,KAAK,CAAC,CAAC;YACpD,CAAC;iBACD,IAAG,EAAE,CAAC,IAAI,IAAI,SAAS,CAAC,IAAI,EAAC,CAAC;gBAC5B,MAAM,CAAC,KAAK,IAAI,YAAY,CAAC;gBAC7B,MAAM,CAAC,KAAK,GAAG,KAAK,CAAC,qBAAqB,CAAC,KAAK,CAAC,CAAC;YACpD,CAAC;iBACD,IAAG,EAAE,CAAC,IAAI,IAAI,SAAS,CAAC,IAAI,EAAC,CAAC;gBAC5B,MAAM,CAAC,KAAK,IAAI,YAAY,CAAC;gBAC7B,MAAM,CAAC,KAAK,GAAG,KAAK,CAAC;YACvB,CAAC;iBACD,IAAG,CAAC,SAAS,CAAC,OAAO,EAAE,SAAS,CAAC,OAAO,EAAE,SAAS,CAAC,QAAQ,EAAE,SAAS,CAAC,MAAM,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,IAAI,CAAC,EAAC,CAAC;gBACjG,MAAM,aAAa,GAA8B,EAAE,CAAC,aAAa,CAAC;gBAClE,MAAM,CAAC,KAAK,GAAG;oBACb,aAAa,CAAC,MAAM;oBACpB,YAAY,CAAC,KAAe,EAAE,OAAO,EAAE,KAAK,aAAa,CAAC,SAAS,IAAI,aAAa,CAAC,SAAS,EAAE,CAAC;oBACjG,aAAa,CAAC,KAAK;iBACpB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YACd,CAAC;iBACD,IAAG,EAAE,CAAC,IAAI,IAAI,SAAS,CAAC,IAAI,EAAC,CAAC;gBAC5B,MAAM,CAAC,KAAK,GAAG,QAAQ,CAAC;YAC1B,CAAC;iBACD,IAAG,EAAE,CAAC,IAAI,IAAI,SAAS,CAAC,IAAI,EAAC,CAAC;gBAC5B,MAAM,CAAC,KAAK,GAAG,MAAM,CAAC;YACxB,CAAC;iBACD,IAAG,EAAE,CAAC,IAAI,IAAI,SAAS,CAAC,MAAM,EAAC,CAAC;gBAC9B,MAAM,CAAC,KAAK,GAAI,EAAE,CAAC,aAA0C,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;gBACrF,MAAM,CAAC,OAAO,GAAG,CAAE,EAAE,CAAC,aAA0C,CAAC,MAAM,CAAC,QAAQ,CAAC;YACnF,CAAC;iBACD,IAAG,CAAC,SAAS,CAAC,MAAM,EAAE,SAAS,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,IAAI,CAAC,EAAC,CAAC;gBAC3D,MAAM,CAAC,KAAK,GAAG,KAAK,CAAA;YACtB,CAAC;iBACD,IAAG,CAAC,SAAS,CAAC,QAAQ,EAAE,SAAS,CAAC,OAAO,EAAE,SAAS,CAAC,eAAe,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,IAAI,CAAC,EAAC,CAAC;gBACvF,MAAM,CAAC,KAAK,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;YAC9C,CAAC;YAED,OAAO,MAAM,CAAC;QAChB,CAAC,CAAC,CAAC;IACL,CAAC;IAED,QAAQ,KAAK,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC;IAEjC,WAAW,CAAC,EAAc;QACxB,IAAG,IAAI,CAAC,eAAe,EAAE,IAAI,EAAE,CAAC,KAAK,EAAC,CAAC;YACrC,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC;YACnC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAC3B,CAAC;aACD,IAAG,IAAI,CAAC,SAAS,EAAE,EAAC,CAAC;YACnB,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAC5B,CAAC;aAAK,CAAC;YACL,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACjC,CAAC;QACD,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;IACtB,CAAC;IAED,YAAY;QACV,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,oBAAoB,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC,CAAC;QAC7D,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACjB,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;IACtB,CAAC;IAED,MAAM,CAAC,EAAU;QACf,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACvB,CAAC;+GAzMU,qBAAqB;mGAArB,qBAAqB,47ECvBlC,u0YAqNM;;4FD9LO,qBAAqB;kBALjC,SAAS;+BACE,eAAe;qIAMhB,aAAa;sBAArB,KAAK;;AA0MR,MAAM,eAAe;IACnB,YACS,IAAO,EACP,EAAsB,EACtB,UAAgC,EAChC,aAAqB,EAAE,EACvB,aAAqB,EAAE;QAJvB,SAAI,GAAJ,IAAI,CAAG;QACP,OAAE,GAAF,EAAE,CAAoB;QACtB,eAAU,GAAV,UAAU,CAAsB;QAChC,eAAU,GAAV,UAAU,CAAa;QACvB,eAAU,GAAV,UAAU,CAAa;IAC9B,CAAC;CACJ;AAED,MAAM,kBAAkB;IAKtB,YACS,QAAa,IAAI,EACjB,EAAc;QADd,UAAK,GAAL,KAAK,CAAY;QACjB,OAAE,GAAF,EAAE,CAAY;QALhB,YAAO,GAAY,KAAK,CAAC;QACzB,UAAK,GAAW,EAAE,CAAC;QACnB,UAAK,GAAW,EAAE,CAAC;IAIxB,CAAC;CACJ;AAED,MAAM,mBAAmB;IACvB,YACS,EAAc,EACd,SAAkB,EAClB,UAAmB;QAFnB,OAAE,GAAF,EAAE,CAAY;QACd,cAAS,GAAT,SAAS,CAAS;QAClB,eAAU,GAAV,UAAU,CAAS;IAC1B,CAAC;CACJ","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<T> = output<T>();\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);\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        this.columnClass() ? this.columnClass()('acoes', item) : '',\r\n        this.columnStyle() ? this.columnClass()('acoes', item) : '',\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.DateISOToDDMMYYYYHHMM(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-2xl 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                    <th scope=\"col\" class=\"px-3 !h-10\" *ngIf=\"acoesTemplate\"> Ações </th>\r\n                        @for (field of lstTableFields; let i = $index; track i) {\r\n                            @if (!field.hidden) {\r\n                                <th scope=\"col\" class=\"p-2 px-3\" id=\"th-filter-select\">\r\n                                    <div class=\"flex items-center justify-start h-full\" style=\"white-space: var(--ion-table-filter-wrap);\"> \r\n                                        @if(!noFilters){\r\n                                            <th-filter class=\"!text-base\" style=\"text-transform: none !important\" *ngIf=\"(field.type != InputTypeFile) && !(field.filter && field.disabledChange()) && !noFilters\"\r\n                                                [field]=\"field\"\r\n                                                (change)=\"ChangeFilter()\"\r\n                                            ></th-filter>\r\n                                        }\r\n                                        <span>{{field.header}}</span>\r\n\r\n                                        <a *ngIf=\"!(!(field.type != InputTypeFile) && !(field.filter && field.disabledChange())) && !noFilters\" class=\"order-switch h-5 flex items-center justify-center px-1 ml-2 shrink-0 cursor-pointer rounded-2xl\" (click)=\"SwitchOrder(field)\" [ngClass]=\"{ 'ordering-asc' : orderByProperty == field.index && ascending, 'ordering-desc' : orderByProperty == field.index && !ascending}\">\r\n                                            <ion-icon id=\"up\"   name=\"arrow-up\"   class=\"-mt-1\"></ion-icon>\r\n                                            <ion-icon id=\"down\" name=\"arrow-down\" class=\"-ml-1 -mb-1\"></ion-icon>\r\n                                        </a>\r\n                                    </div>\r\n                                </th>\r\n                            }\r\n                        }\r\n                </tr>\r\n            </thead>\r\n            <tbody>\r\n                <tr [hidden]=\"loading\" *ngFor=\"let item of items\">\r\n                    @if(acoesTemplate){\r\n                        <td class=\"whitespace-nowrap py-1 px-3\" [style]=\"GetTdStyle('Acoes', item)\" >\r\n                            <ng-container *ngTemplateOutlet=\"acoesTemplate; context: { $implicit: item }\"></ng-container>\r\n                        </td>\r\n                    }\r\n\r\n                    @for (field of lstTableFields; track $index) {\r\n                        @if (!field.hidden) {\r\n                            <td class=\"px-3 py-2\" \r\n                                [ngClass]=\"GetTdClasses(field, item)\" \r\n                                [style]=\"GetTdStyle(field, item)\" \r\n                                (click)=\"Redirect(field, item)\"\r\n                                style=\"white-space: var(--ion-table-row-wrap);\"\r\n                            >\r\n                                @if (field.index == 'ativo') {\r\n                                    <div class=\"w-full h-full flex items-center justify-start\" [routerLink]=\"null\">\r\n                                        <ion-toggle [checked]=\"item[field.index]\" [disabled]=\"loading\" (ionChange)=\"Ativar(item.id)\" ></ion-toggle>\r\n                                    </div>\r\n                                } @else {\r\n                                    @switch (field.type) {\r\n                                        @case (\"Bool\") {\r\n                                            @if (field.configuration.type == \"toggle\") {\r\n                                                <div class=\"-full h-full flex items-center justify-start\">\r\n                                                    <ion-toggle [checked]=\"item[field.index]\" [disabled]=\"true\"></ion-toggle>\r\n                                                </div>\r\n                                            }\r\n                                            @else {\r\n                                                <div class=\"-full h-full flex items-center justify-start\">\r\n                                                    <ion-checkbox [checked]=\"item[field.index]\" [disabled]=\"true\"></ion-checkbox>\r\n                                                </div>\r\n                                            }\r\n                                        }\r\n                                        @case (\"File\") {\r\n                                            <download-button [(ngModel)]=\"item[field.index]\" [configuration]=\"field.configuration\"></download-button>\r\n                                        }\r\n                                        @case (\"Select\") {\r\n                                            {{GetSelectLabel(item, field)}}\r\n                                        }\r\n                                        @default {\r\n                                            {{GetField(item, field)}} \r\n                                        }\r\n                                    }\r\n                                }\r\n                            </td>\r\n                        }\r\n                    }\r\n                </tr>\r\n\r\n                <ng-content select=\"[slot=item-end]\"></ng-content>\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)=\"EmitPage($event)\"\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> -->\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                                    {{col.label}}\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\r\n    <!-- <div class=\"overflow-y-auto\">\r\n        @for (item of lstRows; track $index) {\r\n            <div class=\"border border-red-500 flex\">\r\n                {{$index}} - \r\n                @for (lbl of item.lstColumns; track $index) {\r\n                    ([{{lbl.label}}])\r\n                }\r\n            </div>\r\n        }\r\n    </div> -->\r\n</div>"]}
|