Угловой материал - вставка нескольких строк с автозаполнением - PullRequest
0 голосов
/ 19 июня 2019

Я пишу угловое приложение, которое должно получить несколько строк, и в каждой строке должна быть возможность автоматически заполнять поле идентификатора.

я смог автоматически заполнить все строки одним и тем же автозаполнением

Мне нужно, чтобы в каждой строке была возможность фильтровать значение с помощью автозаполнения и автоматически заполнять другие поля из массива базы данных, при этом изображение заполняет только второе поле, но для целей тестирования было заполнено только второе.

multiples rows with same value


// 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())
 );

}
...