import { Component, Input, Output, EventEmitter, AfterContentInit, OnInit, OnDestroy } from '@angular/core'; import { Store, select } from '@ngrx/store'; import { Observable, of, Subscription } from 'rxjs'; import { catchError, exhaustMap, map, tap } from 'rxjs/operators'; import { ConfirmationService, Message } from 'primeng/primeng'; import { NoAuthProbe } from '@overflow/commons-typescript/model/noauth'; import { AuthContainerSelector } from '@overflow/shared/auth/store'; import { DomainMember } from '@overflow/commons-typescript/model/domain'; import { NoAuthProbeService } from '../service/noauth-probe.service'; import { NoAuthProbeSubscriber, NoAuthProbeNotify } from '../subscriber/noauth-probe.subscriber'; @Component({ selector: 'of-noauth-probe-list', templateUrl: './noauth-probe-list.component.html', providers: [ConfirmationService] }) export class NoAuthProbeListComponent implements OnInit, OnDestroy { pending$: Observable; error$: Observable; noauthProbes: NoAuthProbe[]; // connectingSubscription$: Subscription; constructor( private confirmationService: ConfirmationService, private store: Store, private noAuthProbeService: NoAuthProbeService, private noAuthProbeSubscriber: NoAuthProbeSubscriber, ) { this.noauthProbes = []; } ngOnInit() { this.store.pipe( tap(() => { this.pending$ = of(true); }), select(AuthContainerSelector.selectDomainMember), exhaustMap((domainMember: DomainMember) => this.noAuthProbeService.readAllByDomainID(domainMember.domain.id) .pipe( map((noauthProbes: NoAuthProbe[]) => { this.setNoauthProbes(noauthProbes); }), catchError(error => { this.setError$(error); return of(); }) ) ), tap(() => { this.pending$ = of(false); }), ).take(1).subscribe(); // this.connectingSubscription$ = this.store.pipe( // select(NoAuthProbeConnectingSelector.selectEntities), // tap((entities: { [id: number]: NoAuthProbe }) => { // const noauthProbes = []; // this.noauthProbes.forEach(noauthProbe => { // const t = entities[noauthProbe.id]; // if (undefined !== t) { // noauthProbes.push(t); // } else { // noauthProbes.push(noauthProbe); // } // }); // this.setNoauthProbes(noauthProbes); // } // ), // ).subscribe(); this.noAuthProbeSubscriber.observable().pipe( tap((noAuthProbeNotify: NoAuthProbeNotify) => { const noauthProbes = []; this.noauthProbes.forEach(noauthProbe => { const n = noAuthProbeNotify.params; if (noauthProbe.id === n.id) { noauthProbes.push(n); } else { noauthProbes.push(noauthProbe); } }); this.setNoauthProbes(noauthProbes); } ), ).subscribe(); // this.noauthProbes$ = this.store.pipe( // select(AuthContainerSelector.selectDomainMember), // exhaustMap((domainMember: DomainMember) => // this.noAuthProbeService.readAllByDomainID(domainMember.domain.id) // .pipe( // map((noauthProbes: NoAuthProbe[]) => { // this.pending$ = of(false); // if (null === noauthProbes) { // return null; // } // noauthProbes.forEach(noauthProbe => { // noauthProbe.descriptions = JSON.parse(noauthProbe.description); // }); // return noauthProbes; // }), // catchError(error => { // this.pending$ = of(false); // this.error$ = of(error); // return of(null); // }) // ) // ) // ); } ngOnDestroy(): void { // this.connectingSubscription$.unsubscribe(); } onAcceptOrDeny(isAccept: boolean, selected: NoAuthProbe) { const title = isAccept ? 'Are you sure to accept this Probe?' : 'Are you sure to deny this Probe'; const message = isAccept ? 'Start collecting data as a Probe.' : 'It will be permanently deleted.'; this.confirmationService.confirm({ header: title, message: message, icon: isAccept ? 'fa-check' : 'fa fa-trash', accept: () => { if (isAccept) { this.noAuthProbeService.acceptNoAuthProbe(selected.id) .pipe( tap(() => { this.pending$ = of(true); }), map((noauthProbes: NoAuthProbe[]) => { this.setNoauthProbes(noauthProbes); }), catchError(error => { this.setError$(error); return of(); }), tap(() => { this.pending$ = of(false); }), ).take(1).subscribe(); } else { this.noAuthProbeService.denyNoauthProbe(selected.id) .pipe( tap(() => { this.pending$ = of(true); }), map((noauthProbes: NoAuthProbe[]) => { this.setNoauthProbes(noauthProbes); }), catchError(error => { this.setError$(error); return of(); }), tap(() => { this.pending$ = of(false); }), ).take(1).subscribe(); } }, reject: () => { } }); } private setNoauthProbes(noauthProbes: NoAuthProbe[]): void { if (null === noauthProbes) { return; } noauthProbes.forEach(noauthProbe => { noauthProbe.descriptions = JSON.parse(noauthProbe.description); }); this.noauthProbes = noauthProbes; } private setError$(error: any): void { this.error$ = of(error); } }