import { Component, Input, Output, EventEmitter, OnChanges, SimpleChanges } from '@angular/core';
import { ProbeHost, Probe } from '@overflow/commons-typescript/model/probe';

@Component({
  selector: 'of-probe-selector',
  templateUrl: './selector.component.html',
})
export class ProbeSelectorComponent implements OnChanges {

  @Output() select = new EventEmitter<ProbeHost>();
  @Input() probeHosts: ProbeHost[];
  @Input() probeHostID: number;

  options: Probe[];

  constructor() {
  }

  ngOnChanges(changes: SimpleChanges): void {
    this.checkPreselected();
    this.options = [];
    for (const ph of this.probeHosts) {
      this.options.push(ph.probe);
    }
  }

  checkPreselected() {
    if (!this.probeHosts || !this.probeHostID) {
      return;
    }
    setTimeout(() => {
      const preselected = this.probeHosts.find(probeHost => probeHost.id === Number(this.probeHostID));
      this.select.emit(preselected);
    });
  }

  onSelect(probe: Probe) {
    const optionselected = this.probeHosts.find(probeHost => probeHost.id === probe.id);
    this.select.emit(optionselected);
  }

}