import { IScheduler } from '../Scheduler'; import { Observable } from '../Observable'; import { ArrayObservable } from '../observable/ArrayObservable'; import { ScalarObservable } from '../observable/ScalarObservable'; import { EmptyObservable } from '../observable/EmptyObservable'; import { concat as concatStatic } from '../observable/concat'; import { isScheduler } from '../util/isScheduler'; import { MonoTypeOperatorFunction } from '../interfaces'; /* tslint:disable:max-line-length */ export function startWith(v1: T, scheduler?: IScheduler): MonoTypeOperatorFunction; export function startWith(v1: T, v2: T, scheduler?: IScheduler): MonoTypeOperatorFunction; export function startWith(v1: T, v2: T, v3: T, scheduler?: IScheduler): MonoTypeOperatorFunction; export function startWith(v1: T, v2: T, v3: T, v4: T, scheduler?: IScheduler): MonoTypeOperatorFunction; export function startWith(v1: T, v2: T, v3: T, v4: T, v5: T, scheduler?: IScheduler): MonoTypeOperatorFunction; export function startWith(v1: T, v2: T, v3: T, v4: T, v5: T, v6: T, scheduler?: IScheduler): MonoTypeOperatorFunction; export function startWith(...array: Array): MonoTypeOperatorFunction; /* tslint:enable:max-line-length */ /** * Returns an Observable that emits the items you specify as arguments before it begins to emit * items emitted by the source Observable. * * * * @param {...T} values - Items you want the modified Observable to emit first. * @param {Scheduler} [scheduler] - A {@link IScheduler} to use for scheduling * the emissions of the `next` notifications. * @return {Observable} An Observable that emits the items in the specified Iterable and then emits the items * emitted by the source Observable. * @method startWith * @owner Observable */ export function startWith(...array: Array): MonoTypeOperatorFunction { return (source: Observable) => { let scheduler = array[array.length - 1]; if (isScheduler(scheduler)) { array.pop(); } else { scheduler = null; } const len = array.length; if (len === 1) { return concatStatic(new ScalarObservable(array[0], scheduler), source); } else if (len > 1) { return concatStatic(new ArrayObservable(array, scheduler), source); } else { return concatStatic(new EmptyObservable(scheduler), source); } }; }