Skip to content

Commit

Permalink
Remove nested subscribers (#1184)
Browse files Browse the repository at this point in the history
Inefficient nesting of subscribers in IssueDataTable has introduced 
unnecessary and very expensive computes to CATcher.

Let's 
- Improve CATcher's efficiency by removing the nesting of subscribers
in IssueDataTable.ts
  • Loading branch information
Eclipse-Dominator authored Apr 10, 2023
1 parent 0f73aff commit b94cfaa
Showing 1 changed file with 12 additions and 16 deletions.
28 changes: 12 additions & 16 deletions src/app/shared/issue-tables/IssuesDataTable.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import { DataSource } from '@angular/cdk/table';
import { MatPaginator } from '@angular/material/paginator';
import { MatSort } from '@angular/material/sort';
import { BehaviorSubject, merge, Observable, Subscription } from 'rxjs';
import { map, mergeMap } from 'rxjs/operators';
import { map } from 'rxjs/operators';
import { Issue } from '../../core/models/issue.model';
import { IssueService } from '../../core/services/issue.service';
import { paginateData } from './issue-paginator';
Expand Down Expand Up @@ -49,23 +49,19 @@ export class IssuesDataTable extends DataSource<Issue> {
];

this.issueService.startPollIssues();
this.issueSubscription = this.issueService.issues$
this.issueSubscription = merge(...displayDataChanges)
.pipe(
mergeMap(() => {
return merge(...displayDataChanges).pipe(
map(() => {
let data = <Issue[]>Object.values(this.issueService.issues$.getValue()).reverse();
if (this.defaultFilter) {
data = data.filter(this.defaultFilter);
}
data = getSortedData(this.sort, data);
data = this.getFilteredTeamData(data);
data = applySearchFilter(this.filter, this.displayedColumn, this.issueService, data);
data = paginateData(this.paginator, data);
map(() => {
let data = <Issue[]>Object.values(this.issueService.issues$.getValue()).reverse();
if (this.defaultFilter) {
data = data.filter(this.defaultFilter);
}
data = getSortedData(this.sort, data);
data = this.getFilteredTeamData(data);
data = applySearchFilter(this.filter, this.displayedColumn, this.issueService, data);
data = paginateData(this.paginator, data);

return data;
})
);
return data;
})
)
.subscribe((issues) => {
Expand Down

0 comments on commit b94cfaa

Please sign in to comment.