import {global, isPresent} from 'angular2/src/core/facade/lang'; // We make sure promises are in a separate file so that we can use promises // without depending on rxjs. import {PromiseWrapper, Promise, PromiseCompleter} from 'angular2/src/core/facade/promise'; export {PromiseWrapper, Promise, PromiseCompleter} from 'angular2/src/core/facade/promise'; // TODO(jeffbcross): use ES6 import once typings are available var Subject = require('@reactivex/rxjs/dist/cjs/Subject'); export namespace NodeJS { export interface Timer {} } export class TimerWrapper { static setTimeout(fn: (...args: any[]) => void, millis: number): NodeJS.Timer { return global.setTimeout(fn, millis); } static clearTimeout(id: NodeJS.Timer): void { global.clearTimeout(id); } static setInterval(fn: (...args: any[]) => void, millis: number): NodeJS.Timer { return global.setInterval(fn, millis); } static clearInterval(id: NodeJS.Timer): void { global.clearInterval(id); } } export class ObservableWrapper { // TODO(vsavkin): when we use rxnext, try inferring the generic type from the first arg static subscribe(emitter: Observable, onNext: (value: T) => void, onThrow: (exception: any) => void = null, onReturn: () => void = null): Object { return emitter.observer({next: onNext, throw: onThrow, return: onReturn}); } static isObservable(obs: any): boolean { return obs instanceof Observable; } static dispose(subscription: any) { subscription.unsubscribe(); } static callNext(emitter: EventEmitter, value: any) { emitter.next(value); } static callThrow(emitter: EventEmitter, error: any) { emitter.throw(error); } static callReturn(emitter: EventEmitter) { emitter.return (null); } } // TODO: vsavkin change to interface export class Observable { observer(generator: any): Object { return null; } } /** * Use by directives and components to emit custom Events. * * ### Examples * * In the following example, `Zippy` alternatively emits `open` and `close` events when its * title gets clicked: * * ``` * @Component({ * selector: 'zippy', * template: ` *
*
Toggle
*
* *
*
`}) * export class Zippy { * visible: boolean = true; * @Output() open: EventEmitter = new EventEmitter(); * @Output() close: EventEmitter = new EventEmitter(); * * toggle() { * this.visible = !this.visible; * if (this.visible) { * this.open.next(null); * } else { * this.close.next(null); * } * } * } * ``` * * Use Rx.Observable but provides an adapter to make it work as specified here: * https://github.com/jhusain/observable-spec * * Once a reference implementation of the spec is available, switch to it. */ export class EventEmitter extends Observable { /** @internal */ _subject = new Subject(); observer(generator: any): any { return this._subject.subscribe((value) => { setTimeout(() => generator.next(value)); }, (error) => generator.throw ? generator.throw(error) : null, () => generator.return ? generator.return () : null); } toRx(): any { return this._subject; } next(value: any) { this._subject.next(value); } throw(error: any) { this._subject.error(error); } return (value?: any) { this._subject.complete(); } }