динамический коврик-флажок не отображается из FormGroup - PullRequest
0 голосов
/ 25 марта 2019

Я хочу, чтобы флажки mat были заполнены из массива.Я могу построить группу форм и массив форм и увидеть их содержимое в консоли.Но я не могу получить список устройств для отображения с помощью ngFor.Я посмотрел несколько примеров реактивных форм, и думаю, что я делаю этот HTML правильно, но, очевидно, я что-то упускаю.

Вот код ts:

import { Aircraft } from '../../shared/aircraft';
import { Component, OnInit, Inject } from '@angular/core';
import { FormBuilder, FormGroup, FormArray, FormControl } from '@angular/forms';
import { MAT_DIALOG_DATA, MatDialogRef } from "@angular/material";
import { ViewEncapsulation } from '@angular/core';
import { forEach } from '@angular/router/src/utils/collection';

interface IAircraftCheckbox {
  imei: string;
  selected: boolean;
  name: string;
}

@Component({
  selector: 'app-historical-track-dialog',
  templateUrl: './historical-track-dialog.component.html',
  styleUrls: ['./historical-track-dialog.component.scss',],
  encapsulation: ViewEncapsulation.None
})


export class HistoricalTrackDialogComponent implements OnInit {
aircraftData: any[];
imeiToTrack: string[];
breakpoint: number;
form: FormGroup;
aircraftArray: FormArray;
allSelected: boolean;

  constructor(public dialogRef: MatDialogRef<HistoricalTrackDialogComponent>,
              private fb: FormBuilder,
              @Inject(MAT_DIALOG_DATA) public data: Aircraft[]) {
    this.aircraftData = data;
    console.log('historical track dialog, this.aircraftList: ', data);
    this.aircraftArray = new FormArray([new FormControl('CAP')]);
    this.aircraftArray = this.mapAircraftToCheckboxArrayGroup( this.aircraftData);
    this.form = new FormGroup({
      aircraftList: this.aircraftArray
    });
    this.allSelected = false;
    console.log('this.form: ', this.form);
    console.log('this.aircraftList = ', this.form.controls.aircraftList);
  }

  mapAircraftToCheckboxArrayGroup( aircraft: Aircraft[]): FormArray {
    return this.fb.array(aircraft.map((i) => {
      return this.fb.group ({
        imei: i.IMEI,
        selected: false,
        name: i.DeviceName
      });
    }));
  }

  checkboxToggle(e) {
    console.log('CheckboxToggle, e=', e);
    console.log('source.id', e.source.id);
    console.log('status: ', e.checked);
  }

  toggleAll(e) {
    for (const control of this.aircraftArray.controls) {
      if (this.allSelected === true ) {
        console.log('setting ', control.value.name, 'to false');
        control.value.selected = false;
      } else {
        control.value.selected = true;
        console.log('setting ', control.value.name, 'to true');
      }
    }
    this.allSelected = this.allSelected === true ? false : true;
    this.form.markAsDirty();

  }
  ngOnInit() {
this.breakpoint = (window.innerWidth <= 690) ? 1 : 4;
  }
  onResize(event) {
    this.breakpoint = (event.target.innerWidth <= 690) ? 1 : 4;
  }

  close() {
    console.log('close, formArray: ', this.aircraftArray.controls);
    for (const control of this.aircraftArray.controls) {
      if (control.value.selected === true ) {
        console.log('aircraft checked: ', control.value.name);
      }
    }
    this.dialogRef.close();

  }

}

и вот HTML:

<div class="aList-container"
      fxLayout="column"
      fxLayoutGap="10px"
      fxLayoutAlign="start"
       style="width:500px;max-height:50%">

      <div >
          <div class="a-list-title" >
            <h3>AIRCRAFT LIST</h3>
            <hr>
          </div>
      </div>

      <div class="checkboxList" [formGroup]="form">

        <mat-grid-list [cols]="breakpoint" rowHeight="30px" gutterSize="0px" formArrayName="aircraftList" (window:resize)="onResize($event)">
            <mat-grid-tile fxLayout="column"  *ngFor="let aircraftName of aircraftList.value" [formGroup]="aircraftList">
              <mat-checkbox [formControl]="aircraftName.get('selected')">
                <!--{{aircraftName.get('name').value}}-->
                {{aircraftList}}
              </mat-checkbox>

              </mat-grid-tile>
              <mat-grid-tile fxLayout="column" >
                  <mat-checkbox id="toggle-all" ng-model="all" (click)="toggleAll($event)">Toggle All</mat-checkbox>
              </mat-grid-tile>
        </mat-grid-list>
        <div class="close-button">
            <button class="mat-raised-button " routerLink="/home" (click)="close()" style="margin: 10px;position:center">Close</button>
        </div>

      </div>
</div>

Во время выполнения я получаю сообщение об ошибке, сообщающее, что элементы управления или значение не определены (пробовал оба).Но они есть, когда я регистрирую форму Array: enter image description here

enter image description here

Все, что я вижу, - это пустой диалог.enter image description here

Я уверен, что упускаю что-то простое и фундаментальное для реактивных форм, но вот уже 3 дня гонюсь за моим хвостом .....

1 Ответ

0 голосов
/ 26 марта 2019
<mat-grid-tile fxLayout="column"  *ngFor="let aircraftName of aircraftList.value" [formGroup]="aircraftList">

Вы не определили объект aircraftList. Это элемент управления внутри группы форм:

this.form = new FormGroup({
  aircraftList: this.aircraftArray
});

Так что вы должны получить к нему доступ также:

 <mat-grid-tile fxLayout="column"  *ngFor="let aircraftName of form.controls.aircraftList.value" [formGroup]="aircraftList">
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...