rxjs
Version:
Reactive Extensions for modern JavaScript
41 lines (39 loc) • 1.35 kB
text/typescript
import { OperatorFunction, ObservableInputTuple } from '../types';
import { raceInit } from '../observable/race';
import { operate } from '../util/lift';
import { identity } from '../util/identity';
/**
* Creates an Observable that mirrors the first source Observable to emit a next,
* error or complete notification from the combination of the Observable to which
* the operator is applied and supplied Observables.
*
* ## Example
*
* ```ts
* import { interval, map, raceWith } from 'rxjs';
*
* const obs1 = interval(7000).pipe(map(() => 'slow one'));
* const obs2 = interval(3000).pipe(map(() => 'fast one'));
* const obs3 = interval(5000).pipe(map(() => 'medium one'));
*
* obs1
* .pipe(raceWith(obs2, obs3))
* .subscribe(winner => console.log(winner));
*
* // Outputs
* // a series of 'fast one'
* ```
*
* @param otherSources Sources used to race for which Observable emits first.
* @return A function that returns an Observable that mirrors the output of the
* first Observable to emit an item.
*/
export function raceWith<T, A extends readonly unknown[]>(
...otherSources: [...ObservableInputTuple<A>]
): OperatorFunction<T, T | A[number]> {
return !otherSources.length
? identity
: operate((source, subscriber) => {
raceInit<T | A[number]>([source, ...otherSources])(subscriber);
});
}