UNPKG

@schoolbelle/common

Version:

Demo library to showcase Angular packaging format

168 lines (162 loc) 13.1 kB
import { Injectable, Inject, NgZone, NgModule } from '@angular/core'; import { SOCKET_SERVER_HOST } from '@schoolbelle/common/tokens'; import { Subject } from 'rxjs'; import io from 'socket.io-client'; /** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ class SocketService { /** * @param {?} ngZone * @param {?} socketHost */ constructor(ngZone, socketHost) { 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', () => { console.log('connected as ' + this.socket.id); this.listeners.forEach(listener => { this.listen(listener.event, listener.timeout); }); }); // }); } /** * @param {?=} force * @return {?} */ connect(force = false) { console.log('socket will connect.'); return new Promise((resolve, reject) => { this.ngZone.runOutsideAngular(() => { if (this.socket.connected && force === true) { this.socket.close(); } if (!this.socket.connected) { this.socket.open(); this.socket.once('connect', () => resolve(true)); } else { resolve(true); } }); }); } /** * @param {?} event * @param {?=} timeout * @return {?} */ timeout(event, timeout = undefined) { if (typeof timeout !== 'number') return; return setTimeout(() => { this.unlisten(event); }, timeout); // cancel this subscription in timeout seconds } /** * @param {?} event * @param {?=} timeout * @return {?} */ listen(event, timeout = undefined) { // this.ngZone.runOutsideAngular(() => { if (this.listeners.get(event)) return; let /** @type {?} */ onGoingTimeout; if (typeof this.timeout === 'number') onGoingTimeout = this.timeout(event, timeout); this.connect().then(() => { this.socket.on(event, data => { if (onGoingTimeout) clearTimeout(onGoingTimeout); // if something is emitted, reset the timeout unsubscription. onGoingTimeout = this.timeout(event, timeout); // this.ngZone.run(() => { this.subject.next({ event: event, data: data }); // }); }); this.listeners.set(event, { event: event, timeout: timeout }); }); // }); } /** * @param {?} event * @return {?} */ unlisten(event) { if (!this.listeners.get(event)) return; this.listeners.delete(event); this.socket.off(event); } /** * @param {?} room * @return {?} */ join(room) { this.ngZone.runOutsideAngular(() => { this.connect().then(() => { this.socket.emit('subscribe', room); }); }); } /** * @param {?} room * @return {?} */ leave(room) { this.ngZone.runOutsideAngular(() => { this.connect().then(() => { this.socket.emit('unsubscribe', room); }); }); } /** * @param {?} event * @return {?} */ getObservable(event) { return this.subject.asObservable().filter(data => data.event === event); } } SocketService.decorators = [ { type: Injectable }, ]; /** @nocollapse */ SocketService.ctorParameters = () => [ { type: NgZone, }, { type: undefined, decorators: [{ type: Inject, args: [SOCKET_SERVER_HOST,] },] }, ]; /** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ class SocketServiceModule { /** * @return {?} */ static forRoot() { return { ngModule: SocketServiceModule, providers: [SocketService] }; } } SocketServiceModule.decorators = [ { type: NgModule, args: [{},] }, ]; /** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ /** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ export { SocketServiceModule, SocketService }; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"schoolbelle-common-services-socket.js.map","sources":["ng://@schoolbelle/common/services/socket/socket.service.ts","ng://@schoolbelle/common/services/socket/socket-service.module.ts"],"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","import { NgModule } from '@angular/core';\nimport { SocketService } from './socket.service';\n\n@NgModule({})\nexport class SocketServiceModule {\n  static forRoot() {\n    return {\n      ngModule: SocketServiceModule,\n      providers: [SocketService]\n    };\n  }\n}\n"],"names":[],"mappings":"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"}