UNPKG

6.75 kBJavaScriptView Raw
1"use strict";
2var __extends = (this && this.__extends) || function (d, b) {
3 for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
4 function __() { this.constructor = d; }
5 d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
6};
7var Subject_1 = require('rxjs/Subject');
8var PromiseObservable_1 = require('rxjs/observable/PromiseObservable');
9var toPromise_1 = require('rxjs/operator/toPromise');
10var lang_1 = require('./lang');
11var Observable_1 = require('rxjs/Observable');
12exports.Observable = Observable_1.Observable;
13var Subject_2 = require('rxjs/Subject');
14exports.Subject = Subject_2.Subject;
15var promise_1 = require('./promise');
16exports.PromiseCompleter = promise_1.PromiseCompleter;
17exports.PromiseWrapper = promise_1.PromiseWrapper;
18var TimerWrapper = (function () {
19 function TimerWrapper() {
20 }
21 TimerWrapper.setTimeout = function (fn, millis) {
22 return lang_1.global.setTimeout(fn, millis);
23 };
24 TimerWrapper.clearTimeout = function (id) { lang_1.global.clearTimeout(id); };
25 TimerWrapper.setInterval = function (fn, millis) {
26 return lang_1.global.setInterval(fn, millis);
27 };
28 TimerWrapper.clearInterval = function (id) { lang_1.global.clearInterval(id); };
29 return TimerWrapper;
30}());
31exports.TimerWrapper = TimerWrapper;
32var ObservableWrapper = (function () {
33 function ObservableWrapper() {
34 }
35 // TODO(vsavkin): when we use rxnext, try inferring the generic type from the first arg
36 ObservableWrapper.subscribe = function (emitter, onNext, onError, onComplete) {
37 if (onComplete === void 0) { onComplete = function () { }; }
38 onError = (typeof onError === 'function') && onError || lang_1.noop;
39 onComplete = (typeof onComplete === 'function') && onComplete || lang_1.noop;
40 return emitter.subscribe({ next: onNext, error: onError, complete: onComplete });
41 };
42 ObservableWrapper.isObservable = function (obs) { return !!obs.subscribe; };
43 /**
44 * Returns whether `obs` has any subscribers listening to events.
45 */
46 ObservableWrapper.hasSubscribers = function (obs) { return obs.observers.length > 0; };
47 ObservableWrapper.dispose = function (subscription) { subscription.unsubscribe(); };
48 /**
49 * @deprecated - use callEmit() instead
50 */
51 ObservableWrapper.callNext = function (emitter, value) { emitter.next(value); };
52 ObservableWrapper.callEmit = function (emitter, value) { emitter.emit(value); };
53 ObservableWrapper.callError = function (emitter, error) { emitter.error(error); };
54 ObservableWrapper.callComplete = function (emitter) { emitter.complete(); };
55 ObservableWrapper.fromPromise = function (promise) {
56 return PromiseObservable_1.PromiseObservable.create(promise);
57 };
58 ObservableWrapper.toPromise = function (obj) { return toPromise_1.toPromise.call(obj); };
59 return ObservableWrapper;
60}());
61exports.ObservableWrapper = ObservableWrapper;
62/**
63 * Use by directives and components to emit custom Events.
64 *
65 * ### Examples
66 *
67 * In the following example, `Zippy` alternatively emits `open` and `close` events when its
68 * title gets clicked:
69 *
70 * ```
71 * @Component({
72 * selector: 'zippy',
73 * template: `
74 * <div class="zippy">
75 * <div (click)="toggle()">Toggle</div>
76 * <div [hidden]="!visible">
77 * <ng-content></ng-content>
78 * </div>
79 * </div>`})
80 * export class Zippy {
81 * visible: boolean = true;
82 * @Output() open: EventEmitter<any> = new EventEmitter();
83 * @Output() close: EventEmitter<any> = new EventEmitter();
84 *
85 * toggle() {
86 * this.visible = !this.visible;
87 * if (this.visible) {
88 * this.open.emit(null);
89 * } else {
90 * this.close.emit(null);
91 * }
92 * }
93 * }
94 * ```
95 *
96 * The events payload can be accessed by the parameter `$event` on the components output event
97 * handler:
98 *
99 * ```
100 * <zippy (open)="onOpen($event)" (close)="onClose($event)"></zippy>
101 * ```
102 *
103 * Uses Rx.Observable but provides an adapter to make it work as specified here:
104 * https://github.com/jhusain/observable-spec
105 *
106 * Once a reference implementation of the spec is available, switch to it.
107 * @stable
108 */
109var EventEmitter = (function (_super) {
110 __extends(EventEmitter, _super);
111 /**
112 * Creates an instance of [EventEmitter], which depending on [isAsync],
113 * delivers events synchronously or asynchronously.
114 */
115 function EventEmitter(isAsync) {
116 if (isAsync === void 0) { isAsync = false; }
117 _super.call(this);
118 this.__isAsync = isAsync;
119 }
120 EventEmitter.prototype.emit = function (value) { _super.prototype.next.call(this, value); };
121 /**
122 * @deprecated - use .emit(value) instead
123 */
124 EventEmitter.prototype.next = function (value) { _super.prototype.next.call(this, value); };
125 EventEmitter.prototype.subscribe = function (generatorOrNext, error, complete) {
126 var schedulerFn;
127 var errorFn = function (err) { return null; };
128 var completeFn = function () { return null; };
129 if (generatorOrNext && typeof generatorOrNext === 'object') {
130 schedulerFn = this.__isAsync ? function (value /** TODO #9100 */) {
131 setTimeout(function () { return generatorOrNext.next(value); });
132 } : function (value /** TODO #9100 */) { generatorOrNext.next(value); };
133 if (generatorOrNext.error) {
134 errorFn = this.__isAsync ? function (err) { setTimeout(function () { return generatorOrNext.error(err); }); } :
135 function (err) { generatorOrNext.error(err); };
136 }
137 if (generatorOrNext.complete) {
138 completeFn = this.__isAsync ? function () { setTimeout(function () { return generatorOrNext.complete(); }); } :
139 function () { generatorOrNext.complete(); };
140 }
141 }
142 else {
143 schedulerFn = this.__isAsync ? function (value /** TODO #9100 */) {
144 setTimeout(function () { return generatorOrNext(value); });
145 } : function (value /** TODO #9100 */) { generatorOrNext(value); };
146 if (error) {
147 errorFn =
148 this.__isAsync ? function (err) { setTimeout(function () { return error(err); }); } : function (err) { error(err); };
149 }
150 if (complete) {
151 completeFn =
152 this.__isAsync ? function () { setTimeout(function () { return complete(); }); } : function () { complete(); };
153 }
154 }
155 return _super.prototype.subscribe.call(this, schedulerFn, errorFn, completeFn);
156 };
157 return EventEmitter;
158}(Subject_1.Subject));
159exports.EventEmitter = EventEmitter;
160//# sourceMappingURL=async.js.map
\No newline at end of file