import { Component, OnDestroy, OnInit } from '@angular/core'; import { ActivatedRoute } from '@angular/router'; import { Subject } from 'rxjs'; import { takeUntil } from 'rxjs/operators'; import { Store } from '@ngrx/store'; import { ECLOnChainSendModalComponent } from '../on-chain-send-modal/on-chain-send-modal.component'; import { RTLState } from '../../../store/rtl.state'; import { openAlert } from '../../../store/rtl.actions'; @Component({ selector: 'rtl-ecl-on-chain-send', templateUrl: './on-chain-send.component.html', styleUrls: ['./on-chain-send.component.scss'] }) export class ECLOnChainSendComponent implements OnInit, OnDestroy { public sweepAll = false; private unSubs: Array> = [new Subject(), new Subject()]; constructor(private store: Store, private activatedRoute: ActivatedRoute) { } ngOnInit() { this.activatedRoute.data.pipe(takeUntil(this.unSubs[0])).subscribe((routeData) => { this.sweepAll = routeData.sweepAll; }); } openSendFundsModal() { this.store.dispatch(openAlert({ payload: { data: { sweepAll: this.sweepAll, component: ECLOnChainSendModalComponent } } })); } ngOnDestroy() { this.unSubs.forEach((completeSub) => { completeSub.next(null); completeSub.complete(); }); } }