// @flow // see https://gist.github.com/thecotne/6e5969f4aaf8f253985ed36b30ac9fe0 type $FlowGen$If = $Call< ((true, Then, Else) => Then) & ((false, Then, Else) => Else), X, Then, Else >; type $FlowGen$Assignable = $Call< ((...r: [B]) => true) & ((...r: [A]) => false), A >; declare var TalkbackKind: {| +Pull: 0, // 0 +Close: 1, // 1 |}; declare type TalkbackFn = (signal: $Values) => void; declare type TeardownFn = () => void; declare var SignalKind: {| +Start: 0, // 0 +Push: 1, // 1 +End: 0, // 0 |}; declare interface Tag { tag: T; } declare type Start<_T> = { ...Tag, ...[TalkbackFn] }; declare type Push = { ...Tag, ...[T] }; declare type Signal = Start | Push | typeof SignalKind.End; declare type Sink = (signal: Signal) => void; declare type Source = (sink: Sink) => void; declare type Operator = (a: Source) => Source; declare type TypeOfSource = $FlowGen$If< $FlowGen$Assignable>, U, empty >; declare interface Subscription { unsubscribe(): void; } declare interface Observer { next(value: T): void; complete(): void; } declare type Subject = { source: Source, ... } & Observer; declare type SourceIterable = { ... } & AsyncIterator & AsyncIterable; declare function lazy(produce: () => Source): Source; declare function fromAsyncIterable( iterable: AsyncIterable | AsyncIterator ): Source; declare function fromIterable( iterable: Iterable | AsyncIterable ): Source; declare var fromArray: (array: T[]) => Source; declare function fromValue(value: T): Source; declare function make( subscriber: (observer: Observer) => TeardownFn ): Source; declare function makeSubject(): Subject; declare var empty: Source; declare var never: Source; declare function interval(ms: number): Source; declare function fromDomEvent( element: HTMLElement, event: string ): Source; declare function fromPromise(promise: Promise): Source; declare function buffer(notifier: Source): Operator; declare function concatMap( map: (value: In) => Source ): Operator; declare function concatAll(source: Source>): Source; declare function concat(sources: Source[]): Source; declare function filter( predicate: (value: In) => boolean ): Operator; declare function filter(predicate: (value: T) => boolean): Operator; declare function map(map: (value: In) => Out): Operator; declare function mergeMap( map: (value: In) => Source ): Operator; declare function mergeAll(source: Source>): Source; declare function merge(sources: Source[]): Source; declare function onEnd(callback: () => void): Operator; declare function onPush(callback: (value: T) => void): Operator; declare function onStart(callback: () => void): Operator; declare function sample(notifier: Source): Operator; declare function scan( reducer: (acc: Out, value: In) => Out, seed: Out ): Operator; declare function share(source: Source): Source; declare function skip(wait: number): Operator; declare function skipUntil(notifier: Source): Operator; declare function skipWhile(predicate: (value: T) => boolean): Operator; declare function switchMap( map: (value: In) => Source ): Operator; declare function switchAll(source: Source>): Source; declare function take(max: number): Operator; declare function takeLast(max: number): Operator; declare function takeUntil(notifier: Source): Operator; declare function takeWhile( predicate: (value: T) => boolean, addOne?: boolean ): Operator; declare function debounce(timing: (value: T) => number): Operator; declare function delay(wait: number): Operator; declare function throttle(timing: (value: T) => number): Operator; declare function subscribe( subscriber: (value: T) => void ): (source: Source) => Subscription; declare function forEach( subscriber: (value: T) => void ): (source: Source) => void; declare function publish(source: Source): void; declare var toAsyncIterable: (source: Source) => SourceIterable; declare function toArray(source: Source): T[]; declare function toPromise(source: Source): Promise; declare type TypeOfSourceArray = $FlowGen$If< $FlowGen$Assignable, [TypeOfSource] & TypeOfSourceArray, [] >; declare interface zip { []>( sources: [] & Sources ): Source>; < Sources: { [prop: string]: Source, } >( sources: Sources ): Source< $ObjMapi< Sources, (Property) => TypeOfSource<$ElementType> > >; } declare function zip( sources: Source[] | { [key: string]: Source, ... } ): Source; declare function combine[]>( ...sources: Sources ): Source>; declare module "global" { declare interface SymbolConstructor { +observable: Symbol; } } declare interface ObservableSubscription { closed: boolean; unsubscribe(): void; } declare interface ObservableObserver { next(value: T): void; error?: (error: any) => void; complete?: () => void; } declare interface ObservableLike { subscribe(observer: ObservableObserver): { unsubscribe(): void, ... }; } declare interface Observable { subscribe(observer: ObservableObserver): ObservableSubscription; subscribe( onNext: (value: T) => any, onError?: (error: any) => any, onComplete?: () => any ): ObservableSubscription; } declare function fromObservable(input: ObservableLike): Source; declare function toObservable(source: Source): Observable; declare interface Callbag { (t: 0, d: Callbag): void; (t: 1, d: I): void; (t: 2, d?: any): void; } declare function fromCallbag(callbag: Callbag): Source; declare function toCallbag(source: Source): Callbag; declare interface UnaryFn { (source: T): R; } declare interface pipe { (source: Source, op1: UnaryFn, Source>): Source; ( source: Source, op1: UnaryFn, Source>, op2: UnaryFn, Source> ): Source; ( source: Source, op1: UnaryFn, Source>, op2: UnaryFn, Source>, op3: UnaryFn, Source> ): Source; ( source: Source, op1: UnaryFn, Source>, op2: UnaryFn, Source>, op3: UnaryFn, Source>, op4: UnaryFn, Source> ): Source; ( source: Source, op1: UnaryFn, Source>, op2: UnaryFn, Source>, op3: UnaryFn, Source>, op4: UnaryFn, Source>, op5: UnaryFn, Source> ): Source; ( source: Source, op1: UnaryFn, Source>, op2: UnaryFn, Source>, op3: UnaryFn, Source>, op4: UnaryFn, Source>, op5: UnaryFn, Source>, op6: UnaryFn, Source> ): Source; ( source: Source, op1: UnaryFn, Source>, op2: UnaryFn, Source>, op3: UnaryFn, Source>, op4: UnaryFn, Source>, op5: UnaryFn, Source>, op6: UnaryFn, Source>, op7: UnaryFn, Source> ): Source; ( source: Source, op1: UnaryFn, Source>, op2: UnaryFn, Source>, op3: UnaryFn, Source>, op4: UnaryFn, Source>, op5: UnaryFn, Source>, op6: UnaryFn, Source>, op7: UnaryFn, Source>, op8: UnaryFn, Source> ): Source; (source: Source, consumer: UnaryFn, R>): R; ( source: Source, op1: UnaryFn, Source>, consumer: UnaryFn, R> ): R; ( source: Source, op1: UnaryFn, Source>, op2: UnaryFn, Source>, consumer: UnaryFn, R> ): R; ( source: Source, op1: UnaryFn, Source>, op2: UnaryFn, Source>, op3: UnaryFn, Source>, consumer: UnaryFn, R> ): R; ( source: Source, op1: UnaryFn, Source>, op2: UnaryFn, Source>, op3: UnaryFn, Source>, op4: UnaryFn, Source>, consumer: UnaryFn, R> ): R; ( source: Source, op1: UnaryFn, Source>, op2: UnaryFn, Source>, op3: UnaryFn, Source>, op4: UnaryFn, Source>, op5: UnaryFn, Source>, consumer: UnaryFn, R> ): R; ( source: Source, op1: UnaryFn, Source>, op2: UnaryFn, Source>, op3: UnaryFn, Source>, op4: UnaryFn, Source>, op5: UnaryFn, Source>, op6: UnaryFn, Source>, consumer: UnaryFn, R> ): R; ( source: Source, op1: UnaryFn, Source>, op2: UnaryFn, Source>, op3: UnaryFn, Source>, op4: UnaryFn, Source>, op5: UnaryFn, Source>, op6: UnaryFn, Source>, op7: UnaryFn, Source>, consumer: UnaryFn, R> ): R; ( source: Source, op1: UnaryFn, Source>, op2: UnaryFn, Source>, op3: UnaryFn, Source>, op4: UnaryFn, Source>, op5: UnaryFn, Source>, op6: UnaryFn, Source>, op7: UnaryFn, Source>, op8: UnaryFn, Source>, consumer: UnaryFn, R> ): R; } declare var pipe: pipe; declare export { Observer, Operator, Signal, Sink, Source, Subject, Subscription, TeardownFn, TypeOfSource, buffer, combine, concat, concatAll, concatMap, debounce, delay, empty, filter, mergeAll as flatten, forEach, fromArray, fromAsyncIterable, fromCallbag, fromDomEvent, fromIterable, fromObservable, fromPromise, fromValue, interval, lazy, make, makeSubject, map, merge, mergeAll, mergeMap, never, onEnd, onPush, onStart, pipe, publish, sample, scan, share, skip, skipUntil, skipWhile, subscribe, switchAll, switchMap, take, takeLast, takeUntil, takeWhile, onPush as tap, throttle, toArray, toAsyncIterable, toCallbag, toObservable, toPromise, zip, };