Очистка 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)
    }
}
Другие вопросы по тегам