mirror of
https://github.com/DSpace/dspace-angular.git
synced 2025-10-07 01:54:15 +00:00
115046: Fixed issue where relationsToItems would never emit when an empty array was passed to it
This commit is contained in:
@@ -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]) => {
|
||||||
|
Reference in New Issue
Block a user