Я пишу угловое приложение, которое должно получить несколько строк, и в каждой строке должна быть возможность автоматически заполнять поле идентификатора.
я смог автоматически заполнить все строки одним и тем же автозаполнением
Мне нужно, чтобы в каждой строке была возможность фильтровать значение с помощью автозаполнения и автоматически заполнять другие поля из массива базы данных, при этом изображение заполняет только второе поле, но для целей тестирования было заполнено только второе.
// component.html
<div formArrayName='ArrayProdutos' *ngFor="let item of profileForm.get('ArrayProdutos').controls; let i = index">
<div [formGroupName]="i">
<mat-form-field class="w-100 mr-1">
<input type="number" placeholder="Código" aria-label="number" matInput formControlName="codigo" [matAutocomplete]="autoCodigos"(keydown)="_filterByCodigo($event.target.value)" [(ngModel)]="selectedProd">
<mat-autocomplete autoActiveFirstOption #autoCodigos="matAutocomplete" [displayWith]="displayFnProd">
<mat-option *ngFor="let produto of filteredCodigos | async" [value]="produto" >
{{produto.codigo}}
</mat-option>
</mat-autocomplete>
</mat-form-field>
<mat-form-field class="mr-1">
<input type="text" placeholder="Tipo de Produto" aria-label="text" matInput formControlName="tipo" [matAutocomplete]="autoTipo" (keydown)="_filterTipo($event.target.value)" [ngModel]="elementoProd.tipo" >
<mat-autocomplete autoActiveFirstOption #autoTipo="matAutocomplete" >
<mat-option *ngFor="let tipo of filteredTipos | async" [value]="tipo.tipo" >
{{tipo.tipo}}
</mat-option>
</mat-autocomplete>
</mat-form-field>
</div>
</div>
// component.ts
tipos: Produto[] = [];
produtos: Produto[] = [];
profileForm = this.fb.group({
ArrayProdutos: this.fb.array([this.createElementData()]),
});
createNew(codigo?, tipo?, descricao?, tamanho?, valor?) {
const newRow = this.createElementData(codigo, tipo, descricao, tamanho, valor);
this.ArrayProdutos.push(newRow);
}
get ArrayProdutos(): FormArray {
return this.profileForm.get('ArrayProdutos') as FormArray;
}
createElementData(codigo?, tipo?, descricao?, tamanho?, valor?):
FormGroup {
if (valor) {
return this.fb.group({
codigo: codigo,
tipo: [tipo],
descricao: descricao,
tamanho: [tamanho],
valor: valor
});
} else {
return this.fb.group({
codigo: [''],
tipo: [''],
descricao: '',
tamanho: [''],
valor: 0
});
}
}
ngOnInit() {
this.http.get(`${environment.API}produtos/tipo`)
.subscribe(
(tipos: Produto[] ) => this.tipos = tipos);
// Obtem os dados para filtro
this.http.get(`${environment.API}produtos/busca`)
.subscribe(
(produtos: Produto[] ) => this.produtos = produtos );
this.filteredTipos = this.profileForm.get('ArrayProdutos').valueChanges
.pipe(
startWith<string | Produto>(''),
debounceTime(400),
map(value => typeof value === 'string' ? value : value.tipo),
map(name => name ? this._filterTipo(name) : this.tipos.slice())
);
this.filteredCodigos = this.profileForm.get('ArrayProdutos').valueChanges
.pipe(
startWith<string | Produto>(''),
debounceTime(300),
map(value => typeof value === 'string' ? value : value.codigo),
map(codigo => codigo ? this._filterByCodigo(codigo) : this.produtos.slice())
);
}