appproject-components 1.0.46 → 1.0.48
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.
|
@@ -272,4 +272,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.7", ngImpor
|
|
|
272
272
|
}], pageOffset: [{
|
|
273
273
|
type: Input
|
|
274
274
|
}] } });
|
|
275
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid-view.component.js","sourceRoot":"","sources":["../../../../../projects/appproject-components/src/lib/grid-view/grid-view.component.ts","../../../../../projects/appproject-components/src/lib/grid-view/grid-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output, SimpleChanges } from '@angular/core';\nimport { GridColuna, GridTabela, LibService } from 'appproject-lib';\n\n@Component({\n  selector: 'kb-grid-view',    \n  templateUrl: './grid-view.component.html',\n  styleUrl: './grid-view.component.scss'\n})\nexport class GridViewComponent {\n  @Input() empresaId: number;\n  @Input() tabelaCampos: GridTabela;\n  @Input() dataSet: Array<any>;\n  @Input() minHeight: string = '400px';\n  @Input() inMemoryPagination: boolean = false;\n\n  @Output() selecionarItem = new EventEmitter();\n  @Output() excluirItem = new EventEmitter();\n  @Output() selecionarChecked = new EventEmitter();\n\n  selectedItem: any;\n  //inputs = inject(new InjectionToken<any>('title inputs'));\n  grupos: any[] = [{ Coluna: '', Tabela: null, Dados: null, Nivel: 0 }];\n\n  // tabelaCampos = {\n  //   Selecionar: false,\n  //   Exportar: true,\n  //   Colunas: [\n  //     { Campo: 'Id', Titulo: 'Id', Tamanho: '10%', Ordem: true, Grupo: false, Filtrar: true, OrdemStatus: 0, Tipo: 'number', Valores: [], FiltroOperador: '=', FiltroValor: '', FiltroVisivel: false },\n  //     { Campo: 'Marca', Titulo: 'Marca', Tamanho: '25%', Ordem: true, Grupo: true, Filtrar: true, OrdemStatus: 0, Tipo: 'string', Valores: [], FiltroOperador: '=', FiltroValor: '', FiltroVisivel: false },\n  //     { Campo: 'Descricao', Titulo: 'Descrição', Tamanho: '25%', Ordem: true, Grupo: true, Filtrar: true, OrdemStatus: 0, Tipo: 'string', Valores: [], FiltroOperador: '=', FiltroValor: '', FiltroVisivel: false },\n  //     { Campo: 'Data', Titulo: 'Data', Tamanho: '20%', Ordem: true, Grupo: true, Filtrar: true, OrdemStatus: 0, Tipo: 'date', Valores: [], FiltroOperador: '=', FiltroValor: '', FiltroVisivel: false },\n  //     { Campo: 'Valor', Titulo: 'Valor', Tamanho: '20%', Ordem: true, Grupo: false, Filtrar: true, OrdemStatus: 0, Tipo: 'number', Valores: [], FiltroOperador: '=', FiltroValor: '', FiltroVisivel: false },\n  //   ]\n  // }\n\n  // dataSet: Array<any> = [\n  //   { Id: 1, Marca: 'Apple', Descricao: 'IPhone 14', Data: '2023-05-01', Valor: 7899.99 },\n  //   { Id: 2, Marca: 'Apple', Descricao: 'MacBook Pro', Data: '2023-06-01', Valor: 17999.99 },\n  //   { Id: 3, Marca: 'Samsung', Descricao: 'Galaxy S23', Data: '2023-05-01', Valor: 6899.99 },\n  //   { Id: 4, Marca: 'Sony', Descricao: 'PS 5', Data: '2023-06-01', Valor: 4899.99 },\n  //   { Id: 5, Marca: 'Samsung', Descricao: 'Watch 23', Data: '2023-05-01', Valor: 1899.99 },\n  // ]\n\n\n\n  groups = []\n  @Input() filteredDataSet = [];\n  pageDataSet = [];\n\n\n  //array com os campos filtrados para display\n  camposDisplay = [];\n\n  //filtro\n  isFiltroOpen: boolean = false;\n  selectedColuna: any;\n  todosSelecionados: boolean = false;\n\n  //pagination\n  //página atual\n  page: number = 1;\n  //registros por página\n  @Input() pageOffset: number = 20;\n  //total de registros\n  totalRec: number;\n  //total de páginas\n  totalPages: number;\n  //indexador de paginas\n  pages: number[];  \n  start: number;\n\n\n  constructor() { }\n\n  valoresFiltro() {\n    this.tabelaCampos.Colunas.forEach(c => {\n      if (c.Filtrar) {\n        //projetar a coluna\n        let initial = [];\n        let valores = this.dataSet.map(d => d[c.Campo]);\n        c.Valores = valores.filter((value, index, self) => {\n          return self.indexOf(value) === index;\n        }).map(v => { return { Selecionado: false, Valor: v } });\n      //   console.log(c.Campo, valores);\n      //   console.log(c.Valores)\n      }\n    })\n  }\n\n  ngOnInit() {\n\n\n    //this.inicializaGrupo();\n    //this.agrupar('Marca');\n    //console.log('inputs', this.inputs);\n    //console.log('Input empresa', this.empresaId);\n    GridTabela.init(this.tabelaCampos);\n    this.valoresFiltro();\n    this.filteredDataSet = this.dataSet;\n    console.log('Init Tabela campos', this.tabelaCampos);\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    console.log('On changes Tabela campos', this.tabelaCampos);\n    //evento chamado quando o dataset for atualizado\n    //inicializar vars de paginação\n    this.initPage();\n    this.todosSelecionados = false;\n  }\n\n  initPage() {\n    this.page = 1;\n    this.totalRec = this.filteredDataSet.length;\n    this.totalPages = Math.ceil(this.totalRec / this.pageOffset);    \n\n    if (this.inMemoryPagination === true) {\n      this.getRegistrosPage();\n    } else {\n      this.pageDataSet = this.filteredDataSet;\n    }\n  }\n\n  getRegistrosPage() {\n    this.start = (this.page - 1) * this.pageOffset;\n    console.log('dataset', this.filteredDataSet);\n    console.log('start', this.start);\n    console.log('offset', this.pageOffset);\n    this.pageDataSet = this.filteredDataSet.slice(this.start, (this.start + this.pageOffset));\n    console.log('page dataset', this.pageDataSet);\n  }\n\n  proximo() {\n    if (this.page < this.totalPages) {\n      this.page++;\n      this.getRegistrosPage();\n      this.gerarArrayPags();\n    }\n  }\n\n  anterior() {\n    if (this.page > 1) {\n      this.page--;\n      this.getRegistrosPage();\n      this.gerarArrayPags();\n    }\n  }\n\n  gerarArrayPags() {\n\n  }\n\n  inicializaGrupo() {\n    //inicializar o primeiro grupo 'default'\n    this.camposDisplay = this.tabelaCampos.Colunas;\n    this.grupos[0].Tabela = this.camposDisplay;\n    this.grupos[0].Dados = this.dataSet;\n  }\n\n  agrupar(campo: string) {\n    this.groups.push(campo);\n    let level = 0;\n    for (let g in this.groups) {\n      console.log(g);\n      //filtrar os dados\n      let result = this.dataSet.reduce((group, data) => {\n        const { g } = data;\n        group[g] = group[campo] ?? [];\n        group[g].push(data);\n        return group;\n      }, {});\n      console.log(result);\n    }\n\n  }\n\n  filtrarCampos(coluna = '') {\n    if (coluna != '') {\n\n    } else {\n\n    }\n  }\n\n  filtrar(col: GridColuna) {\n    //console.log('filtrar', col);\n    if (col.Valores && col.Valores.find(v => v.Selecionado) != null) {\n      const valores = col.Valores.filter(v => v.Selecionado).map(v => v.Valor);\n\n      //filtrar por valores selecionados\n      this.filteredDataSet = this.dataSet.filter(d => valores.indexOf(d[col.Campo]) > -1);\n    } else if (col.FiltroOperador && col.FiltroValor) {\n      //console.log(col.FiltroOperador, col.FiltroValor)\n      try {\n        this.filteredDataSet = this.dataSet.filter(d => {\n          switch (col.FiltroOperador) {\n            case \"=\":\n              return d[col.Campo] == col.FiltroValor;\n            case \">=\":\n              if (col.Tipo == 'number') {\n                return LibService.stringToDecimal(d[col.Campo], true) >= LibService.stringToDecimal(col.FiltroValor, true);  \n              } else if (col.Tipo == 'data') {\n                return new Date(this.dataToString(d[col.Campo])) >= new Date(this.dataToString(col.FiltroValor));  \n              } else\n              return d[col.Campo] >= col.FiltroValor;\n            case \"<=\":\n              if (col.Tipo == 'number') {\n                return LibService.stringToDecimal(d[col.Campo], true) <= LibService.stringToDecimal(col.FiltroValor, true);  \n              } else\n              return d[col.Campo] <= col.FiltroValor;\n            case \"tem\":\n              return d[col.Campo].toString().toLowerCase().indexOf(col.FiltroValor.toLowerCase()) > -1;\n            default:\n              return true;\n          }\n\n        });\n      } catch(ex) {\n        console.log(ex);\n        this.filteredDataSet = this.dataSet;\n      }\n    }\n    col.FiltroVisivel = false;\n\n    this.initPage();\n  }\n\n  getPage() {\n\n  }\n\n  limpar() {\n    this.filteredDataSet = this.dataSet;\n  }\n\n  dataToString(data: string): string {\n    if (data) {\n      return data.split('/').reverse().join('-');\n    } else {\n      return \"\";\n    }\n  }\n\n  ordenar(col: GridColuna) {\n    if (col.OrdemStatus == 0 || col.OrdemStatus == -1) {\n      if (col.Tipo == 'data') {\n        this.filteredDataSet.sort((a, b) => this.dataToString(a[col.Campo]) > this.dataToString(b[col.Campo]) ? 1 : (this.dataToString(a[col.Campo]) < this.dataToString(b[col.Campo]) ? -1 : 0));\n      } else if (col.Tipo == 'number') {\n        this.filteredDataSet.sort((a, b) => LibService.stringToDecimal(a[col.Campo]) > LibService.stringToDecimal(b[col.Campo]) ? 1 : (LibService.stringToDecimal(a[col.Campo]) < LibService.stringToDecimal(b[col.Campo]) ? -1 : 0));\n      } else \n        this.filteredDataSet.sort((a, b) => a[col.Campo] > b[col.Campo] ? 1 : (a[col.Campo] < b[col.Campo] ? -1 : 0));\n      col.OrdemStatus = 1; //asc\n    } else {\n      if (col.Tipo == 'data') {\n        this.filteredDataSet.sort((a, b) => this.dataToString(a[col.Campo]) < this.dataToString(b[col.Campo]) ? 1 : (this.dataToString(a[col.Campo]) > this.dataToString(b[col.Campo]) ? -1 : 0));\n      } else if (col.Tipo == 'number') {\n        this.filteredDataSet.sort((a, b) => LibService.stringToDecimal(a[col.Campo], true) < LibService.stringToDecimal(b[col.Campo], true) ? 1 : (LibService.stringToDecimal(a[col.Campo], true) > LibService.stringToDecimal(b[col.Campo], true) ? -1 : 0));\n      } else \n      this.filteredDataSet.sort((a, b) => a[col.Campo] < b[col.Campo] ? 1 : (a[col.Campo] > b[col.Campo] ? -1 : 0));\n      col.OrdemStatus = -1; //desc\n    }\n  }\n\n  setFiltroOpen(col: any) {\n    col.FiltroVisivel = !col.FiltroVisivel\n    if (col.FiltroVisivel) {\n      this.selectedColuna = col;\n      //console.log(this.selectedColuna);\n    }    \n  }\n\n  selecionarTodos() {\n    //this.todosSelecionados = !this.todosSelecionados;\n    this.filteredDataSet.forEach(item => {\n      item[this.tabelaCampos.CampoSelecionar] = this.todosSelecionados;\n    });\n    this.selecionarChecked.emit();\n  }\n\n  selecionarLinha(item: any) {\n    this.selecionarItem.emit(item);\n    this.selectedItem = item;\n  }\n\n  excluirLinha(item: any) {\n    this.excluirItem.emit(item);\n  }\n\n  //check\n  selecionadoChecked() {\n    this.selecionarChecked.emit();\n  }\n}\n","<div style=\"font-size: 14px;\">\n    <div id=\"painelExportacao\">\n      <ion-row *ngIf=\"inMemoryPagination\">\n        <!--\n        <ion-col size=\"2\">\n          <ion-button *ngIf=\"tabelaCampos.Selecionar === true\" size=\"small\" fill=\"outline\" color=\"medium\"\n            (click)=\"selecionarTodos()\">Selecionar Todos</ion-button>\n        </ion-col>\n        -->\n        <ion-col size=\"3\">\n          <ion-button *ngIf=\"inMemoryPagination === true\" size=\"small\" fill=\"outline\" color=\"bluetool\"\n            (click)=\"anterior()\">\n            <ion-icon name=\"chevron-back-outline\" slot=\"start\"></ion-icon>\n            Anterior\n          </ion-button>\n          <ion-button *ngIf=\"inMemoryPagination === true\" size=\"small\" fill=\"outline\" color=\"bluetool\"\n            (click)=\"proximo()\">\n            Próximo\n            <ion-icon name=\"chevron-forward-outline\" slot=\"end\"></ion-icon>\n          </ion-button>                \n        </ion-col>\n        <ion-col size=\"2\">\n          <span style=\"display: block; margin-top: 10px;\" *ngIf=\"inMemoryPagination && totalRec > 0\">Exibindo {{ start + 1 }} - {{ (start + pageOffset) < totalRec ? (start + pageOffset) : totalRec }} total de {{ totalRec }}        \n          </span>      \n        </ion-col>\n      </ion-row>\n    </div>\n    <div style=\"width: 100%;\" [style.min-height]=\"minHeight\">\n      <table class=\"grid\">\n        <thead>\n          <tr style=\"background-color: var(--ion-color-bluetool); color: white;\">\n            <td *ngIf=\"tabelaCampos.Selecionar === true\" style=\"width: 3%; text-align: center;\">\n              <input type=\"checkbox\" [(ngModel)]=\"todosSelecionados\" (change)=\"selecionarTodos()\">\n            </td>\n            <td *ngFor=\"let col of tabelaCampos.Colunas\" [style.width]=\"col.Tamanho\">\n              <div style=\"position: relative;\">\n                <div style=\"display: flex; justify-content: space-between; align-items: end;\">\n                  <strong>{{ col.Titulo }}</strong>\n                  <div>\n                    <ion-icon *ngIf=\"col.Ordem\" slot=\"end\" (click)=\"ordenar(col)\" style=\"cursor: pointer;\"\n                      [name]=\"col.OrdemStatus == 0 ? 'swap-vertical' : (col.OrdemStatus == 1 ? 'arrow-up': 'arrow-down')\"></ion-icon>\n  \n                    <ion-icon *ngIf=\"col.Filtrar\" name=\"funnel\" (click)=\"setFiltroOpen(col)\" slot=\"end\"></ion-icon>\n                  </div>\n                </div>\n  \n  \n                <div class=\"caixaGrande\" [hidden]=\"!col.FiltroVisivel\" tabindex=\"-1\"\n                  style=\"color: black; display: block; position: absolute; z-index: 800; width: 210px; right: 0px; opacity: 0.9;\">\n                  Filtrar:\n                  <div>\n                    <div style=\"display: flex; justify-content: space-between; align-items: start;\">\n                      <select style=\"width: 80px;\" [(ngModel)]=\"col.FiltroOperador\">\n                        <option>=</option>\n                        <option>&gt;=</option>\n                        <option>&lt;=</option>\n                        <option>tem</option>\n                      </select>\n                      <input style=\"width: 100px;\" type=\"text\" [(ngModel)]=\"col.FiltroValor\">\n                    </div>\n                    <ion-button size=\"small\" color=\"medium\" expand=\"block\" (click)=\"filtrar(col)\">Filtrar</ion-button>\n                    <ion-button size=\"small\" color=\"light\" expand=\"block\" (click)=\"limpar()\">Limpar</ion-button>\n                  </div>\n                  <div *ngIf=\"col.Valores\" class=\"scroll-container\" style=\"height: 200px; overflow-y: scroll;\">\n                    <div *ngFor=\"let valor of col.Valores\">\n                      <input type=\"checkbox\" [(ngModel)]=\"valor.Selecionado\">\n                      <span>{{ valor.Valor }}</span>\n                    </div>\n                  </div>\n                </div>\n  \n              </div>\n            </td>\n            <td *ngIf=\"tabelaCampos.Excluir === true\">\n  \n            </td>\n          </tr>\n        </thead>\n        <tbody>\n          <tr *ngFor=\"let item of pageDataSet\" [class]=\"item == selectedItem ? 'item-selecionado' : '' \">\n            <td *ngIf=\"tabelaCampos.Selecionar === true\" style=\"text-align: center; cursor: auto;\">\n              <input type=\"checkbox\" [(ngModel)]=\"item[tabelaCampos.CampoSelecionar]\" (change)=\"selecionadoChecked()\">\n            </td>\n            <td class=\"col\" *ngFor=\"let col of tabelaCampos.Colunas\" [style.width]=\"col.Tamanho\"\n              [style.text-align]=\"col.Tipo == 'number' ? 'right' : (col.Alinhamento ?? 'left')\"\n              (click)=\"col.ClickFunction ? col.ClickFunction(item) : selecionarLinha(item)\">\n              <span *ngIf=\"col.Pipe == 'date'\">{{ item[col.Campo] | date: 'dd/MM/yyyy' }}</span>              \n              <span *ngIf=\"col.Pipe == 'valor'\">{{ item[col.Campo] | valorFormat }}</span>\n              <span *ngIf=\"col.RenderFunction\" [innerHtml]=\"col.RenderFunction(item) | safeHtml\"></span>\n              <span *ngIf=\"!col.Pipe && !col.RenderFunction\">{{ item[col.Campo] ?? col.Default }}</span>\n            </td>\n            <td *ngIf=\"tabelaCampos.Excluir === true\" style=\"padding: 0px; text-align: center;\">\n              <ion-button size=\"small\" color=\"danger\" fill=\"outline\" style=\"transform: scale(0.85);\" (click)=\"excluirLinha(item)\">\n                <ion-icon name=\"trash\"></ion-icon>\n              </ion-button>\n            </td>\n          </tr>\n        </tbody>\n      </table>\n    </div>\n  \n    <ion-modal [isOpen]=\"isFiltroOpen\" (didDismiss)=\"isFiltroOpen = false;\">\n      <ng-template>\n        <ion-content class=\"ion-padding\">\n          <div class=\"caixaGrande\">\n            Filtrar:\n            <div *ngIf=\"selectedColuna.Valores\">\n              <div *ngFor=\"let valor of selectedColuna.Valores\">\n                <span>{{ valor }}</span>\n              </div>\n            </div>\n          </div>\n        </ion-content>\n      </ng-template>\n    </ion-modal>\n  </div>"]}
|
|
275
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid-view.component.js","sourceRoot":"","sources":["../../../../../projects/appproject-components/src/lib/grid-view/grid-view.component.ts","../../../../../projects/appproject-components/src/lib/grid-view/grid-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges } from '@angular/core';\nimport { GridColuna, GridTabela, LibService } from 'appproject-lib';\n\n@Component({\n  selector: 'kb-grid-view',    \n  templateUrl: './grid-view.component.html',\n  styleUrl: './grid-view.component.scss'\n})\nexport class GridViewComponent implements OnInit, OnChanges {\n  @Input() empresaId: number;\n  @Input() tabelaCampos: GridTabela;\n  @Input() dataSet: Array<any>;\n  @Input() minHeight: string = '400px';\n  @Input() inMemoryPagination: boolean = false;\n\n  @Output() selecionarItem = new EventEmitter();\n  @Output() excluirItem = new EventEmitter();\n  @Output() selecionarChecked = new EventEmitter();\n\n  selectedItem: any;\n  //inputs = inject(new InjectionToken<any>('title inputs'));\n  grupos: any[] = [{ Coluna: '', Tabela: null, Dados: null, Nivel: 0 }];\n\n  // tabelaCampos = {\n  //   Selecionar: false,\n  //   Exportar: true,\n  //   Colunas: [\n  //     { Campo: 'Id', Titulo: 'Id', Tamanho: '10%', Ordem: true, Grupo: false, Filtrar: true, OrdemStatus: 0, Tipo: 'number', Valores: [], FiltroOperador: '=', FiltroValor: '', FiltroVisivel: false },\n  //     { Campo: 'Marca', Titulo: 'Marca', Tamanho: '25%', Ordem: true, Grupo: true, Filtrar: true, OrdemStatus: 0, Tipo: 'string', Valores: [], FiltroOperador: '=', FiltroValor: '', FiltroVisivel: false },\n  //     { Campo: 'Descricao', Titulo: 'Descrição', Tamanho: '25%', Ordem: true, Grupo: true, Filtrar: true, OrdemStatus: 0, Tipo: 'string', Valores: [], FiltroOperador: '=', FiltroValor: '', FiltroVisivel: false },\n  //     { Campo: 'Data', Titulo: 'Data', Tamanho: '20%', Ordem: true, Grupo: true, Filtrar: true, OrdemStatus: 0, Tipo: 'date', Valores: [], FiltroOperador: '=', FiltroValor: '', FiltroVisivel: false },\n  //     { Campo: 'Valor', Titulo: 'Valor', Tamanho: '20%', Ordem: true, Grupo: false, Filtrar: true, OrdemStatus: 0, Tipo: 'number', Valores: [], FiltroOperador: '=', FiltroValor: '', FiltroVisivel: false },\n  //   ]\n  // }\n\n  // dataSet: Array<any> = [\n  //   { Id: 1, Marca: 'Apple', Descricao: 'IPhone 14', Data: '2023-05-01', Valor: 7899.99 },\n  //   { Id: 2, Marca: 'Apple', Descricao: 'MacBook Pro', Data: '2023-06-01', Valor: 17999.99 },\n  //   { Id: 3, Marca: 'Samsung', Descricao: 'Galaxy S23', Data: '2023-05-01', Valor: 6899.99 },\n  //   { Id: 4, Marca: 'Sony', Descricao: 'PS 5', Data: '2023-06-01', Valor: 4899.99 },\n  //   { Id: 5, Marca: 'Samsung', Descricao: 'Watch 23', Data: '2023-05-01', Valor: 1899.99 },\n  // ]\n\n\n\n  groups = []\n  @Input() filteredDataSet = [];\n  pageDataSet = [];\n\n\n  //array com os campos filtrados para display\n  camposDisplay = [];\n\n  //filtro\n  isFiltroOpen: boolean = false;\n  selectedColuna: any;\n  todosSelecionados: boolean = false;\n\n  //pagination\n  //página atual\n  page: number = 1;\n  //registros por página\n  @Input() pageOffset: number = 20;\n  //total de registros\n  totalRec: number;\n  //total de páginas\n  totalPages: number;\n  //indexador de paginas\n  pages: number[];  \n  start: number;\n\n\n  constructor() { }\n\n  valoresFiltro() {\n    this.tabelaCampos.Colunas.forEach(c => {\n      if (c.Filtrar) {\n        //projetar a coluna\n        let initial = [];\n        let valores = this.dataSet.map(d => d[c.Campo]);\n        c.Valores = valores.filter((value, index, self) => {\n          return self.indexOf(value) === index;\n        }).map(v => { return { Selecionado: false, Valor: v } });\n      //   console.log(c.Campo, valores);\n      //   console.log(c.Valores)\n      }\n    })\n  }\n\n  ngOnInit() {\n\n\n    //this.inicializaGrupo();\n    //this.agrupar('Marca');\n    //console.log('inputs', this.inputs);\n    //console.log('Input empresa', this.empresaId);\n    GridTabela.init(this.tabelaCampos);\n    this.valoresFiltro();\n    this.filteredDataSet = this.dataSet;\n    console.log('Init Tabela campos', this.tabelaCampos);\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    console.log('On changes Tabela campos', this.tabelaCampos);\n    //evento chamado quando o dataset for atualizado\n    //inicializar vars de paginação\n    this.initPage();\n    this.todosSelecionados = false;\n  }\n\n  initPage() {\n    this.page = 1;\n    this.totalRec = this.filteredDataSet.length;\n    this.totalPages = Math.ceil(this.totalRec / this.pageOffset);    \n\n    if (this.inMemoryPagination === true) {\n      this.getRegistrosPage();\n    } else {\n      this.pageDataSet = this.filteredDataSet;\n    }\n  }\n\n  getRegistrosPage() {\n    this.start = (this.page - 1) * this.pageOffset;\n    console.log('dataset', this.filteredDataSet);\n    console.log('start', this.start);\n    console.log('offset', this.pageOffset);\n    this.pageDataSet = this.filteredDataSet.slice(this.start, (this.start + this.pageOffset));\n    console.log('page dataset', this.pageDataSet);\n  }\n\n  proximo() {\n    if (this.page < this.totalPages) {\n      this.page++;\n      this.getRegistrosPage();\n      this.gerarArrayPags();\n    }\n  }\n\n  anterior() {\n    if (this.page > 1) {\n      this.page--;\n      this.getRegistrosPage();\n      this.gerarArrayPags();\n    }\n  }\n\n  gerarArrayPags() {\n\n  }\n\n  inicializaGrupo() {\n    //inicializar o primeiro grupo 'default'\n    this.camposDisplay = this.tabelaCampos.Colunas;\n    this.grupos[0].Tabela = this.camposDisplay;\n    this.grupos[0].Dados = this.dataSet;\n  }\n\n  agrupar(campo: string) {\n    this.groups.push(campo);\n    let level = 0;\n    for (let g in this.groups) {\n      console.log(g);\n      //filtrar os dados\n      let result = this.dataSet.reduce((group, data) => {\n        const { g } = data;\n        group[g] = group[campo] ?? [];\n        group[g].push(data);\n        return group;\n      }, {});\n      console.log(result);\n    }\n\n  }\n\n  filtrarCampos(coluna = '') {\n    if (coluna != '') {\n\n    } else {\n\n    }\n  }\n\n  filtrar(col: GridColuna) {\n    //console.log('filtrar', col);\n    if (col.Valores && col.Valores.find(v => v.Selecionado) != null) {\n      const valores = col.Valores.filter(v => v.Selecionado).map(v => v.Valor);\n\n      //filtrar por valores selecionados\n      this.filteredDataSet = this.dataSet.filter(d => valores.indexOf(d[col.Campo]) > -1);\n    } else if (col.FiltroOperador && col.FiltroValor) {\n      //console.log(col.FiltroOperador, col.FiltroValor)\n      try {\n        this.filteredDataSet = this.dataSet.filter(d => {\n          switch (col.FiltroOperador) {\n            case \"=\":\n              return d[col.Campo] == col.FiltroValor;\n            case \">=\":\n              if (col.Tipo == 'number') {\n                return LibService.stringToDecimal(d[col.Campo], true) >= LibService.stringToDecimal(col.FiltroValor, true);  \n              } else if (col.Tipo == 'data') {\n                return new Date(this.dataToString(d[col.Campo])) >= new Date(this.dataToString(col.FiltroValor));  \n              } else\n              return d[col.Campo] >= col.FiltroValor;\n            case \"<=\":\n              if (col.Tipo == 'number') {\n                return LibService.stringToDecimal(d[col.Campo], true) <= LibService.stringToDecimal(col.FiltroValor, true);  \n              } else\n              return d[col.Campo] <= col.FiltroValor;\n            case \"tem\":\n              return d[col.Campo].toString().toLowerCase().indexOf(col.FiltroValor.toLowerCase()) > -1;\n            default:\n              return true;\n          }\n\n        });\n      } catch(ex) {\n        console.log(ex);\n        this.filteredDataSet = this.dataSet;\n      }\n    }\n    col.FiltroVisivel = false;\n\n    this.initPage();\n  }\n\n  getPage() {\n\n  }\n\n  limpar() {\n    this.filteredDataSet = this.dataSet;\n  }\n\n  dataToString(data: string): string {\n    if (data) {\n      return data.split('/').reverse().join('-');\n    } else {\n      return \"\";\n    }\n  }\n\n  ordenar(col: GridColuna) {\n    if (col.OrdemStatus == 0 || col.OrdemStatus == -1) {\n      if (col.Tipo == 'data') {\n        this.filteredDataSet.sort((a, b) => this.dataToString(a[col.Campo]) > this.dataToString(b[col.Campo]) ? 1 : (this.dataToString(a[col.Campo]) < this.dataToString(b[col.Campo]) ? -1 : 0));\n      } else if (col.Tipo == 'number') {\n        this.filteredDataSet.sort((a, b) => LibService.stringToDecimal(a[col.Campo]) > LibService.stringToDecimal(b[col.Campo]) ? 1 : (LibService.stringToDecimal(a[col.Campo]) < LibService.stringToDecimal(b[col.Campo]) ? -1 : 0));\n      } else \n        this.filteredDataSet.sort((a, b) => a[col.Campo] > b[col.Campo] ? 1 : (a[col.Campo] < b[col.Campo] ? -1 : 0));\n      col.OrdemStatus = 1; //asc\n    } else {\n      if (col.Tipo == 'data') {\n        this.filteredDataSet.sort((a, b) => this.dataToString(a[col.Campo]) < this.dataToString(b[col.Campo]) ? 1 : (this.dataToString(a[col.Campo]) > this.dataToString(b[col.Campo]) ? -1 : 0));\n      } else if (col.Tipo == 'number') {\n        this.filteredDataSet.sort((a, b) => LibService.stringToDecimal(a[col.Campo], true) < LibService.stringToDecimal(b[col.Campo], true) ? 1 : (LibService.stringToDecimal(a[col.Campo], true) > LibService.stringToDecimal(b[col.Campo], true) ? -1 : 0));\n      } else \n      this.filteredDataSet.sort((a, b) => a[col.Campo] < b[col.Campo] ? 1 : (a[col.Campo] > b[col.Campo] ? -1 : 0));\n      col.OrdemStatus = -1; //desc\n    }\n  }\n\n  setFiltroOpen(col: any) {\n    col.FiltroVisivel = !col.FiltroVisivel\n    if (col.FiltroVisivel) {\n      this.selectedColuna = col;\n      //console.log(this.selectedColuna);\n    }    \n  }\n\n  selecionarTodos() {\n    //this.todosSelecionados = !this.todosSelecionados;\n    this.filteredDataSet.forEach(item => {\n      item[this.tabelaCampos.CampoSelecionar] = this.todosSelecionados;\n    });\n    this.selecionarChecked.emit();\n  }\n\n  selecionarLinha(item: any) {\n    this.selecionarItem.emit(item);\n    this.selectedItem = item;\n  }\n\n  excluirLinha(item: any) {\n    this.excluirItem.emit(item);\n  }\n\n  //check\n  selecionadoChecked() {\n    this.selecionarChecked.emit();\n  }\n}\n","<div style=\"font-size: 14px;\">\n    <div id=\"painelExportacao\">\n      <ion-row *ngIf=\"inMemoryPagination\">\n        <!--\n        <ion-col size=\"2\">\n          <ion-button *ngIf=\"tabelaCampos.Selecionar === true\" size=\"small\" fill=\"outline\" color=\"medium\"\n            (click)=\"selecionarTodos()\">Selecionar Todos</ion-button>\n        </ion-col>\n        -->\n        <ion-col size=\"3\">\n          <ion-button *ngIf=\"inMemoryPagination === true\" size=\"small\" fill=\"outline\" color=\"bluetool\"\n            (click)=\"anterior()\">\n            <ion-icon name=\"chevron-back-outline\" slot=\"start\"></ion-icon>\n            Anterior\n          </ion-button>\n          <ion-button *ngIf=\"inMemoryPagination === true\" size=\"small\" fill=\"outline\" color=\"bluetool\"\n            (click)=\"proximo()\">\n            Próximo\n            <ion-icon name=\"chevron-forward-outline\" slot=\"end\"></ion-icon>\n          </ion-button>                \n        </ion-col>\n        <ion-col size=\"2\">\n          <span style=\"display: block; margin-top: 10px;\" *ngIf=\"inMemoryPagination && totalRec > 0\">Exibindo {{ start + 1 }} - {{ (start + pageOffset) < totalRec ? (start + pageOffset) : totalRec }} total de {{ totalRec }}        \n          </span>      \n        </ion-col>\n      </ion-row>\n    </div>\n    <div style=\"width: 100%;\" [style.min-height]=\"minHeight\">\n      <table class=\"grid\">\n        <thead>\n          <tr style=\"background-color: var(--ion-color-bluetool); color: white;\">\n            <td *ngIf=\"tabelaCampos.Selecionar === true\" style=\"width: 3%; text-align: center;\">\n              <input type=\"checkbox\" [(ngModel)]=\"todosSelecionados\" (change)=\"selecionarTodos()\">\n            </td>\n            <td *ngFor=\"let col of tabelaCampos.Colunas\" [style.width]=\"col.Tamanho\">\n              <div style=\"position: relative;\">\n                <div style=\"display: flex; justify-content: space-between; align-items: end;\">\n                  <strong>{{ col.Titulo }}</strong>\n                  <div>\n                    <ion-icon *ngIf=\"col.Ordem\" slot=\"end\" (click)=\"ordenar(col)\" style=\"cursor: pointer;\"\n                      [name]=\"col.OrdemStatus == 0 ? 'swap-vertical' : (col.OrdemStatus == 1 ? 'arrow-up': 'arrow-down')\"></ion-icon>\n  \n                    <ion-icon *ngIf=\"col.Filtrar\" name=\"funnel\" (click)=\"setFiltroOpen(col)\" slot=\"end\"></ion-icon>\n                  </div>\n                </div>\n  \n  \n                <div class=\"caixaGrande\" [hidden]=\"!col.FiltroVisivel\" tabindex=\"-1\"\n                  style=\"color: black; display: block; position: absolute; z-index: 800; width: 210px; right: 0px; opacity: 0.9;\">\n                  Filtrar:\n                  <div>\n                    <div style=\"display: flex; justify-content: space-between; align-items: start;\">\n                      <select style=\"width: 80px;\" [(ngModel)]=\"col.FiltroOperador\">\n                        <option>=</option>\n                        <option>&gt;=</option>\n                        <option>&lt;=</option>\n                        <option>tem</option>\n                      </select>\n                      <input style=\"width: 100px;\" type=\"text\" [(ngModel)]=\"col.FiltroValor\">\n                    </div>\n                    <ion-button size=\"small\" color=\"medium\" expand=\"block\" (click)=\"filtrar(col)\">Filtrar</ion-button>\n                    <ion-button size=\"small\" color=\"light\" expand=\"block\" (click)=\"limpar()\">Limpar</ion-button>\n                  </div>\n                  <div *ngIf=\"col.Valores\" class=\"scroll-container\" style=\"height: 200px; overflow-y: scroll;\">\n                    <div *ngFor=\"let valor of col.Valores\">\n                      <input type=\"checkbox\" [(ngModel)]=\"valor.Selecionado\">\n                      <span>{{ valor.Valor }}</span>\n                    </div>\n                  </div>\n                </div>\n  \n              </div>\n            </td>\n            <td *ngIf=\"tabelaCampos.Excluir === true\">\n  \n            </td>\n          </tr>\n        </thead>\n        <tbody>\n          <tr *ngFor=\"let item of pageDataSet\" [class]=\"item == selectedItem ? 'item-selecionado' : '' \">\n            <td *ngIf=\"tabelaCampos.Selecionar === true\" style=\"text-align: center; cursor: auto;\">\n              <input type=\"checkbox\" [(ngModel)]=\"item[tabelaCampos.CampoSelecionar]\" (change)=\"selecionadoChecked()\">\n            </td>\n            <td class=\"col\" *ngFor=\"let col of tabelaCampos.Colunas\" [style.width]=\"col.Tamanho\"\n              [style.text-align]=\"col.Tipo == 'number' ? 'right' : (col.Alinhamento ?? 'left')\"\n              (click)=\"col.ClickFunction ? col.ClickFunction(item) : selecionarLinha(item)\">\n              <span *ngIf=\"col.Pipe == 'date'\">{{ item[col.Campo] | date: 'dd/MM/yyyy' }}</span>              \n              <span *ngIf=\"col.Pipe == 'valor'\">{{ item[col.Campo] | valorFormat }}</span>\n              <span *ngIf=\"col.RenderFunction\" [innerHtml]=\"col.RenderFunction(item) | safeHtml\"></span>\n              <span *ngIf=\"!col.Pipe && !col.RenderFunction\">{{ item[col.Campo] ?? col.Default }}</span>\n            </td>\n            <td *ngIf=\"tabelaCampos.Excluir === true\" style=\"padding: 0px; text-align: center;\">\n              <ion-button size=\"small\" color=\"danger\" fill=\"outline\" style=\"transform: scale(0.85);\" (click)=\"excluirLinha(item)\">\n                <ion-icon name=\"trash\"></ion-icon>\n              </ion-button>\n            </td>\n          </tr>\n        </tbody>\n      </table>\n    </div>\n  \n    <ion-modal [isOpen]=\"isFiltroOpen\" (didDismiss)=\"isFiltroOpen = false;\">\n      <ng-template>\n        <ion-content class=\"ion-padding\">\n          <div class=\"caixaGrande\">\n            Filtrar:\n            <div *ngIf=\"selectedColuna.Valores\">\n              <div *ngFor=\"let valor of selectedColuna.Valores\">\n                <span>{{ valor }}</span>\n              </div>\n            </div>\n          </div>\n        </ion-content>\n      </ng-template>\n    </ion-modal>\n  </div>"]}
|