115046: Fixed issue where relationsToItems would never emit when an empty array was passed to it

This commit is contained in:
Alexandre Vryghem
2024-06-03 13:50:42 +02:00
parent 3253e0e785
commit 4ccd459b1a

View File

@@ -2,6 +2,7 @@ import { InjectionToken } from '@angular/core';
import { import {
combineLatest as observableCombineLatest, combineLatest as observableCombineLatest,
Observable, Observable,
of as observableOf,
zip as observableZip, zip as observableZip,
} from 'rxjs'; } from 'rxjs';
import { import {
@@ -53,17 +54,19 @@ export const compareArraysUsingIds = <T extends { id: string }>() =>
/** /**
* Operator for turning a list of relationships into a list of the relevant items * Operator for turning a list of relationships into a list of the relevant items
* @param {string} thisId The item's id of which the relations belong to * @param {string} thisId The item's id of which the relations belong to
* @returns {(source: Observable<Relationship[]>) => Observable<Item[]>}
*/ */
export const relationsToItems = (thisId: string) => export const relationsToItems = (thisId: string): (source: Observable<Relationship[]>) => Observable<Item[]> =>
(source: Observable<Relationship[]>): Observable<Item[]> => (source: Observable<Relationship[]>): Observable<Item[]> =>
source.pipe( source.pipe(
mergeMap((rels: Relationship[]) => mergeMap((relationships: Relationship[]) => {
observableZip( if (relationships.length === 0) {
...rels.map((rel: Relationship) => observableCombineLatest(rel.leftItem, rel.rightItem)), return observableOf([]);
), }
), return observableZip(
map((arr) => ...relationships.map((rel: Relationship) => observableCombineLatest([rel.leftItem, rel.rightItem])),
);
}),
map((arr: [RemoteData<Item>, RemoteData<Item>][]) =>
arr arr
.filter(([leftItem, rightItem]) => leftItem.hasSucceeded && rightItem.hasSucceeded) .filter(([leftItem, rightItem]) => leftItem.hasSucceeded && rightItem.hasSucceeded)
.map(([leftItem, rightItem]) => { .map(([leftItem, rightItem]) => {