keevo-components 0.3.0 → 0.3.1

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.
@@ -101,10 +101,10 @@ export class TableComponent {
101
101
  return value;
102
102
  }
103
103
  adjustTableSize() {
104
- if (this.screenSize > 1400)
105
- this.selectedSize = '';
106
- else
104
+ if ((this.screenSize < 1600 && this.screenSize > 1200 || this.screenSize < 760))
107
105
  this.selectedSize = 'p-datatable-sm';
106
+ else
107
+ this.selectedSize = '';
108
108
  }
109
109
  }
110
110
  TableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: TableComponent, deps: [{ token: i1.DatePipe }, { token: i1.DecimalPipe }, { token: i2.CodigoFipePipe }, { token: i3.CpfCnpjPipe }, { token: i4.TelefonePipe }], target: i0.ɵɵFactoryTarget.Component });
@@ -143,4 +143,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImpor
143
143
  }], onSelectionChange: [{
144
144
  type: Output
145
145
  }] } });
146
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../projects/keevo-components/src/lib/table/table.component.ts","../../../../../projects/keevo-components/src/lib/table/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DatePipe, DecimalPipe } from '@angular/common';\r\nimport { Component, ContentChildren, EventEmitter, HostListener, Input, OnInit, Output, QueryList, TemplateRef, ViewChild } from '@angular/core';\r\nimport { Table } from 'primeng/table';\r\n\r\n\r\nimport { outputAst } from '@angular/compiler';\r\nimport { TableConfig } from '../api/components/table/table.config';\r\nimport { TableConfigColumn } from '../api/components/table/table.config.column';\r\nimport { TablePaginate } from '../api/components/table/table.paginate';\r\nimport { TemplateDirective } from '../directives/template.directive';\r\nimport { CodigoFipePipe } from '../pipes/codigofile.pipe';\r\nimport { CpfCnpjPipe } from '../pipes/cpfcnpj.pipe';\r\nimport { TelefonePipe } from '../pipes/telefone.pipe';\r\n\r\n@Component({\r\n  selector: 'kv-table',\r\n  templateUrl: './table.component.html',\r\n  styleUrls: ['./table.component.scss']\r\n})\r\nexport class TableComponent implements OnInit {\r\n  config!: TableConfig;\r\n  pesquisaValue!: string;\r\n  globalFilterFields: string[] = [];\r\n  actionsTemplate!: TemplateRef<any>;\r\n\r\n  selectedSize: string = '';\r\n  screenSize!: number;\r\n\r\n  @ContentChildren(TemplateDirective) templates!: QueryList<any>;\r\n\r\n  @HostListener('window:resize', ['$event'])\r\n  onWindowResize() {\r\n    this.screenSize = window.innerWidth;\r\n    this.adjustTableSize();\r\n  }\r\n\r\n  @ViewChild('table', { static: false }) table!: Table;\r\n\r\n  @Input('config') set setConfig(value: TableConfig) {\r\n    this.config = {\r\n      enableCation: value.enableCation || true,\r\n      enableSelect: value.enableSelect || false,\r\n      enableFilter: value.enableFilter || true,\r\n      ...value,\r\n    };\r\n\r\n    if (this.config.enableFilter) {\r\n      this.config.columns.forEach(col => {\r\n        this.globalFilterFields.push(col.field);\r\n      });\r\n    }\r\n  }\r\n\r\n  @Input() dataSource: any;\r\n  @Input() selectedItems: any;\r\n  @Input() totalRecords!: number;\r\n  @Input() lazy: boolean = true;\r\n  @Input() paginator: boolean = true;\r\n  @Input() rowsPerPageOptions!: number[];\r\n\r\n  @Output() onActiveItem: EventEmitter<any> = new EventEmitter();\r\n  @Output() onPaginate: EventEmitter<any> = new EventEmitter();\r\n  @Output() onSelectionChange: EventEmitter<any> = new EventEmitter();\r\n\r\n  constructor(private readonly datePipe: DatePipe,\r\n    private readonly decimalPipe: DecimalPipe,\r\n    private readonly codigoFipePipe: CodigoFipePipe,\r\n    private readonly cpfCnpjPipe: CpfCnpjPipe,\r\n    private readonly telefonePipe: TelefonePipe) { }\r\n\r\n  ngOnInit() {\r\n    this.screenSize = window.innerWidth;\r\n    this.adjustTableSize();\r\n  }\r\n\r\n  public activeItem(rowData: any) {\r\n    this.onActiveItem.emit(rowData);\r\n  }\r\n\r\n  isBooleanField(rowData: any, col: TableConfigColumn): boolean {\r\n    return typeof rowData[col.field] == 'boolean';\r\n  }\r\n\r\n  public onGlobalFilter(table: Table, event: Event) {\r\n    table.filterGlobal((event.target as HTMLInputElement).value, 'contains');\r\n  }\r\n\r\n  public paginate(event: any) {\r\n    if (event) {\r\n      let paginaInicial = ((event?.first > 0) ? (event.first / event.rows) : event.first) + 1;\r\n      let termoPesquisa = '';\r\n      let ordenacao = '';\r\n\r\n      if (event.globalFilter)\r\n        termoPesquisa = event.globalFilter;\r\n\r\n      if (event.sortField) {\r\n        ordenacao = `${event.sortField} ${(event.sortOrder === 1) ? 'ASC' : 'DESC'}`;\r\n      }\r\n\r\n      const objeto: TablePaginate = {\r\n        paginaInicial: paginaInicial,\r\n        tamanhoPagina: event.rows,\r\n        termoPesquisa: termoPesquisa,\r\n        ordenacao: ordenacao\r\n      };\r\n\r\n      this.onPaginate.emit(objeto);\r\n    }\r\n  }\r\n\r\n  selectionChange(value = []) {\r\n    this.onSelectionChange.emit(value);\r\n  }\r\n\r\n  transformValue(rowData: any, col: TableConfigColumn) {\r\n    let value = rowData[col.field];\r\n\r\n    if (!col.pipe) return value;\r\n\r\n    switch (col.pipe) {\r\n      case 'date':\r\n        value = this.datePipe.transform(value, 'dd/MM/yyyy');\r\n        break;\r\n      case 'decimal':\r\n        value = this.decimalPipe.transform(value, '1.2-2', 'pt-BR');\r\n        break;\r\n      case 'cpfcnpj':\r\n        value = this.cpfCnpjPipe.transform(value);\r\n        break;\r\n      case 'telefone':\r\n        value = this.telefonePipe.transform(value);\r\n        break;\r\n      case 'codigofipe':\r\n        value = this.codigoFipePipe.transform(value);\r\n        break;\r\n    }\r\n\r\n    return value;\r\n  }\r\n\r\n  adjustTableSize() {\r\n    if (this.screenSize > 1400)\r\n      this.selectedSize = '';\r\n    else this.selectedSize = 'p-datatable-sm';\r\n  }\r\n}\r\n","<p-table *ngIf=\"config\" #dt styleClass=\"p-datatable-striped {{selectedSize}}\" [value]=\"dataSource\"\n  [(selection)]=\"selectedItems\" [columns]=\"config.columns\" [globalFilterFields]=\"globalFilterFields\" [rows]=\"5\"\n  [paginator]=\"paginator\" [rowsPerPageOptions]=\"rowsPerPageOptions\" [showCurrentPageReport]=\"true\"\n  currentPageReportTemplate=\"{first} - {last} de {totalRecords}\" [rowHover]=\"true\" [totalRecords]=\"totalRecords\"\n  [lazy]=\"config.lazy\" (onLazyLoad)=\"paginate($event)\" (selectionChange)=\"selectionChange($event)\"\n  rowGroupMode=\"rowspan\" [groupRowsBy]=\"config.fieldGroup\" [showFirstLastIcon]=\"false\"\n  [tableStyle]=\"{ 'min-width': '35rem' }\" [pageLinks]=\"1\">\n\n  <ng-template pTemplate=\"caption\" *ngIf=\"config.enableCation\">\n    <div class=\"flex flex-column md:flex-row md:justify-content-between\n      md:align-items-center\">\n      <h5 class=\"m-0\">{{ config.title }}</h5>\n      <span *ngIf=\"config.enableFilter\" class=\"block mt-2 md:mt-0\n        p-input-icon-left\">\n        <i class=\"pi pi-search\"></i>\n        <input pInputText pAutoFocus [autofocus]=\"true\" type=\"text\" (input)=\"onGlobalFilter(dt, $event)\"\n          placeholder=\"Pesquisar...\" class=\"w-full sm:w-auto\" />\n      </span>\n    </div>\n  </ng-template>\n\n  <ng-template pTemplate=\"header\" let-columns>\n    <tr>\n      <th style=\"width: 4rem\" *ngIf=\"config.enableSelect\">\n        <p-tableHeaderCheckbox></p-tableHeaderCheckbox>\n      </th>\n      <th *ngFor=\"let col of columns;\" [pSortableColumn]=\"col.field\" [pSortableColumnDisabled]=\"col.sortable === false\"\n        [style.width]=\"col.width\" class=\"text-sm\">\n        <div class=\"flex flex-row\">\n          {{col.header}}\n          <p-sortIcon *ngIf=\"col.sortable === true\" [field]=\"col.field\" style=\"font-size: 10px;\"></p-sortIcon>\n        </div>\n\n      </th>\n      <th *ngIf=\"config.actions && config.actions.length> 0\"></th>\n    </tr>\n  </ng-template>\n\n  <ng-template pTemplate=\"body\" let-rowData let-columns=\"columns\" let-rowgroup=\"rowgroup\" let-rowspan=\"rowspan\">\n    <tr>\n      <td *ngIf=\"config.enableSelect\">\n        <p-tableCheckbox [value]=\"rowData\"></p-tableCheckbox>\n      </td>\n\n      <ng-container *ngFor=\"let col of columns\">\n\n        <td *ngIf=\"rowgroup\" [attr.rowspan]=\"rowgroup && col.grouped? rowspan: null\">\n          <span class=\"p-column-title\">{{col.header}}</span>\n          <span *ngIf=\"!isBooleanField(rowData, col); else booleanField\" [class]=\"(screenSize < 1600 && screenSize > 1200 || screenSize < 760) ? 'text-xs' : 'text-sm'\">\n            {{ transformValue(rowData, col) }}\n          </span>\n\n          <ng-template #booleanField>\n            <i [ngClass]=\"rowData[col.field] ? 'pi pi-check' : 'pi pi-times'\"></i>\n          </ng-template>\n        </td>\n\n        <td *ngIf=\"!rowgroup && !col.grouped\">\n          <span class=\"p-column-title\">{{col.header}}</span>\n          <span *ngIf=\"!isBooleanField(rowData, col); else booleanField\" [class]=\"(screenSize < 1600 && screenSize > 1200 || screenSize < 760) ? 'text-xs' : 'text-sm'\">\n            {{ transformValue(rowData, col) }}\n          </span>\n\n          <ng-template #booleanField>\n            <i [ngClass]=\"rowData[col.field] ? 'pi pi-check' : 'pi pi-times'\"></i>\n          </ng-template>\n        </td>\n\n      </ng-container>\n\n      <!-- <td *ngIf=\"config.actions && config.actions.length> 0\">\n        <i class=\"pi pi-ellipsis-h\" style=\"cursor: pointer\"\n          (click)=\"activeItem(rowData);menu.toggle($event)\"></i>\n      </td> -->\n\n      <td *ngIf=\"config.actions && config.actions.length> 0\" class=\"flex flex-row\">\n        <div *ngFor=\"let action of config.actions\">\n          <i class=\"pi {{action.icon}}\" style=\"cursor: pointer\" class=\"mr-2 ml-2\" (click)=\"action?.command()\"></i>\n        </div>\n      </td>\n\n    </tr>\n  </ng-template>\n\n  <ng-template pTemplate=\"emptymessage\" let-columns>\n    <tr>\n      <td [attr.colspan]=\"columns.length\" style=\"text-align: center;\">\n        Nenhum registro encontrado\n      </td>\n    </tr>\n  </ng-template>\n</p-table>\n<p-menu #menu [popup]=\"true\" [model]=\"config.actions\"></p-menu>\n"]}
146
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../projects/keevo-components/src/lib/table/table.component.ts","../../../../../projects/keevo-components/src/lib/table/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DatePipe, DecimalPipe } from '@angular/common';\r\nimport { Component, ContentChildren, EventEmitter, HostListener, Input, OnInit, Output, QueryList, TemplateRef, ViewChild } from '@angular/core';\r\nimport { Table } from 'primeng/table';\r\n\r\n\r\nimport { outputAst } from '@angular/compiler';\r\nimport { TableConfig } from '../api/components/table/table.config';\r\nimport { TableConfigColumn } from '../api/components/table/table.config.column';\r\nimport { TablePaginate } from '../api/components/table/table.paginate';\r\nimport { TemplateDirective } from '../directives/template.directive';\r\nimport { CodigoFipePipe } from '../pipes/codigofile.pipe';\r\nimport { CpfCnpjPipe } from '../pipes/cpfcnpj.pipe';\r\nimport { TelefonePipe } from '../pipes/telefone.pipe';\r\n\r\n@Component({\r\n  selector: 'kv-table',\r\n  templateUrl: './table.component.html',\r\n  styleUrls: ['./table.component.scss']\r\n})\r\nexport class TableComponent implements OnInit {\r\n  config!: TableConfig;\r\n  pesquisaValue!: string;\r\n  globalFilterFields: string[] = [];\r\n  actionsTemplate!: TemplateRef<any>;\r\n\r\n  selectedSize: string = '';\r\n  screenSize!: number;\r\n\r\n  @ContentChildren(TemplateDirective) templates!: QueryList<any>;\r\n\r\n  @HostListener('window:resize', ['$event'])\r\n  onWindowResize() {\r\n    this.screenSize = window.innerWidth;\r\n    this.adjustTableSize();\r\n  }\r\n\r\n  @ViewChild('table', { static: false }) table!: Table;\r\n\r\n  @Input('config') set setConfig(value: TableConfig) {\r\n    this.config = {\r\n      enableCation: value.enableCation || true,\r\n      enableSelect: value.enableSelect || false,\r\n      enableFilter: value.enableFilter || true,\r\n      ...value,\r\n    };\r\n\r\n    if (this.config.enableFilter) {\r\n      this.config.columns.forEach(col => {\r\n        this.globalFilterFields.push(col.field);\r\n      });\r\n    }\r\n  }\r\n\r\n  @Input() dataSource: any;\r\n  @Input() selectedItems: any;\r\n  @Input() totalRecords!: number;\r\n  @Input() lazy: boolean = true;\r\n  @Input() paginator: boolean = true;\r\n  @Input() rowsPerPageOptions!: number[];\r\n\r\n  @Output() onActiveItem: EventEmitter<any> = new EventEmitter();\r\n  @Output() onPaginate: EventEmitter<any> = new EventEmitter();\r\n  @Output() onSelectionChange: EventEmitter<any> = new EventEmitter();\r\n\r\n  constructor(private readonly datePipe: DatePipe,\r\n    private readonly decimalPipe: DecimalPipe,\r\n    private readonly codigoFipePipe: CodigoFipePipe,\r\n    private readonly cpfCnpjPipe: CpfCnpjPipe,\r\n    private readonly telefonePipe: TelefonePipe) { }\r\n\r\n  ngOnInit() {\r\n    this.screenSize = window.innerWidth;\r\n    this.adjustTableSize();\r\n  }\r\n\r\n  public activeItem(rowData: any) {\r\n    this.onActiveItem.emit(rowData);\r\n  }\r\n\r\n  isBooleanField(rowData: any, col: TableConfigColumn): boolean {\r\n    return typeof rowData[col.field] == 'boolean';\r\n  }\r\n\r\n  public onGlobalFilter(table: Table, event: Event) {\r\n    table.filterGlobal((event.target as HTMLInputElement).value, 'contains');\r\n  }\r\n\r\n  public paginate(event: any) {\r\n    if (event) {\r\n      let paginaInicial = ((event?.first > 0) ? (event.first / event.rows) : event.first) + 1;\r\n      let termoPesquisa = '';\r\n      let ordenacao = '';\r\n\r\n      if (event.globalFilter)\r\n        termoPesquisa = event.globalFilter;\r\n\r\n      if (event.sortField) {\r\n        ordenacao = `${event.sortField} ${(event.sortOrder === 1) ? 'ASC' : 'DESC'}`;\r\n      }\r\n\r\n      const objeto: TablePaginate = {\r\n        paginaInicial: paginaInicial,\r\n        tamanhoPagina: event.rows,\r\n        termoPesquisa: termoPesquisa,\r\n        ordenacao: ordenacao\r\n      };\r\n\r\n      this.onPaginate.emit(objeto);\r\n    }\r\n  }\r\n\r\n  selectionChange(value = []) {\r\n    this.onSelectionChange.emit(value);\r\n  }\r\n\r\n  transformValue(rowData: any, col: TableConfigColumn) {\r\n    let value = rowData[col.field];\r\n\r\n    if (!col.pipe) return value;\r\n\r\n    switch (col.pipe) {\r\n      case 'date':\r\n        value = this.datePipe.transform(value, 'dd/MM/yyyy');\r\n        break;\r\n      case 'decimal':\r\n        value = this.decimalPipe.transform(value, '1.2-2', 'pt-BR');\r\n        break;\r\n      case 'cpfcnpj':\r\n        value = this.cpfCnpjPipe.transform(value);\r\n        break;\r\n      case 'telefone':\r\n        value = this.telefonePipe.transform(value);\r\n        break;\r\n      case 'codigofipe':\r\n        value = this.codigoFipePipe.transform(value);\r\n        break;\r\n    }\r\n\r\n    return value;\r\n  }\r\n\r\n  adjustTableSize() {\r\n    if ((this.screenSize < 1600 && this.screenSize > 1200 || this.screenSize < 760))\r\n      this.selectedSize = 'p-datatable-sm';\r\n    else this.selectedSize = '';\r\n  }\r\n}\r\n","<p-table *ngIf=\"config\" #dt styleClass=\"p-datatable-striped {{selectedSize}}\" [value]=\"dataSource\"\n  [(selection)]=\"selectedItems\" [columns]=\"config.columns\" [globalFilterFields]=\"globalFilterFields\" [rows]=\"5\"\n  [paginator]=\"paginator\" [rowsPerPageOptions]=\"rowsPerPageOptions\" [showCurrentPageReport]=\"true\"\n  currentPageReportTemplate=\"{first} - {last} de {totalRecords}\" [rowHover]=\"true\" [totalRecords]=\"totalRecords\"\n  [lazy]=\"config.lazy\" (onLazyLoad)=\"paginate($event)\" (selectionChange)=\"selectionChange($event)\"\n  rowGroupMode=\"rowspan\" [groupRowsBy]=\"config.fieldGroup\" [showFirstLastIcon]=\"false\"\n  [tableStyle]=\"{ 'min-width': '35rem' }\" [pageLinks]=\"1\">\n\n  <ng-template pTemplate=\"caption\" *ngIf=\"config.enableCation\">\n    <div class=\"flex flex-column md:flex-row md:justify-content-between\n      md:align-items-center\">\n      <h5 class=\"m-0\">{{ config.title }}</h5>\n      <span *ngIf=\"config.enableFilter\" class=\"block mt-2 md:mt-0\n        p-input-icon-left\">\n        <i class=\"pi pi-search\"></i>\n        <input pInputText pAutoFocus [autofocus]=\"true\" type=\"text\" (input)=\"onGlobalFilter(dt, $event)\"\n          placeholder=\"Pesquisar...\" class=\"w-full sm:w-auto\" />\n      </span>\n    </div>\n  </ng-template>\n\n  <ng-template pTemplate=\"header\" let-columns>\n    <tr>\n      <th style=\"width: 4rem\" *ngIf=\"config.enableSelect\">\n        <p-tableHeaderCheckbox></p-tableHeaderCheckbox>\n      </th>\n      <th *ngFor=\"let col of columns;\" [pSortableColumn]=\"col.field\" [pSortableColumnDisabled]=\"col.sortable === false\"\n        [style.width]=\"col.width\" class=\"text-sm\">\n        <div class=\"flex flex-row\">\n          {{col.header}}\n          <p-sortIcon *ngIf=\"col.sortable === true\" [field]=\"col.field\" style=\"font-size: 10px;\"></p-sortIcon>\n        </div>\n\n      </th>\n      <th *ngIf=\"config.actions && config.actions.length> 0\"></th>\n    </tr>\n  </ng-template>\n\n  <ng-template pTemplate=\"body\" let-rowData let-columns=\"columns\" let-rowgroup=\"rowgroup\" let-rowspan=\"rowspan\">\n    <tr>\n      <td *ngIf=\"config.enableSelect\">\n        <p-tableCheckbox [value]=\"rowData\"></p-tableCheckbox>\n      </td>\n\n      <ng-container *ngFor=\"let col of columns\">\n\n        <td *ngIf=\"rowgroup\" [attr.rowspan]=\"rowgroup && col.grouped? rowspan: null\">\n          <span class=\"p-column-title\">{{col.header}}</span>\n          <span *ngIf=\"!isBooleanField(rowData, col); else booleanField\" [class]=\"(screenSize < 1600 && screenSize > 1200 || screenSize < 760) ? 'text-xs' : 'text-sm'\">\n            {{ transformValue(rowData, col) }}\n          </span>\n\n          <ng-template #booleanField>\n            <i [ngClass]=\"rowData[col.field] ? 'pi pi-check' : 'pi pi-times'\"></i>\n          </ng-template>\n        </td>\n\n        <td *ngIf=\"!rowgroup && !col.grouped\">\n          <span class=\"p-column-title\">{{col.header}}</span>\n          <span *ngIf=\"!isBooleanField(rowData, col); else booleanField\" [class]=\"(screenSize < 1600 && screenSize > 1200 || screenSize < 760) ? 'text-xs' : 'text-sm'\">\n            {{ transformValue(rowData, col) }}\n          </span>\n\n          <ng-template #booleanField>\n            <i [ngClass]=\"rowData[col.field] ? 'pi pi-check' : 'pi pi-times'\"></i>\n          </ng-template>\n        </td>\n\n      </ng-container>\n\n      <!-- <td *ngIf=\"config.actions && config.actions.length> 0\">\n        <i class=\"pi pi-ellipsis-h\" style=\"cursor: pointer\"\n          (click)=\"activeItem(rowData);menu.toggle($event)\"></i>\n      </td> -->\n\n      <td *ngIf=\"config.actions && config.actions.length> 0\" class=\"flex flex-row\">\n        <div *ngFor=\"let action of config.actions\">\n          <i class=\"pi {{action.icon}}\" style=\"cursor: pointer\" class=\"mr-2 ml-2\" (click)=\"action?.command()\"></i>\n        </div>\n      </td>\n\n    </tr>\n  </ng-template>\n\n  <ng-template pTemplate=\"emptymessage\" let-columns>\n    <tr>\n      <td [attr.colspan]=\"columns.length\" style=\"text-align: center;\">\n        Nenhum registro encontrado\n      </td>\n    </tr>\n  </ng-template>\n</p-table>\n<p-menu #menu [popup]=\"true\" [model]=\"config.actions\"></p-menu>\n"]}
@@ -916,10 +916,10 @@ class TableComponent {
916
916
  return value;
917
917
  }
918
918
  adjustTableSize() {
919
- if (this.screenSize > 1400)
920
- this.selectedSize = '';
921
- else
919
+ if ((this.screenSize < 1600 && this.screenSize > 1200 || this.screenSize < 760))
922
920
  this.selectedSize = 'p-datatable-sm';
921
+ else
922
+ this.selectedSize = '';
923
923
  }
924
924
  }
925
925
  TableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: TableComponent, deps: [{ token: i1.DatePipe }, { token: i1.DecimalPipe }, { token: CodigoFipePipe }, { token: CpfCnpjPipe }, { token: TelefonePipe }], target: i0.ɵɵFactoryTarget.Component });