He encontrado un interesante problema que no puedo eludir.
Tengo el siguiente *ngFor bucle con un evento click.
<label class="input-group" *ngFor="let status of statuses; trackBy: id"
(click)="filterByCategory(status.name)">{{ status.name }}
<span class="chip chip-icon" [attr.data-chip-state]="status.name">
{{ partners | counter: status.name }}</span>
<input type="checkbox" />
<span class="checkmark"></span>
</label>
el evento click fn filterByCategory() es un proceso simple, responsable de agregar o quitar de la cadena a partir de una matriz para luego filtrar una matriz de objetos.
filterByCategory(category, event: Event) {
let verify = this.filterArr.includes(category);
if (!verify) {
this.filterArr.push(category)
} else {
let indexOfCategory = this.filterArr.indexOf(category);
this.filterArr.splice(indexOfCategory, 1);
}
this.filteredPartners = this.partners.filter(partner => {
return this.filterArr.includes(partner.partner_status.name);
})
}
Cuando se desencadena el evento, se ejecuta dos veces, y la declaración de si primero se agrega la cadena y, a continuación, quita.
¿Alguno tiene una manera de resolver esto?
Gracias!