TrackDeviceDialogComponent_Host.ngfactory.js?[см]: 1 ОШИБКА Ошибка: StaticInjectorError (AppModule) [В - PullRequest
0 голосов
/ 01 апреля 2019

Я затрудняюсь понять, откуда исходит моя ошибка.У меня есть диалог с сообщением об ошибке «Нет инжектора», где я пытаюсь вызвать его.Вот строка, в которой я получаю сообщение об ошибке:

  const dialogRef = this.trackDeviceDialogComponent.open(TrackDeviceDialogComponent, dialogConfig);

, и получаю ошибку:

ERROR Error: StaticInjectorError(AppModule)[TrackDeviceDialogComponent -> 
 InjectionToken MatDialogData]: 
   StaticInjectorError(Platform: core)[TrackDeviceDialogComponent -> 
 InjectionToken MatDialogData]: 
     NullInjectorError: No provider for InjectionToken MatDialogData!

Но я импортирую и также объявляю ее в своем конструкторе:

 import { TrackDeviceDialogComponent } from '../../dialogs/track-device-dialog/track-device-dialog.component';

 constructor(public appSettingsService: AppSettingsService,
               private deviceManagerService: DeviceManagerService,
               private devicesToTrackService: DevicesToTrackService,
               private trackDeviceDialogComponent: MatDialog
              ) {

, а также в моем app.module:

import { TrackDeviceDialogComponent } from './dialogs/track-device-dialog/track-device-dialog.component';

@NgModule({
   declarations: [
      TrackDeviceDialogComponent,

.,,

   entryComponents: [EditDeviceDialogComponent,
                     DeleteDeviceDialogComponent,
                     LayerControlDialogComponent,
                     HistoricalTrackDialogComponent,
                     TrackDeviceDialogComponent,
                 ]
}

ОБНОВЛЕНИЕ: Вот код для диалога:

import { Aircraft } from '../../shared/aircraft';
import { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material';

import { Component, OnInit, Inject } from '@angular/core';
import { FormBuilder, FormGroup, FormArray, FormControl } from '@angular/forms';
import { AnimationKeyframesSequenceMetadata } from '@angular/animations';

interface IDeviceNameList {
  id: number;
  deviceName: string;
}

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

export class TrackDeviceDialogComponent implements OnInit {
  deviceForm: FormGroup;
  aircraftData: Aircraft[];
  deviceNames: IDeviceNameList[] = [];
  breakpoint: number;
  dt1: string;
  dt2: string;
  public dateTimeRange: Date[] = [];


  constructor(public dialogRef: MatDialogRef<TrackDeviceDialogComponent>,
              private fb: FormBuilder,
              @Inject(MAT_DIALOG_DATA) public data: any) {

console.log('dialog init');
    // Get the full DB of aircraft data
    this.aircraftData = data;
    // Now filter down to an array of DeviceName's only
    this.buildDeviceList( this.aircraftData );

    // Create a FormControl for each available music preference, initialize them as unchecked, and put them in an array
    const formControls = this.deviceNames.map(control => new FormControl(false));
    // Create a FormControl for the select/unselect all checkbox
    const selectAllControl = new FormControl(false);

    // Simply add the list of FormControls to the FormGroup as a FormArray, add the selectAllControl separetely
    this.deviceForm = this.fb.group({
      deviceNames: new FormArray(formControls),
      selectAll: selectAllControl,
    });
  }

  buildDeviceList( aircraftDB: Aircraft[] ) {
    this.aircraftData.map((obj, indx) => {
      const ac = {id: indx,
        deviceName: obj.DeviceName};
      this.deviceNames.push( ac );
    });
  }
  ngOnInit() {
    this.breakpoint = (window.innerWidth <= 690) ? 1 : 4;
    this.onChanges();
  }

  onChanges(): void {
    // Subscribe to changes on the selectAll checkbox
    this.deviceForm.get('selectAll').valueChanges.subscribe(bool => {
      this.deviceForm
        .get('deviceNames')
        .patchValue(Array(this.deviceNames.length).fill(bool), { emitEvent: false });
    });

    // Subscribe to changes on the music preference checkboxes
    this.deviceForm.get('deviceNames').valueChanges.subscribe(val => {
      const allSelected = val.every(bool => bool);
      if (this.deviceForm.get('selectAll').value !== allSelected) {
        this.deviceForm.get('selectAll').patchValue(allSelected, { emitEvent: false });
      }
    });
  }

  close() {
    // Filter out the unselected ids
    const selectedDevices = this.deviceForm.value.deviceNames
      .map((checked, index) => checked ? this.deviceNames[index].id : null)
      .filter(value => value !== null);
    // Do something with the result
    const selectedIMEIs = selectedDevices.map(( imei, index) => this.aircraftData[index].IMEI);
    const returnData = [ selectedIMEIs, this.dateTimeRange ];
    console.log('returnData: ', returnData);
    this.dialogRef.close( returnData );
  }


}

Таким образом, я, кажется, объявляю это везде, где мне нужно, но все еще появляется ошибка.Как мне отследить это до рута?

Спасибо ...

Ответы [ 2 ]

0 голосов
/ 02 апреля 2019

Поскольку данные, которые я вводил в диалоговое окно, поступают из подписки, мне пришлось вызывать диалоговое окно из .subscribe, в противном случае данные еще не были определены во время выполнения, так как обещание не было выполнено. По крайней мере, я так думаю.

0 голосов
/ 01 апреля 2019

удалить trackDeviceDialogComponent из конструктора

также обратитесь к этому руководству за помощью https://material.angular.io/components/dialog/overview

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...