2015-09-04 01:01:36 -04:00
|
|
|
///<reference path="../../../typings/tsd.d.ts" />
|
2015-08-20 17:28:25 -04:00
|
|
|
import {global, isPresent} from 'angular2/src/core/facade/lang';
|
2015-09-11 18:38:09 -04:00
|
|
|
// TODO(jeffbcross): use ES6 import once typings are available
|
|
|
|
var Subject = require('@reactivex/rxjs/dist/cjs/Subject');
|
2015-04-01 13:45:56 -04:00
|
|
|
|
2015-06-24 01:02:20 -04:00
|
|
|
export {Promise};
|
2015-04-24 18:19:11 -04:00
|
|
|
|
2015-06-26 14:10:52 -04:00
|
|
|
export interface PromiseCompleter<R> {
|
|
|
|
promise: Promise<R>;
|
2015-08-06 12:52:33 -04:00
|
|
|
resolve: (value?: R | PromiseLike<R>) => void;
|
2015-06-26 14:10:52 -04:00
|
|
|
reject: (error?: any, stackTrace?: string) => void;
|
|
|
|
}
|
|
|
|
|
2015-04-01 13:45:56 -04:00
|
|
|
export class PromiseWrapper {
|
2015-07-07 23:03:00 -04:00
|
|
|
static resolve<T>(obj: T): Promise<T> { return Promise.resolve(obj); }
|
2015-04-01 13:45:56 -04:00
|
|
|
|
2015-07-07 23:03:00 -04:00
|
|
|
static reject(obj: any, _): Promise<any> { return Promise.reject(obj); }
|
2015-04-01 13:45:56 -04:00
|
|
|
|
|
|
|
// Note: We can't rename this method into `catch`, as this is not a valid
|
|
|
|
// method name in Dart.
|
2015-08-06 12:52:33 -04:00
|
|
|
static catchError<T>(promise: Promise<T>,
|
|
|
|
onError: (error: any) => T | PromiseLike<T>): Promise<T> {
|
2015-04-01 13:45:56 -04:00
|
|
|
return promise.catch(onError);
|
|
|
|
}
|
|
|
|
|
2015-08-28 14:29:19 -04:00
|
|
|
static all(promises: any[]): Promise<any> {
|
2015-04-01 13:45:56 -04:00
|
|
|
if (promises.length == 0) return Promise.resolve([]);
|
|
|
|
return Promise.all(promises);
|
|
|
|
}
|
|
|
|
|
2015-08-06 12:52:33 -04:00
|
|
|
static then<T, U>(promise: Promise<T>, success: (value: T) => U | PromiseLike<U>,
|
|
|
|
rejection?: (error: any, stack?: any) => U | PromiseLike<U>): Promise<U> {
|
2015-04-01 13:45:56 -04:00
|
|
|
return promise.then(success, rejection);
|
|
|
|
}
|
|
|
|
|
2015-06-26 18:58:52 -04:00
|
|
|
static wrap<T>(computation: () => T): Promise<T> {
|
|
|
|
return new Promise((res, rej) => {
|
|
|
|
try {
|
|
|
|
res(computation());
|
|
|
|
} catch (e) {
|
|
|
|
rej(e);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2015-06-26 14:10:52 -04:00
|
|
|
static completer(): PromiseCompleter<any> {
|
2015-04-01 13:45:56 -04:00
|
|
|
var resolve;
|
|
|
|
var reject;
|
|
|
|
|
|
|
|
var p = new Promise(function(res, rej) {
|
|
|
|
resolve = res;
|
|
|
|
reject = rej;
|
|
|
|
});
|
|
|
|
|
|
|
|
return {promise: p, resolve: resolve, reject: reject};
|
|
|
|
}
|
2015-05-19 10:47:30 -04:00
|
|
|
}
|
2015-04-01 13:45:56 -04:00
|
|
|
|
2015-05-19 10:47:30 -04:00
|
|
|
export class TimerWrapper {
|
2015-08-20 19:25:34 -04:00
|
|
|
static setTimeout(fn: Function, millis: number): number { return global.setTimeout(fn, millis); }
|
|
|
|
static clearTimeout(id: number): void { global.clearTimeout(id); }
|
2015-05-12 10:28:57 -04:00
|
|
|
|
2015-08-20 19:25:34 -04:00
|
|
|
static setInterval(fn: Function, millis: number): number {
|
|
|
|
return global.setInterval(fn, millis);
|
|
|
|
}
|
|
|
|
static clearInterval(id: number): void { global.clearInterval(id); }
|
2015-04-01 13:45:56 -04:00
|
|
|
}
|
|
|
|
|
2015-04-14 17:34:41 -04:00
|
|
|
export class ObservableWrapper {
|
2015-08-06 12:52:33 -04:00
|
|
|
// TODO(vsavkin): when we use rxnext, try inferring the generic type from the first arg
|
2015-07-07 23:03:00 -04:00
|
|
|
static subscribe<T>(emitter: Observable, onNext: (value: T) => void,
|
|
|
|
onThrow: (exception: any) => void = null,
|
|
|
|
onReturn: () => void = null): Object {
|
2015-04-14 17:34:41 -04:00
|
|
|
return emitter.observer({next: onNext, throw: onThrow, return: onReturn});
|
|
|
|
}
|
|
|
|
|
2015-04-19 15:45:08 -04:00
|
|
|
static isObservable(obs: any): boolean { return obs instanceof Observable; }
|
|
|
|
|
2015-09-11 18:38:09 -04:00
|
|
|
static dispose(subscription: any) { subscription.unsubscribe(); }
|
2015-04-19 15:45:08 -04:00
|
|
|
|
2015-04-14 17:34:41 -04:00
|
|
|
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 {
|
2015-05-01 17:05:19 -04:00
|
|
|
observer(generator: any): Object { return null; }
|
2015-04-14 17:34:41 -04:00
|
|
|
}
|
|
|
|
|
2015-04-01 13:45:56 -04:00
|
|
|
/**
|
2015-09-30 23:59:23 -04:00
|
|
|
* Use by directives and components to emit custom Events.
|
2015-09-03 19:17:23 -04:00
|
|
|
*
|
|
|
|
* ## Examples
|
|
|
|
*
|
|
|
|
* In the following example, `Zippy` alternatively emits `open` and `close` events when its
|
|
|
|
* title gets clicked:
|
|
|
|
*
|
|
|
|
* ```
|
|
|
|
* @Component({selector: 'zippy'})
|
|
|
|
* @View({template: `
|
|
|
|
* <div class="zippy">
|
|
|
|
* <div (click)="toggle()">Toggle</div>
|
|
|
|
* <div [hidden]="!visible">
|
|
|
|
* <ng-content></ng-content>
|
|
|
|
* </div>
|
|
|
|
* </div>`})
|
|
|
|
* export class Zippy {
|
|
|
|
* visible: boolean = true;
|
2015-09-30 23:59:23 -04:00
|
|
|
* @Output() open: EventEmitter = new EventEmitter();
|
|
|
|
* @Output() close: EventEmitter = new EventEmitter();
|
2015-09-03 19:17:23 -04:00
|
|
|
*
|
|
|
|
* toggle() {
|
|
|
|
* this.visible = !this.visible;
|
|
|
|
* if (this.visible) {
|
|
|
|
* this.open.next(null);
|
|
|
|
* } else {
|
|
|
|
* this.close.next(null);
|
|
|
|
* }
|
|
|
|
* }
|
|
|
|
* }
|
|
|
|
* ```
|
|
|
|
*
|
2015-04-01 13:45:56 -04:00
|
|
|
* 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.
|
|
|
|
*/
|
2015-04-14 17:34:41 -04:00
|
|
|
export class EventEmitter extends Observable {
|
2015-09-11 18:38:09 -04:00
|
|
|
_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);
|
2015-04-14 17:34:41 -04:00
|
|
|
}
|
2015-04-01 13:45:56 -04:00
|
|
|
|
2015-10-05 21:04:28 -04:00
|
|
|
toRx(): any { return this._subject; }
|
2015-04-01 13:45:56 -04:00
|
|
|
|
2015-09-11 18:38:09 -04:00
|
|
|
next(value: any) { this._subject.next(value); }
|
2015-04-14 17:34:41 -04:00
|
|
|
|
2015-09-11 18:38:09 -04:00
|
|
|
throw(error: any) { this._subject.error(error); }
|
2015-04-14 17:34:41 -04:00
|
|
|
|
2015-09-11 18:38:09 -04:00
|
|
|
return (value?: any) { this._subject.complete(); }
|
2015-04-27 19:11:20 -04:00
|
|
|
}
|