import { Component, OnInit, Input, AfterViewInit, Output, EventEmitter } from '@angular/core'; import { Observable } from 'rxjs'; import { ProbeHost, Probe } from '@overflow/commons-typescript/model/probe'; import { Store, select } from '@ngrx/store'; import * as ProbeStore from '../store/entity/probe'; import { ProbeSelector } from '../store'; import { ActivatedRoute } from '@angular/router'; import { RPCClientError } from '@loafer/ng-rpc'; @Component({ selector: 'of-probe-detail-container', templateUrl: './probe-detail-container.html', }) export class ProbeDetailContainerComponent implements OnInit { @Input() probeHostID: number; @Output() discovery = new EventEmitter(); probeHost$: Observable; error$: Observable; constructor( private store: Store, private route: ActivatedRoute, ) { } ngOnInit() { this.probeHost$ = this.store.pipe(select(ProbeSelector.selectOne(this.probeHostID))); this.store.dispatch(new ProbeStore.Read(this.probeHostID)); } onModify(probeHost: ProbeHost) { this.store.dispatch(new ProbeStore.Modify(probeHost.probe)); } onDiscovery(probeHostID: number) { this.discovery.emit(probeHostID); } }