UNPKG

@angular/router-deprecated

Version:
160 lines 6.75 kB
"use strict"; var __extends = (this && this.__extends) || function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; function __() { this.constructor = d; } d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; var Subject_1 = require('rxjs/Subject'); var PromiseObservable_1 = require('rxjs/observable/PromiseObservable'); var toPromise_1 = require('rxjs/operator/toPromise'); var lang_1 = require('./lang'); var Observable_1 = require('rxjs/Observable'); exports.Observable = Observable_1.Observable; var Subject_2 = require('rxjs/Subject'); exports.Subject = Subject_2.Subject; var promise_1 = require('./promise'); exports.PromiseCompleter = promise_1.PromiseCompleter; exports.PromiseWrapper = promise_1.PromiseWrapper; var TimerWrapper = (function () { function TimerWrapper() { } TimerWrapper.setTimeout = function (fn, millis) { return lang_1.global.setTimeout(fn, millis); }; TimerWrapper.clearTimeout = function (id) { lang_1.global.clearTimeout(id); }; TimerWrapper.setInterval = function (fn, millis) { return lang_1.global.setInterval(fn, millis); }; TimerWrapper.clearInterval = function (id) { lang_1.global.clearInterval(id); }; return TimerWrapper; }()); exports.TimerWrapper = TimerWrapper; var ObservableWrapper = (function () { function ObservableWrapper() { } // TODO(vsavkin): when we use rxnext, try inferring the generic type from the first arg ObservableWrapper.subscribe = function (emitter, onNext, onError, onComplete) { if (onComplete === void 0) { onComplete = function () { }; } onError = (typeof onError === 'function') && onError || lang_1.noop; onComplete = (typeof onComplete === 'function') && onComplete || lang_1.noop; return emitter.subscribe({ next: onNext, error: onError, complete: onComplete }); }; ObservableWrapper.isObservable = function (obs) { return !!obs.subscribe; }; /** * Returns whether `obs` has any subscribers listening to events. */ ObservableWrapper.hasSubscribers = function (obs) { return obs.observers.length > 0; }; ObservableWrapper.dispose = function (subscription) { subscription.unsubscribe(); }; /** * @deprecated - use callEmit() instead */ ObservableWrapper.callNext = function (emitter, value) { emitter.next(value); }; ObservableWrapper.callEmit = function (emitter, value) { emitter.emit(value); }; ObservableWrapper.callError = function (emitter, error) { emitter.error(error); }; ObservableWrapper.callComplete = function (emitter) { emitter.complete(); }; ObservableWrapper.fromPromise = function (promise) { return PromiseObservable_1.PromiseObservable.create(promise); }; ObservableWrapper.toPromise = function (obj) { return toPromise_1.toPromise.call(obj); }; return ObservableWrapper; }()); exports.ObservableWrapper = ObservableWrapper; /** * 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: ` * <div class="zippy"> * <div (click)="toggle()">Toggle</div> * <div [hidden]="!visible"> * <ng-content></ng-content> * </div> * </div>`}) * export class Zippy { * visible: boolean = true; * @Output() open: EventEmitter<any> = new EventEmitter(); * @Output() close: EventEmitter<any> = new EventEmitter(); * * toggle() { * this.visible = !this.visible; * if (this.visible) { * this.open.emit(null); * } else { * this.close.emit(null); * } * } * } * ``` * * The events payload can be accessed by the parameter `$event` on the components output event * handler: * * ``` * <zippy (open)="onOpen($event)" (close)="onClose($event)"></zippy> * ``` * * Uses 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. * @stable */ var EventEmitter = (function (_super) { __extends(EventEmitter, _super); /** * Creates an instance of [EventEmitter], which depending on [isAsync], * delivers events synchronously or asynchronously. */ function EventEmitter(isAsync) { if (isAsync === void 0) { isAsync = false; } _super.call(this); this.__isAsync = isAsync; } EventEmitter.prototype.emit = function (value) { _super.prototype.next.call(this, value); }; /** * @deprecated - use .emit(value) instead */ EventEmitter.prototype.next = function (value) { _super.prototype.next.call(this, value); }; EventEmitter.prototype.subscribe = function (generatorOrNext, error, complete) { var schedulerFn; var errorFn = function (err) { return null; }; var completeFn = function () { return null; }; if (generatorOrNext && typeof generatorOrNext === 'object') { schedulerFn = this.__isAsync ? function (value /** TODO #9100 */) { setTimeout(function () { return generatorOrNext.next(value); }); } : function (value /** TODO #9100 */) { generatorOrNext.next(value); }; if (generatorOrNext.error) { errorFn = this.__isAsync ? function (err) { setTimeout(function () { return generatorOrNext.error(err); }); } : function (err) { generatorOrNext.error(err); }; } if (generatorOrNext.complete) { completeFn = this.__isAsync ? function () { setTimeout(function () { return generatorOrNext.complete(); }); } : function () { generatorOrNext.complete(); }; } } else { schedulerFn = this.__isAsync ? function (value /** TODO #9100 */) { setTimeout(function () { return generatorOrNext(value); }); } : function (value /** TODO #9100 */) { generatorOrNext(value); }; if (error) { errorFn = this.__isAsync ? function (err) { setTimeout(function () { return error(err); }); } : function (err) { error(err); }; } if (complete) { completeFn = this.__isAsync ? function () { setTimeout(function () { return complete(); }); } : function () { complete(); }; } } return _super.prototype.subscribe.call(this, schedulerFn, errorFn, completeFn); }; return EventEmitter; }(Subject_1.Subject)); exports.EventEmitter = EventEmitter; //# sourceMappingURL=async.js.map