Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

InvalidPipeArgument: '[object Object]' for pipe 'AsyncPipe'

Declared in service like this:

public currentDBUserBS$: any;

constructor(private afDb: AngularFireDatabase){}

fetchUser(uid){
  this.afDb.object(`users/${uid}`).valueChanges().subscribe((dUser) => {
    if (dUser) {
      this.currentDBUserBS$ = dUser;
    }
  });
}

Now trying to use in template

template: `<li *ngIf="(authService.currentDBUserBS$ | async)?.role=='admin'"> Something </li>`

The error stack:

ERROR Error: InvalidPipeArgument: '[object Object]' for pipe 'AsyncPipe'
    at invalidPipeArgumentError (common.js:4219)
    at AsyncPipe._selectStrategy (common.js:5630)
    at AsyncPipe._subscribe (common.js:5612)
    at AsyncPipe.transform (common.js:5586)
    at Object.View_AppNavigatorComponent_0._co [as updateDirectives] (AppNavigatorComponent.html:40)
    at Object.debugUpdateDirectives [as updateDirectives] (core.js:14339)
    at checkAndUpdateView (core.js:13508)
    at callViewAction (core.js:13858)
    at execComponentViewsAction (core.js:13790)
    at checkAndUpdateView (core.js:13514)
like image 600
ishandutta2007 Avatar asked Nov 28 '17 10:11

ishandutta2007


2 Answers

You are giving currentDBUserBS$ the object you are fetching from Firebase and not the Observable. If you want to do it this way, you have to remove the | async in your template.

However, you could do the following :

fetchUser(uid){
  this.currentDBUserBS$ = this.afDb.object(`users/${uid}`).valueChanges();
}

.valueChanges() gives you an observable and will update automatically when a new value is emitted or an existing value is modified.

like image 164
tomrcht Avatar answered Oct 06 '22 08:10

tomrcht


You must add .valueChanges(); after subscribing operation. It is required as shown below:

 this.courses$=db.list('/courses').valueChanges();
like image 23
amr hamdy Avatar answered Oct 06 '22 09:10

amr hamdy