import { Observable } from '../Observable';
|
import { ObservableInput, OperatorFunction } from '../types';
|
import { identity } from '../util/identity';
|
import { mapOneOrManyArgs } from '../util/mapOneOrManyArgs';
|
import { pipe } from '../util/pipe';
|
import { mergeMap } from './mergeMap';
|
import { toArray } from './toArray';
|
|
/**
|
* Collects all of the inner sources from source observable. Then, once the
|
* source completes, joins the values using the given static.
|
*
|
* This is used for {@link combineLatestAll} and {@link zipAll} which both have the
|
* same behavior of collecting all inner observables, then operating on them.
|
*
|
* @param joinFn The type of static join to apply to the sources collected
|
* @param project The projection function to apply to the values, if any
|
*/
|
export function joinAllInternals<T, R>(joinFn: (sources: ObservableInput<T>[]) => Observable<T>, project?: (...args: any[]) => R) {
|
return pipe(
|
// Collect all inner sources into an array, and emit them when the
|
// source completes.
|
toArray() as OperatorFunction<ObservableInput<T>, ObservableInput<T>[]>,
|
// Run the join function on the collected array of inner sources.
|
mergeMap((sources) => joinFn(sources)),
|
// If a projection function was supplied, apply it to each result.
|
project ? mapOneOrManyArgs(project) : (identity as any)
|
);
|
}
|