@schoolbelle/common
Version:
Demo library to showcase Angular packaging format
193 lines (192 loc) • 14.4 kB
JavaScript
/**
* @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"]}