Ag Grid and async pipe causing issues with Loading Overlay
Asked Answered
P

2

6

The loading overlay applies fine on initial load.

HTML

  <ag-grid-angular #agGrid style="width: 100%; height: 550px;" 
    class="ag-theme-balham" [gridOptions]="gridOptions" 
    [rowData]="filteredTasks$ | async" 
    (selectionChanged)="onSelectionChanged()" 
    (rowClicked)="onRowClicked($event)">
  </ag-grid-angular>

Component.ts

    filteredTasks$: Observable<TaskListDto[]>;

    this.filteredTask$ = this.taskService.getFilteredTasks(httpParams);

I have a filter that a user selects that goes out to the DB with new httpParams and returns the data the user is requesting. I am not even able to force the Loading overlay. For some reason being set to the observable is just causing the grid to display "No Row to Show"

Something is overriding my overlay even when I force the api to display what I want. Below is the code I used to figure out there is something forcing the "No Rows to Show"

    1st debugger;
    this.gridApi.setRowData([]);
    2nd debugger;
    this.filteredTasks$ = this.taskService.getFilteredTasks(httpParams);
    3rd debugger;
    this.gridOptions.api.hideOverlay();
    4th debugger;
    this.gridOptions.api.showLoadingOverlay();
    5th debugger;

First debugger hits and previous data is shown

Second debugger hits and ag grid is empty and no rows is displayed

Third debugger hits and no rows is still displayed (even though the data source is now set to the observable with async pipe)

Fourth debugger hits and No overlay at all is displayed

Fifth debugger hits and finally 'Loading' is shown but it's instantly replaced by "No Rows to Show"

What is going on? What am i doing wrong here?

Pogge answered 26/2, 2019 at 20:6 Comment(4)
could u prepare a code-sample base for testing?Bluing
Yes, I can get a working code sample this afternoon.Pogge
stackblitz.com/edit/angular-ag-grid-angular-fw4hv2Pogge
@Bluing stackblitz.com/edit/angular-ag-grid-angular-fw4hv2 This shows what the issue isPogge
B
2

Fifth debugger hits and finally 'Loading' is shown but it's instantly replaced by "No Rows to Show"

Your flow of debugging is correct, "no rows to show" displayed cuz on this step loadNewData rows$ got new observer binding, but it shouldn't.

Once you've set the data (on init phase) - it's done, after that - all manipulation with grid should be handled via gridApi

on your case, loadNewData should be done like that:

loadNewData() {
    this.showOverlay();
    let request = of(this.rowData2).pipe(
      delay(5000)
    )
    request.subscribe(result=>{
      this.hideOverlay();
      this.gridOptions.api.setRowData(result)
    })
}
Bluing answered 9/5, 2019 at 16:53 Comment(2)
So this makes the async pipe pretty useless in the first case since now i am having to manual unsubscribe from the second set of data.Pogge
that's somewhat true :/ you can do the easy unsubscribe with a plain take(1) pipe, then it immediately unsubscribes after the request. in the newer ag grid versions you don't need to call hideOverlay, since it will automatically hide on row data refresh @NathanElgDepraved
R
0

I was also struggling with loading overlay for ag-grid + async pipes. I just simply put rxjs tap in my data loading observable to show loading overlay:

tap(_ => this.gridOptions.api?.showLoadingOverlay())

ag-grid will hide overlay by itself, while data is ready.

Rod answered 9/7, 2024 at 12:15 Comment(0)

© 2022 - 2025 — McMap. All rights reserved.