UNPKG

rxjs

Version:

Reactive Extensions for modern JavaScript

41 lines (39 loc) 1.35 kB
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); }); }