Waiting for an observable to finish

28,055

how i would tackle this challenge:

Query you back-end and when we've got what we need push it to a Subject

riskSubject = new Subject<Risk>();

getRiskFromServer(quoteReference: string) {
  this.riskService.getCustom("Url")
  .subscribe( 
    data => { this.riskSubject.next(data); },
    error => { console.log(error) }
 });
}

and then subscribe to subject and wait until you get what you need and start validating

private validateQuoteRetrievalAnswers(reference: string) {

         // Get the risk from the server
        this.riskManager.getRiskFromServer(reference);
        // subscribe to subject
        this.riskManager.riskSubject.subscribe(
         data => {
           //do your validation
        })
}

The heart of an observable data service is the RxJs Subject. Subjects implement both the Observer and the Observable interfaces, meaning that we can use them to both emit values and register subscriptors.

The subject is nothing more than a traditional event bus, but much more powerful as it provides all the RxJs functional operators with it. But at its heart, we simply use it to subscribe just like a regular observable

source: angular-university.io

OR you can use Observable.fromPromise(promise) but this will make things a bit more complicated to understand if you are new to ng2

Share:
28,055
Admin
Author by

Admin

Updated on April 13, 2020

Comments

  • Admin
    Admin about 4 years

    I have a method that needs to wait for an observable to finish. I know observable are great for returning single pieces of data over time but I need to know when this observable has completely finished returning all of its data so I can run validation code on the object it has returned.

    The method getCustom subscribes to an observable run on the supplied url which then returns the observable.

    I am not too sure if this is the best way to approach this situation so I would appreciate if anyone could give me any advice or a direction to handle this.

      private validateQuoteRetrievalAnswers(reference: string) {
    
             // Get the risk from the server
            this.riskManager.getRiskFromServer(reference);
    
            if (this.riskManager.risk) {
                // Validate risk that was returned
            }
        }
    
    getRiskFromServer(quoteReference: string) {
    
        this.riskService.getCustom("Url").subscribe => {
            // need to know when the observable has returned the risk
        });
    
    }
    
  • Admin
    Admin about 7 years
    This is exactly what I ended up doing, my issue was I was trying to do specific logic after the success handler off the riskSubject,subscribe(). Instead I just performed my operations inside the data = { } code block. It was more my mistake for not understanding the best away to use the availability of an observable