UNPKG

@schoolbelle/common

Version:

Demo library to showcase Angular packaging format

193 lines (192 loc) 14.4 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ import { Injectable, Inject, NgZone } from '@angular/core'; import { SOCKET_SERVER_HOST } from '@schoolbelle/common/tokens'; import { Subject } from 'rxjs'; import io from 'socket.io-client'; var SocketService = /** @class */ (function () { function SocketService(ngZone, socketHost) { var _this = this; this.ngZone = ngZone; this.socketHost = socketHost; this.listeners = new Map(); this.subject = new Subject(); // this.ngZone.runOutsideAngular(() => { this.socket = io(this.socketHost, { autoConnect: false }); this.socket.on('connect', function () { console.log('connected as ' + _this.socket.id); _this.listeners.forEach(function (listener) { _this.listen(listener.event, listener.timeout); }); }); // }); } /** * @param {?=} force * @return {?} */ SocketService.prototype.connect = /** * @param {?=} force * @return {?} */ function (force) { var _this = this; if (force === void 0) { force = false; } console.log('socket will connect.'); return new Promise(function (resolve, reject) { _this.ngZone.runOutsideAngular(function () { if (_this.socket.connected && force === true) { _this.socket.close(); } if (!_this.socket.connected) { _this.socket.open(); _this.socket.once('connect', function () { return resolve(true); }); } else { resolve(true); } }); }); }; /** * @param {?} event * @param {?=} timeout * @return {?} */ SocketService.prototype.timeout = /** * @param {?} event * @param {?=} timeout * @return {?} */ function (event, timeout) { var _this = this; if (timeout === void 0) { timeout = undefined; } if (typeof timeout !== 'number') return; return setTimeout(function () { _this.unlisten(event); }, timeout); // cancel this subscription in timeout seconds }; /** * @param {?} event * @param {?=} timeout * @return {?} */ SocketService.prototype.listen = /** * @param {?} event * @param {?=} timeout * @return {?} */ function (event, timeout) { var _this = this; if (timeout === void 0) { timeout = undefined; } // this.ngZone.runOutsideAngular(() => { if (this.listeners.get(event)) return; var /** @type {?} */ onGoingTimeout; if (typeof this.timeout === 'number') onGoingTimeout = this.timeout(event, timeout); this.connect().then(function () { _this.socket.on(event, function (data) { if (onGoingTimeout) clearTimeout(onGoingTimeout); // if something is emitted, reset the timeout unsubscription. onGoingTimeout = _this.timeout(event, timeout); // this.ngZone.run(() => { // this.ngZone.run(() => { _this.subject.next({ event: event, data: data }); // }); }); _this.listeners.set(event, { event: event, timeout: timeout }); }); // }); }; /** * @param {?} event * @return {?} */ SocketService.prototype.unlisten = /** * @param {?} event * @return {?} */ function (event) { if (!this.listeners.get(event)) return; this.listeners.delete(event); this.socket.off(event); }; /** * @param {?} room * @return {?} */ SocketService.prototype.join = /** * @param {?} room * @return {?} */ function (room) { var _this = this; this.ngZone.runOutsideAngular(function () { _this.connect().then(function () { _this.socket.emit('subscribe', room); }); }); }; /** * @param {?} room * @return {?} */ SocketService.prototype.leave = /** * @param {?} room * @return {?} */ function (room) { var _this = this; this.ngZone.runOutsideAngular(function () { _this.connect().then(function () { _this.socket.emit('unsubscribe', room); }); }); }; /** * @param {?} event * @return {?} */ SocketService.prototype.getObservable = /** * @param {?} event * @return {?} */ function (event) { return this.subject.asObservable().filter(function (data) { return data.event === event; }); }; SocketService.decorators = [ { type: Injectable }, ]; /** @nocollapse */ SocketService.ctorParameters = function () { return [ { type: NgZone, }, { type: undefined, decorators: [{ type: Inject, args: [SOCKET_SERVER_HOST,] },] }, ]; }; return SocketService; }()); export { SocketService }; function SocketService_tsickle_Closure_declarations() { /** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */ SocketService.decorators; /** * @nocollapse * @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>} */ SocketService.ctorParameters; /** @type {?} */ SocketService.prototype.socket; /** @type {?} */ SocketService.prototype.listeners; /** @type {?} */ SocketService.prototype.subject; /** @type {?} */ SocketService.prototype.ngZone; /** @type {?} */ SocketService.prototype.socketHost; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"socket.service.js","sourceRoot":"ng://@schoolbelle/common/services/","sources":["socket/src/socket.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Inject, NgZone } from '@angular/core';\nimport { SOCKET_SERVER_HOST } from '@schoolbelle/common/tokens';\nimport { Observable, Subject } from 'rxjs';\nimport io from 'socket.io-client';\n\nexport type SocketListener = { event: string; timeout?: number };\nexport type SocketEvent = { event: string; data: any };\n\n@Injectable()\nexport class SocketService {\n  public socket;\n  private listeners: Map<string, SocketListener> = new Map();\n  private subject: Subject<SocketEvent> = new Subject();\n\n  constructor(\n    public ngZone: NgZone,\n    @Inject(SOCKET_SERVER_HOST) private socketHost: string\n  ) {\n    // this.ngZone.runOutsideAngular(() => {\n    this.socket = io(this.socketHost, { autoConnect: false });\n    this.socket.on('connect', () => {\n      console.log('connected as ' + this.socket.id);\n      this.listeners.forEach(listener => {\n        this.listen(listener.event, listener.timeout);\n      });\n    });\n    // });\n  }\n  connect(force: boolean = false): Promise<any> {\n    console.log('socket will connect.');\n    return new Promise((resolve, reject) => {\n      this.ngZone.runOutsideAngular(() => {\n        if (this.socket.connected && force === true) {\n          this.socket.close();\n        }\n        if (!this.socket.connected) {\n          this.socket.open();\n          this.socket.once('connect', () => resolve(true));\n        } else {\n          resolve(true);\n        }\n      });\n    });\n  }\n  private timeout(event, timeout = undefined) {\n    if (typeof timeout !== 'number') return;\n    return setTimeout(() => {\n      this.unlisten(event);\n    }, timeout); // cancel this subscription in timeout seconds\n  }\n  public listen(event, timeout: number = undefined) {\n    // this.ngZone.runOutsideAngular(() => {\n    if (this.listeners.get(event)) return;\n    let onGoingTimeout;\n    if (typeof this.timeout === 'number')\n      onGoingTimeout = this.timeout(event, timeout);\n    this.connect().then(() => {\n      this.socket.on(event, data => {\n        if (onGoingTimeout) clearTimeout(onGoingTimeout); // if something is emitted, reset the timeout unsubscription.\n        onGoingTimeout = this.timeout(event, timeout);\n        // this.ngZone.run(() => {\n        this.subject.next({ event: event, data: data });\n        // });\n      });\n      this.listeners.set(event, { event: event, timeout: timeout });\n    });\n    // });\n  }\n  public unlisten(event) {\n    if (!this.listeners.get(event)) return;\n    this.listeners.delete(event);\n    this.socket.off(event);\n  }\n  public join(room: string) {\n    this.ngZone.runOutsideAngular(() => {\n      this.connect().then(() => {\n        this.socket.emit('subscribe', room);\n      });\n    });\n  }\n  public leave(room: string) {\n    this.ngZone.runOutsideAngular(() => {\n      this.connect().then(() => {\n        this.socket.emit('unsubscribe', room);\n      });\n    });\n  }\n  getObservable(event): Observable<SocketEvent> {\n    return this.subject.asObservable().filter(data => data.event === event);\n  }\n}\n"]}