I have the following code:
this.projects$ = new Subject();
let observableProjects: ProjectList = [];
this.userObject$.subscribe( async (user) => {
observableProjects = [];
for (let projectID of user.ownedProjects) {
await this.firestore.collection('projects').doc(projectID).ref.get().then( async (doc) => {
if (doc.exists) {
let tempProject = doc.data() as Project;
let tempDate = tempProject.startDate as unknown as { nanoseconds: number; seconds: number; };
let tempLocation = tempProject.location as unknown as string;
let observerProject: Project = new Project(
projectID,
tempProject.fullName,
tempProject.shortName,
tempProject.ownerID,
tempProject.lastOwnerID,
tempDate.seconds,
tempProject.duration,
tempProject.logo,
tempProject.status,
tempProject.categoryID,
tempLocation,
[],
tempProject.timelinePosts);
await this.firestore.collection('projects/' + projectID + '/descriptions').ref.get().then((snapshot) => {
snapshot.forEach((doc) => {
observerProject.description.push(doc.data() as Description);
});
observableProjects.push(observerProject);
});
}
});
}
this.projects$.next(observableProjects);
});
When I simply subscribe and console.log it as so:
this.projects$.subscribe((list) => {
console.log(list);
});
Then, there it outputs the list which is needed to the console. But in my HTML document I have the following code:
<ng-container *ngIf="showProjects && (projects$ | async) as projectList; else loading">
<div class="ion-margin-top ion-padding-top" id="ownedProjectsCardContainer" overflow-scroll="true">
<ion-card *ngFor="let project of projectList" class="ion-margin-top">
<img width="100%" [src]="project.logo" />
<ion-card-header>
<ion-card-subtitle>{{ project.startDateString }} - <span class="{{ project.status ? 'active' : 'inactive' }}">{{ project.status ? 'ACTIVE' : 'INACTIVE' }}</span></ion-card-subtitle>
<ion-card-title>{{ project.fullName }}</ion-card-title>
<ion-fab vertical="bottom" horizontal="end">
<ion-fab-button (click)="goToEditProject(project.id)">
<ion-icon name="pencil-outline"></ion-icon>
</ion-fab-button>
</ion-fab>
</ion-card-header>
</ion-card>
<ng-container *ngIf="(projects$ | async)?.length == 0" [ngTemplateOutlet]="noProjects"></ng-container>
</div>
</ng-container>
<ng-template #loading>
<ion-progress-bar type="indeterminate"></ion-progress-bar>
</ng-template>
However, no matter what the project observable returns, angular just shows the loading component. What am I doing wrong?
Thank you!
<ng-container *ngIf="(projects$ | async) as projectList; else loading">
<ng-container *ngIf="showProjects; else loading">
...
</ng-container>
</ng-container>
Please use the individually two *ngIf
conditions when you use the value of the observable.