Очистка FormArray после выбора другого значения из выпадающего списка в Reactive Forms Angular 4
У меня проблема, так как мне нужно выбрать склад, прежде чем я смогу увидеть ингредиенты. Моя проблема в том, что когда я пытаюсь изменить другой склад, как я могу очистить массив форм или ВЕСЬ ФОРМУ, потому что на каждом складе есть свой набор ингредиентов? Я пытался сделать это this.form = new FormGroup({})
но это уничтожает подписку. Как я могу это сделать? Вот мой код ниже.
constructor(private fb: FormBuilder,
private stocksRequestService: StocksRequestService,
private warehouseService: WarehouseService) {
this.form = new FormGroup({});
this.form.setControl('ingredients', new FormArray([]));
this.ingredientsFormArray = <FormArray>this.form.controls['ingredients'];
}
ngOnInit() {
this.getAllWarehouse();
this.subscription = this.route.params
.subscribe((params: Params) => {
this.id = +params['id'];
this.stocksRequestService.getStockRequest(this.id)
.subscribe(
(data:any) => {
this.request = data[0];
console.log(data);
},
error => {
console.log(error);
alert("ERROR");
})
});
}
initializeForm() {
this.initializeIngredientsFormArray();
}
initializeIngredientsFormArray() {
this.request2.delivery_items.forEach(ingredient => {
this.ingredientsFormArray.push(new FormGroup({
id: new FormControl(ingredient.id),
sku: new FormControl(ingredient.ingredient.SKU),
name: new FormControl(ingredient.ingredient.name),
requested_qty: new FormControl(ingredient.request_quantity),
approved_qty: new FormControl(ingredient.approved_quantity),
available_approved_qty: new FormControl(ingredient.approved_quantity - ingredient.delivered_quantity),
unit: new FormControl(ingredient.unit.name),
quantities: new FormArray([]),
}));
console.log(this.ingredientsFormArray);
const ingredientForm = <FormGroup>this.ingredientsFormArray.controls[this.ingredientsFormArray.length-1];
const singleIngredientFormArray = <FormArray>ingredientForm.controls['quantities'];
ingredient.ingredient.warehouse_items.forEach(element => {
singleIngredientFormArray.push(this.initializeSingleQuantityForm(element));
});
});
}
initializeSingleQuantityForm(quantity: any): FormGroup {
return new FormGroup({
warehouse_item_id: new FormControl(quantity.id),
unit_id: new FormControl(quantity.unit),
ingredient_id: new FormControl(quantity.ingredient_id),
expiration_date: new FormControl(quantity.expiration_date),
available_warehouse_qty: new FormControl(quantity.available_stocks),
transfer_qty: new FormControl('', [Validators.required]),
});
}
onSelectWarehouse(event): void {
const formData = {
warehouse_id: event.target.value,
request_stock_id: this.id
}
console.log(formData);
this.warehouse_id = event.target.value
this.subscription = this.stocksRequestService.selectIngredient(formData)
.subscribe(
(data:any) => {
this.request2 = data.requestStock[0];
console.log(data);
// HOW TO CLEAR FORM ARRAY HERE
this.initializeForm();
},
error => {
alert("Error! Can't Select Warehouse");
console.log(error);
})
}
getAllWarehouse() {
this.subscription = this.warehouseService.getAll()
.subscribe(
(data:any) => {
this.warehouses = data.warehouses;
console.log(data);
},
error => {
console.log(error);
});
}
2 ответа
Решение
Вы можете сделать ваш formarray пустым, выполнив следующее
const arr = <FormArray>this.form.controls.ingredients;
arr.controls = [];
Ты можешь позвонить this.form.reset()
очистить форму. Чтобы удалить все из FormArray при сохранении подписки, вы можете удалить элементы один за другим:
resetFormArray = (formArray: FormArray) => {
while (formArray.length !== 0) {
formArray.removeAt(0)
}
}