New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

@chatie/angular

Package Overview
Dependencies
Maintainers
2
Versions
62
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@chatie/angular - npm Package Compare versions

Comparing version 0.7.2 to 0.7.3

4

bundles/chatie-angular.umd.js

@@ -311,3 +311,3 @@ (function (global, factory) {

*/
var VERSION = '0.7.2';
var VERSION = '0.7.3';

@@ -880,3 +880,3 @@ var ReadyState;

args: ['message'],
script: 'return this.syncMessage(message)',
source: 'return this.syncMessage(message)',
},

@@ -883,0 +883,0 @@ };

@@ -15,3 +15,3 @@ !function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("rxjs"),require("rxjs/operators"),require("brolog"),require("state-switch")):"function"==typeof define&&define.amd?define("@chatie/angular",["exports","@angular/core","rxjs","rxjs/operators","brolog","state-switch"],t):t(((e="undefined"!=typeof globalThis?globalThis:e||self).chatie=e.chatie||{},e.chatie.angular={}),e.ng.core,e.rxjs,e.rxjs.operators,e.brolog,e.stateSwitch)}(this,(function(e,t,o,n,s,i){"use strict";

PERFORMANCE OF THIS SOFTWARE.
***************************************************************************** */function r(e,t,o,n){return new(o||(o=Promise))((function(s,i){function r(e){try{c(n.next(e))}catch(e){i(e)}}function a(e){try{c(n.throw(e))}catch(e){i(e)}}function c(e){var t;e.done?s(e.value):(t=e.value,t instanceof o?t:new o((function(e){e(t)}))).then(r,a)}c((n=n.apply(e,t||[])).next())}))}function a(e,t){var o,n,s,i,r={label:0,sent:function(){if(1&s[0])throw s[1];return s[1]},trys:[],ops:[]};return i={next:a(0),throw:a(1),return:a(2)},"function"==typeof Symbol&&(i[Symbol.iterator]=function(){return this}),i;function a(i){return function(a){return function(i){if(o)throw new TypeError("Generator is already executing.");for(;r;)try{if(o=1,n&&(s=2&i[0]?n.return:i[0]?n.throw||((s=n.return)&&s.call(n),0):n.next)&&!(s=s.call(n,i[1])).done)return s;switch(n=0,s&&(i=[2&i[0],s.value]),i[0]){case 0:case 1:s=i;break;case 4:return r.label++,{value:i[1],done:!1};case 5:r.label++,n=i[1],i=[0];continue;case 7:i=r.ops.pop(),r.trys.pop();continue;default:if(!(s=r.trys,(s=s.length>0&&s[s.length-1])||6!==i[0]&&2!==i[0])){r=0;continue}if(3===i[0]&&(!s||i[1]>s[0]&&i[1]<s[3])){r.label=i[1];break}if(6===i[0]&&r.label<s[1]){r.label=s[1],s=i;break}if(s&&r.label<s[2]){r.label=s[2],r.ops.push(i);break}s[2]&&r.ops.pop(),r.trys.pop();continue}i=t.call(e,r)}catch(e){i=[6,e],n=0}finally{o=s=0}if(5&i[0])throw i[1];return{value:i[0]?i[1]:void 0,done:!0}}([i,a])}}}Object.create;Object.create;var c,h="0.7.2";!function(e){e[e.CLOSED=WebSocket.CLOSED]="CLOSED",e[e.CLOSING=WebSocket.CLOSING]="CLOSING",e[e.CONNECTING=WebSocket.CONNECTING]="CONNECTING",e[e.OPEN=WebSocket.OPEN]="OPEN"}(c||(c={}));var u=function(){function e(){this.autoReconnect=!0,this.log=s.Brolog.instance(),this.CONNECT_TIMEOUT=1e4,this.ENDPOINT="wss://api.chatie.io/v0/websocket/token/",this.PROTOCOL="web|0.0.1",this.sendBuffer=[],this.log.verbose("IoService","constructor()")}return Object.defineProperty(e.prototype,"readyState",{get:function(){return this._readyState.asObservable()},enumerable:!1,configurable:!0}),e.prototype.init=function(){return r(this,void 0,void 0,(function(){var e,t=this;return a(this,(function(n){switch(n.label){case 0:if(this.log.verbose("IoService","init()"),this.state)throw new Error("re-init");this.snapshot={readyState:c.CLOSED,event:null},this._readyState=new o.BehaviorSubject(c.CLOSED),this.state=new i.StateSwitch("IoService",this.log),this.state.setLog(this.log),n.label=1;case 1:return n.trys.push([1,4,,5]),[4,this.initStateDealer()];case 2:return n.sent(),[4,this.initRxSocket()];case 3:return n.sent(),[3,5];case 4:throw e=n.sent(),this.log.silly("IoService","init() exception: %s",e.message),e;case 5:return this.readyState.subscribe((function(e){t.log.silly("IoService","init() readyState.subscribe(%s)",c[e]),t.snapshot.readyState=e})),this.event.subscribe((function(e){t.log.silly("IoService","init() event.subscribe({name:%s})",e.name),t.snapshot.event=e})),[2]}}))}))},e.prototype.token=function(e){if(this.log.silly("IoService","token(%s)",e),!e)return this._token;this._token=e},e.prototype.start=function(){return r(this,void 0,void 0,(function(){var e;return a(this,(function(t){switch(t.label){case 0:if(this.log.verbose("IoService","start() with token:%s",this._token),!this._token)throw new Error("start() without token");if(this.state.on())throw new Error("state is already ON");if(this.state.pending())throw new Error("state is pending");this.state.on("pending"),this.autoReconnect=!0,t.label=1;case 1:return t.trys.push([1,3,,4]),[4,this.connectRxSocket()];case 2:return t.sent(),this.state.on(!0),[3,4];case 3:return e=t.sent(),this.log.warn("IoService","start() failed:%s",e.message),this.state.off(!0),[3,4];case 4:return[2]}}))}))},e.prototype.stop=function(){return r(this,void 0,void 0,(function(){return a(this,(function(e){switch(e.label){case 0:if(this.log.verbose("IoService","stop()"),this.state.off()){if(this.log.warn("IoService","stop() state is already off"),this.state.pending())throw new Error("state pending() is true");return[2]}if(this.state.off("pending"),this.autoReconnect=!1,!this._websocket)throw new Error("no websocket");return[4,this.socketClose(1e3,"IoService.stop()")];case 1:return e.sent(),this.state.off(!0),[2]}}))}))},e.prototype.restart=function(){return r(this,void 0,void 0,(function(){var e;return a(this,(function(t){switch(t.label){case 0:this.log.verbose("IoService","restart()"),t.label=1;case 1:return t.trys.push([1,4,,5]),[4,this.stop()];case 2:return t.sent(),[4,this.start()];case 3:return t.sent(),[3,5];case 4:throw e=t.sent(),this.log.error("IoService","restart() error:%s",e.message),e;case 5:return[2]}}))}))},e.prototype.initStateDealer=function(){var e=this;this.log.verbose("IoService","initStateDealer()");this.readyState.pipe(n.filter((function(e){return e===c.OPEN}))).subscribe((function(t){return e.stateOnOpen()}))},e.prototype.initRxSocket=function(){return r(this,void 0,void 0,(function(){var e,t=this;return a(this,(function(s){if(this.log.verbose("IoService","initRxSocket()"),this.event)throw new Error("re-init is not permitted");return this.moObserver={next:this.socketSend.bind(this),error:this.socketClose.bind(this),complete:this.socketClose.bind(this)},e=new o.Observable((function(e){return t.log.verbose("IoService","initRxSocket() Observable.create()"),t.mtObserver=e,t.socketClose.bind(t)})),this.event=o.Subject.create(this.moObserver,e.pipe(n.share())),[2]}))}))},e.prototype.connectRxSocket=function(){return r(this,void 0,void 0,(function(){var e,t=this;return a(this,(function(o){if(this.log.verbose("IoService","connectRxSocket()"),this._websocket)throw new Error("already has a websocket");if(this.state.off())throw new Error("switch state is off");if(!this.state.pending())throw new Error("switch state is already ON");return this._websocket=new WebSocket(this.endPoint(),this.PROTOCOL),this.socketUpdateState(),e=new Promise((function(e,o){t.log.verbose("IoService","connectRxSocket() Promise()");var n=setTimeout((function(){t._websocket=null;var e=new Error("rxSocket connect timeout after "+Math.round(t.CONNECT_TIMEOUT/1e3));o(e)}),t.CONNECT_TIMEOUT);t._websocket.onopen=function(o){t.log.verbose("IoService","connectRxSocket() Promise() WebSocket.onOpen() resolve()"),t.socketUpdateState(),clearTimeout(n),e()}})),this._websocket.onmessage=this.socketOnMessage.bind(this),this._websocket.onerror=this.socketOnError.bind(this),this._websocket.onclose=this.socketOnClose.bind(this),[2,e]}))}))},e.prototype.endPoint=function(){var e=this.ENDPOINT+this._token;return this.log.verbose("IoService","endPoint() => %s",e),e},e.prototype.stateOnOpen=function(){this.log.verbose("IoService","stateOnOpen()"),this.socketSendBuffer(),this.rpcUpdate("from stateOnOpen()")},e.prototype.rpcDing=function(e){return r(this,void 0,void 0,(function(){var t;return a(this,(function(o){return this.log.verbose("IoService","ding(%s)",e),t={name:"ding",payload:e},this.event.next(t),[2]}))}))},e.prototype.rpcUpdate=function(e){return r(this,void 0,void 0,(function(){return a(this,(function(t){return this.event.next({name:"update",payload:e}),[2]}))}))},e.prototype.socketClose=function(e,t){return r(this,void 0,void 0,(function(){var o=this;return a(this,(function(s){switch(s.label){case 0:if(this.log.verbose("IoService","socketClose()"),!this._websocket)throw new Error("no websocket");return this._websocket.close(e,t),this.socketUpdateState(),[4,new Promise((function(e){o.readyState.pipe(n.filter((function(e){return e===c.CLOSED}))).subscribe(e)}))];case 1:return s.sent(),[2]}}))}))},e.prototype.socketSend=function(e){this.log.silly("IoService","socketSend({name:%s, payload:%s})",e.name,e.payload),this._websocket||this.log.silly("IoService","socketSend() no _websocket");var t=JSON.stringify(e);this.sendBuffer.push(t),this.socketSendBuffer()},e.prototype.socketSendBuffer=function(){if(this.log.silly("IoService","socketSendBuffer() length:%s",this.sendBuffer.length),!this._websocket)throw new Error("socketSendBuffer(): no _websocket");if(this._websocket.readyState===WebSocket.OPEN)for(;this.sendBuffer.length;){var e=this.sendBuffer.shift();this.log.silly("IoService","socketSendBuffer() sending(%s)",e),this._websocket.send(e)}else this.log.warn("IoService","socketSendBuffer() readyState is not OPEN, send job delayed.")},e.prototype.socketUpdateState=function(){this.log.verbose("IoService","socketUpdateState() is %s",c[this._websocket.readyState]),this._websocket?this._readyState.next(this._websocket.readyState):this.log.error("IoService","socketUpdateState() no _websocket")},e.prototype.socketOnMessage=function(e){this.log.verbose("IoService","onMessage({data: %s})",e.data);var t=e.data,o={name:"raw",payload:t};try{var n=JSON.parse(t);o.name=n.name,o.payload=n.payload}catch(e){this.log.warn("IoService","onMessage parse message fail. save as RAW")}this.mtObserver.next(o)},e.prototype.socketOnError=function(e){this.log.silly("IoService","socketOnError(%s)",e)},e.prototype.socketOnClose=function(e){var t=this;this.log.verbose("IoService","socketOnClose({code:%s, reason:%s, returnValue:%s})",e.code,e.reason,e.returnValue),this.socketUpdateState(),this.autoReconnect?(this.state.on("pending"),setTimeout((function(){return r(t,void 0,void 0,(function(){var e;return a(this,(function(t){switch(t.label){case 0:return t.trys.push([0,2,,3]),[4,this.connectRxSocket()];case 1:return t.sent(),this.state.on(!0),[3,3];case 2:return e=t.sent(),this.log.warn("IoService","socketOnClose() autoReconnect() exception: %s",e),this.state.off(!0),[3,3];case 3:return[2]}}))}))}),1e3)):this.state.off(!0),this._websocket=null,e.wasClean||this.log.warn("IoService","socketOnClose() event.wasClean FALSE")},e}(),l=function(){function e(e,o){this.log=e,this.ngZone=o,this.message=new t.EventEmitter,this.scan=new t.EventEmitter,this.login=new t.EventEmitter,this.logout=new t.EventEmitter,this.error=new t.EventEmitter,this.heartbeat=new t.EventEmitter,this.timerSub=null,this.counter=0,this.timestamp=new Date,this.log.verbose("WechatyComponent","constructor() v%s",h)}return Object.defineProperty(e.prototype,"token",{get:function(){return this._token},set:function(e){this.log.verbose("WechatyComponent","set token(%s)",e);var t=(e||"").trim();if(this._token!==t){if(this._token=t,!this.ioService)return this.log.silly("WechatyComponent","set token() skip token init value"),void this.log.silly("WechatyComponent","set token() because ioService will do it inside ngOnInit()");this.log.silly("WechatyComponent","set token(%s) reloading ioService now...",t),this.ioService.token(this.token),this.ioService.restart()}else this.log.silly("WechatyComponent","set token(%s) not new",t)},enumerable:!1,configurable:!0}),e.prototype.ngOnInit=function(){return r(this,void 0,void 0,(function(){return a(this,(function(e){switch(e.label){case 0:return this.log.verbose("WechatyComponent","ngOnInit() with token: "+this.token),this.ioService=new u,[4,this.ioService.init()];case 1:return e.sent(),this.ioService.event.subscribe(this.onIo.bind(this)),this.log.silly("WechatyComponent","ngOnInit() ioService.event.subscribe()-ed"),this.token?(this.ioService.token(this.token),[4,this.ioService.start()]):[3,3];case 2:e.sent(),e.label=3;case 3:return[2]}}))}))},e.prototype.ngOnDestroy=function(){this.log.verbose("WechatyComponent","ngOnDestroy()"),this.endTimer(),this.ioService&&this.ioService.stop()},e.prototype.onIo=function(e){switch(this.log.silly("WechatyComponent","onIo#%d(%s)",this.counter++,e.name),this.timestamp=new Date,e.name){case"scan":this.scan.emit(e.payload);break;case"login":this.login.emit(e.payload);break;case"logout":this.logout.emit(e.payload);break;case"message":this.message.emit(e.payload);break;case"error":this.error.emit(e.payload);break;case"ding":case"dong":case"raw":this.heartbeat.emit(e.name+"["+e.payload+"]");break;case"heartbeat":this.heartbeat.emit(e.payload);break;case"sys":this.log.silly("WechatyComponent","onIo(%s): %s",e.name,e.payload);break;default:this.log.warn("WechatyComponent","onIo() unknown event name: %s[%s]",e.name,e.payload)}},e.prototype.reset=function(e){this.log.verbose("WechatyComponent","reset(%s)",e);var t={name:"reset",payload:e};if(!this.ioService)throw new Error("no ioService");this.ioService.event.next(t)},e.prototype.shutdown=function(e){this.log.verbose("WechatyComponent","shutdown(%s)",e);var t={name:"shutdown",payload:e};if(!this.ioService)throw new Error("no ioService");this.ioService.event.next(t)},e.prototype.startSyncMessage=function(){this.log.verbose("WechatyComponent","startSyncMessage()");if(!this.ioService)throw new Error("no ioService");this.ioService.event.next({name:"botie",payload:{args:["message"],script:"return this.syncMessage(message)"}})},e.prototype.startTimer=function(){var e=this;this.log.verbose("WechatyComponent","startTimer()"),this.ender=new o.Subject,this.ngZone.runOutsideAngular((function(){e.timer=o.interval(3e3).pipe(n.tap((function(t){e.log.verbose("do"," %d",t)})),n.takeUntil(e.ender),n.share())})),this.timerSub=this.timer.subscribe((function(t){if(e.counter=t,!e.ioService)throw new Error("no ioService");e.ioService.rpcDing(e.counter)}))},e.prototype.endTimer=function(){this.log.verbose("WechatyComponent","endTimer()"),this.timerSub&&(this.timerSub.unsubscribe(),this.timerSub=null),this.ender&&this.ender.next(null)},e.prototype.logoff=function(e){this.log.silly("WechatyComponent","logoff(%s)",e);var t={name:"logout",payload:e};this.ioService.event.next(t)},Object.defineProperty(e.prototype,"readyState",{get:function(){return this.ioService.readyState},enumerable:!1,configurable:!0}),e}();l.decorators=[{type:t.Component,args:[{selector:"wechaty",template:"<ng-content></ng-content>"}]}],l.ctorParameters=function(){return[{type:s.Brolog},{type:t.NgZone}]},l.propDecorators={message:[{type:t.Output}],scan:[{type:t.Output}],login:[{type:t.Output}],logout:[{type:t.Output}],error:[{type:t.Output}],heartbeat:[{type:t.Output}],token:[{type:t.Input}]};var p=function(){};p.decorators=[{type:t.NgModule,args:[{id:"wechaty",declarations:[l],exports:[l]}]}],e.VERSION=h,e.WechatyComponent=l,e.WechatyModule=p,e.ɵa=l,Object.defineProperty(e,"__esModule",{value:!0})}));
***************************************************************************** */function r(e,t,o,n){return new(o||(o=Promise))((function(s,i){function r(e){try{c(n.next(e))}catch(e){i(e)}}function a(e){try{c(n.throw(e))}catch(e){i(e)}}function c(e){var t;e.done?s(e.value):(t=e.value,t instanceof o?t:new o((function(e){e(t)}))).then(r,a)}c((n=n.apply(e,t||[])).next())}))}function a(e,t){var o,n,s,i,r={label:0,sent:function(){if(1&s[0])throw s[1];return s[1]},trys:[],ops:[]};return i={next:a(0),throw:a(1),return:a(2)},"function"==typeof Symbol&&(i[Symbol.iterator]=function(){return this}),i;function a(i){return function(a){return function(i){if(o)throw new TypeError("Generator is already executing.");for(;r;)try{if(o=1,n&&(s=2&i[0]?n.return:i[0]?n.throw||((s=n.return)&&s.call(n),0):n.next)&&!(s=s.call(n,i[1])).done)return s;switch(n=0,s&&(i=[2&i[0],s.value]),i[0]){case 0:case 1:s=i;break;case 4:return r.label++,{value:i[1],done:!1};case 5:r.label++,n=i[1],i=[0];continue;case 7:i=r.ops.pop(),r.trys.pop();continue;default:if(!(s=r.trys,(s=s.length>0&&s[s.length-1])||6!==i[0]&&2!==i[0])){r=0;continue}if(3===i[0]&&(!s||i[1]>s[0]&&i[1]<s[3])){r.label=i[1];break}if(6===i[0]&&r.label<s[1]){r.label=s[1],s=i;break}if(s&&r.label<s[2]){r.label=s[2],r.ops.push(i);break}s[2]&&r.ops.pop(),r.trys.pop();continue}i=t.call(e,r)}catch(e){i=[6,e],n=0}finally{o=s=0}if(5&i[0])throw i[1];return{value:i[0]?i[1]:void 0,done:!0}}([i,a])}}}Object.create;Object.create;var c,h="0.7.3";!function(e){e[e.CLOSED=WebSocket.CLOSED]="CLOSED",e[e.CLOSING=WebSocket.CLOSING]="CLOSING",e[e.CONNECTING=WebSocket.CONNECTING]="CONNECTING",e[e.OPEN=WebSocket.OPEN]="OPEN"}(c||(c={}));var u=function(){function e(){this.autoReconnect=!0,this.log=s.Brolog.instance(),this.CONNECT_TIMEOUT=1e4,this.ENDPOINT="wss://api.chatie.io/v0/websocket/token/",this.PROTOCOL="web|0.0.1",this.sendBuffer=[],this.log.verbose("IoService","constructor()")}return Object.defineProperty(e.prototype,"readyState",{get:function(){return this._readyState.asObservable()},enumerable:!1,configurable:!0}),e.prototype.init=function(){return r(this,void 0,void 0,(function(){var e,t=this;return a(this,(function(n){switch(n.label){case 0:if(this.log.verbose("IoService","init()"),this.state)throw new Error("re-init");this.snapshot={readyState:c.CLOSED,event:null},this._readyState=new o.BehaviorSubject(c.CLOSED),this.state=new i.StateSwitch("IoService",this.log),this.state.setLog(this.log),n.label=1;case 1:return n.trys.push([1,4,,5]),[4,this.initStateDealer()];case 2:return n.sent(),[4,this.initRxSocket()];case 3:return n.sent(),[3,5];case 4:throw e=n.sent(),this.log.silly("IoService","init() exception: %s",e.message),e;case 5:return this.readyState.subscribe((function(e){t.log.silly("IoService","init() readyState.subscribe(%s)",c[e]),t.snapshot.readyState=e})),this.event.subscribe((function(e){t.log.silly("IoService","init() event.subscribe({name:%s})",e.name),t.snapshot.event=e})),[2]}}))}))},e.prototype.token=function(e){if(this.log.silly("IoService","token(%s)",e),!e)return this._token;this._token=e},e.prototype.start=function(){return r(this,void 0,void 0,(function(){var e;return a(this,(function(t){switch(t.label){case 0:if(this.log.verbose("IoService","start() with token:%s",this._token),!this._token)throw new Error("start() without token");if(this.state.on())throw new Error("state is already ON");if(this.state.pending())throw new Error("state is pending");this.state.on("pending"),this.autoReconnect=!0,t.label=1;case 1:return t.trys.push([1,3,,4]),[4,this.connectRxSocket()];case 2:return t.sent(),this.state.on(!0),[3,4];case 3:return e=t.sent(),this.log.warn("IoService","start() failed:%s",e.message),this.state.off(!0),[3,4];case 4:return[2]}}))}))},e.prototype.stop=function(){return r(this,void 0,void 0,(function(){return a(this,(function(e){switch(e.label){case 0:if(this.log.verbose("IoService","stop()"),this.state.off()){if(this.log.warn("IoService","stop() state is already off"),this.state.pending())throw new Error("state pending() is true");return[2]}if(this.state.off("pending"),this.autoReconnect=!1,!this._websocket)throw new Error("no websocket");return[4,this.socketClose(1e3,"IoService.stop()")];case 1:return e.sent(),this.state.off(!0),[2]}}))}))},e.prototype.restart=function(){return r(this,void 0,void 0,(function(){var e;return a(this,(function(t){switch(t.label){case 0:this.log.verbose("IoService","restart()"),t.label=1;case 1:return t.trys.push([1,4,,5]),[4,this.stop()];case 2:return t.sent(),[4,this.start()];case 3:return t.sent(),[3,5];case 4:throw e=t.sent(),this.log.error("IoService","restart() error:%s",e.message),e;case 5:return[2]}}))}))},e.prototype.initStateDealer=function(){var e=this;this.log.verbose("IoService","initStateDealer()");this.readyState.pipe(n.filter((function(e){return e===c.OPEN}))).subscribe((function(t){return e.stateOnOpen()}))},e.prototype.initRxSocket=function(){return r(this,void 0,void 0,(function(){var e,t=this;return a(this,(function(s){if(this.log.verbose("IoService","initRxSocket()"),this.event)throw new Error("re-init is not permitted");return this.moObserver={next:this.socketSend.bind(this),error:this.socketClose.bind(this),complete:this.socketClose.bind(this)},e=new o.Observable((function(e){return t.log.verbose("IoService","initRxSocket() Observable.create()"),t.mtObserver=e,t.socketClose.bind(t)})),this.event=o.Subject.create(this.moObserver,e.pipe(n.share())),[2]}))}))},e.prototype.connectRxSocket=function(){return r(this,void 0,void 0,(function(){var e,t=this;return a(this,(function(o){if(this.log.verbose("IoService","connectRxSocket()"),this._websocket)throw new Error("already has a websocket");if(this.state.off())throw new Error("switch state is off");if(!this.state.pending())throw new Error("switch state is already ON");return this._websocket=new WebSocket(this.endPoint(),this.PROTOCOL),this.socketUpdateState(),e=new Promise((function(e,o){t.log.verbose("IoService","connectRxSocket() Promise()");var n=setTimeout((function(){t._websocket=null;var e=new Error("rxSocket connect timeout after "+Math.round(t.CONNECT_TIMEOUT/1e3));o(e)}),t.CONNECT_TIMEOUT);t._websocket.onopen=function(o){t.log.verbose("IoService","connectRxSocket() Promise() WebSocket.onOpen() resolve()"),t.socketUpdateState(),clearTimeout(n),e()}})),this._websocket.onmessage=this.socketOnMessage.bind(this),this._websocket.onerror=this.socketOnError.bind(this),this._websocket.onclose=this.socketOnClose.bind(this),[2,e]}))}))},e.prototype.endPoint=function(){var e=this.ENDPOINT+this._token;return this.log.verbose("IoService","endPoint() => %s",e),e},e.prototype.stateOnOpen=function(){this.log.verbose("IoService","stateOnOpen()"),this.socketSendBuffer(),this.rpcUpdate("from stateOnOpen()")},e.prototype.rpcDing=function(e){return r(this,void 0,void 0,(function(){var t;return a(this,(function(o){return this.log.verbose("IoService","ding(%s)",e),t={name:"ding",payload:e},this.event.next(t),[2]}))}))},e.prototype.rpcUpdate=function(e){return r(this,void 0,void 0,(function(){return a(this,(function(t){return this.event.next({name:"update",payload:e}),[2]}))}))},e.prototype.socketClose=function(e,t){return r(this,void 0,void 0,(function(){var o=this;return a(this,(function(s){switch(s.label){case 0:if(this.log.verbose("IoService","socketClose()"),!this._websocket)throw new Error("no websocket");return this._websocket.close(e,t),this.socketUpdateState(),[4,new Promise((function(e){o.readyState.pipe(n.filter((function(e){return e===c.CLOSED}))).subscribe(e)}))];case 1:return s.sent(),[2]}}))}))},e.prototype.socketSend=function(e){this.log.silly("IoService","socketSend({name:%s, payload:%s})",e.name,e.payload),this._websocket||this.log.silly("IoService","socketSend() no _websocket");var t=JSON.stringify(e);this.sendBuffer.push(t),this.socketSendBuffer()},e.prototype.socketSendBuffer=function(){if(this.log.silly("IoService","socketSendBuffer() length:%s",this.sendBuffer.length),!this._websocket)throw new Error("socketSendBuffer(): no _websocket");if(this._websocket.readyState===WebSocket.OPEN)for(;this.sendBuffer.length;){var e=this.sendBuffer.shift();this.log.silly("IoService","socketSendBuffer() sending(%s)",e),this._websocket.send(e)}else this.log.warn("IoService","socketSendBuffer() readyState is not OPEN, send job delayed.")},e.prototype.socketUpdateState=function(){this.log.verbose("IoService","socketUpdateState() is %s",c[this._websocket.readyState]),this._websocket?this._readyState.next(this._websocket.readyState):this.log.error("IoService","socketUpdateState() no _websocket")},e.prototype.socketOnMessage=function(e){this.log.verbose("IoService","onMessage({data: %s})",e.data);var t=e.data,o={name:"raw",payload:t};try{var n=JSON.parse(t);o.name=n.name,o.payload=n.payload}catch(e){this.log.warn("IoService","onMessage parse message fail. save as RAW")}this.mtObserver.next(o)},e.prototype.socketOnError=function(e){this.log.silly("IoService","socketOnError(%s)",e)},e.prototype.socketOnClose=function(e){var t=this;this.log.verbose("IoService","socketOnClose({code:%s, reason:%s, returnValue:%s})",e.code,e.reason,e.returnValue),this.socketUpdateState(),this.autoReconnect?(this.state.on("pending"),setTimeout((function(){return r(t,void 0,void 0,(function(){var e;return a(this,(function(t){switch(t.label){case 0:return t.trys.push([0,2,,3]),[4,this.connectRxSocket()];case 1:return t.sent(),this.state.on(!0),[3,3];case 2:return e=t.sent(),this.log.warn("IoService","socketOnClose() autoReconnect() exception: %s",e),this.state.off(!0),[3,3];case 3:return[2]}}))}))}),1e3)):this.state.off(!0),this._websocket=null,e.wasClean||this.log.warn("IoService","socketOnClose() event.wasClean FALSE")},e}(),l=function(){function e(e,o){this.log=e,this.ngZone=o,this.message=new t.EventEmitter,this.scan=new t.EventEmitter,this.login=new t.EventEmitter,this.logout=new t.EventEmitter,this.error=new t.EventEmitter,this.heartbeat=new t.EventEmitter,this.timerSub=null,this.counter=0,this.timestamp=new Date,this.log.verbose("WechatyComponent","constructor() v%s",h)}return Object.defineProperty(e.prototype,"token",{get:function(){return this._token},set:function(e){this.log.verbose("WechatyComponent","set token(%s)",e);var t=(e||"").trim();if(this._token!==t){if(this._token=t,!this.ioService)return this.log.silly("WechatyComponent","set token() skip token init value"),void this.log.silly("WechatyComponent","set token() because ioService will do it inside ngOnInit()");this.log.silly("WechatyComponent","set token(%s) reloading ioService now...",t),this.ioService.token(this.token),this.ioService.restart()}else this.log.silly("WechatyComponent","set token(%s) not new",t)},enumerable:!1,configurable:!0}),e.prototype.ngOnInit=function(){return r(this,void 0,void 0,(function(){return a(this,(function(e){switch(e.label){case 0:return this.log.verbose("WechatyComponent","ngOnInit() with token: "+this.token),this.ioService=new u,[4,this.ioService.init()];case 1:return e.sent(),this.ioService.event.subscribe(this.onIo.bind(this)),this.log.silly("WechatyComponent","ngOnInit() ioService.event.subscribe()-ed"),this.token?(this.ioService.token(this.token),[4,this.ioService.start()]):[3,3];case 2:e.sent(),e.label=3;case 3:return[2]}}))}))},e.prototype.ngOnDestroy=function(){this.log.verbose("WechatyComponent","ngOnDestroy()"),this.endTimer(),this.ioService&&this.ioService.stop()},e.prototype.onIo=function(e){switch(this.log.silly("WechatyComponent","onIo#%d(%s)",this.counter++,e.name),this.timestamp=new Date,e.name){case"scan":this.scan.emit(e.payload);break;case"login":this.login.emit(e.payload);break;case"logout":this.logout.emit(e.payload);break;case"message":this.message.emit(e.payload);break;case"error":this.error.emit(e.payload);break;case"ding":case"dong":case"raw":this.heartbeat.emit(e.name+"["+e.payload+"]");break;case"heartbeat":this.heartbeat.emit(e.payload);break;case"sys":this.log.silly("WechatyComponent","onIo(%s): %s",e.name,e.payload);break;default:this.log.warn("WechatyComponent","onIo() unknown event name: %s[%s]",e.name,e.payload)}},e.prototype.reset=function(e){this.log.verbose("WechatyComponent","reset(%s)",e);var t={name:"reset",payload:e};if(!this.ioService)throw new Error("no ioService");this.ioService.event.next(t)},e.prototype.shutdown=function(e){this.log.verbose("WechatyComponent","shutdown(%s)",e);var t={name:"shutdown",payload:e};if(!this.ioService)throw new Error("no ioService");this.ioService.event.next(t)},e.prototype.startSyncMessage=function(){this.log.verbose("WechatyComponent","startSyncMessage()");if(!this.ioService)throw new Error("no ioService");this.ioService.event.next({name:"botie",payload:{args:["message"],source:"return this.syncMessage(message)"}})},e.prototype.startTimer=function(){var e=this;this.log.verbose("WechatyComponent","startTimer()"),this.ender=new o.Subject,this.ngZone.runOutsideAngular((function(){e.timer=o.interval(3e3).pipe(n.tap((function(t){e.log.verbose("do"," %d",t)})),n.takeUntil(e.ender),n.share())})),this.timerSub=this.timer.subscribe((function(t){if(e.counter=t,!e.ioService)throw new Error("no ioService");e.ioService.rpcDing(e.counter)}))},e.prototype.endTimer=function(){this.log.verbose("WechatyComponent","endTimer()"),this.timerSub&&(this.timerSub.unsubscribe(),this.timerSub=null),this.ender&&this.ender.next(null)},e.prototype.logoff=function(e){this.log.silly("WechatyComponent","logoff(%s)",e);var t={name:"logout",payload:e};this.ioService.event.next(t)},Object.defineProperty(e.prototype,"readyState",{get:function(){return this.ioService.readyState},enumerable:!1,configurable:!0}),e}();l.decorators=[{type:t.Component,args:[{selector:"wechaty",template:"<ng-content></ng-content>"}]}],l.ctorParameters=function(){return[{type:s.Brolog},{type:t.NgZone}]},l.propDecorators={message:[{type:t.Output}],scan:[{type:t.Output}],login:[{type:t.Output}],logout:[{type:t.Output}],error:[{type:t.Output}],heartbeat:[{type:t.Output}],token:[{type:t.Input}]};var p=function(){};p.decorators=[{type:t.NgModule,args:[{id:"wechaty",declarations:[l],exports:[l]}]}],e.VERSION=h,e.WechatyComponent=l,e.WechatyModule=p,e.ɵa=l,Object.defineProperty(e,"__esModule",{value:!0})}));
//# sourceMappingURL=chatie-angular.umd.min.js.map

@@ -1,1 +0,1 @@

{"__symbolic":"module","version":4,"metadata":{"ɵa":{"__symbolic":"reference","name":"WechatyComponent"},"ScanInfo":{"__symbolic":"interface"},"UserInfo":{"__symbolic":"interface"},"WechatyComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":47,"character":1},"arguments":[{"selector":"wechaty","template":"<ng-content></ng-content>"}]}],"members":{"message":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":66,"character":3}}]}],"scan":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":67,"character":3}}]}],"login":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":68,"character":3}}]}],"logout":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":69,"character":3}}]}],"error":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":70,"character":3}}]}],"heartbeat":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":71,"character":3}}]}],"token":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":75,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"brolog","name":"Brolog","line":108,"character":20},{"__symbolic":"reference","module":"@angular/core","name":"NgZone","line":109,"character":20}]}],"ngOnInit":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"onIo":[{"__symbolic":"method"}],"reset":[{"__symbolic":"method"}],"shutdown":[{"__symbolic":"method"}],"startSyncMessage":[{"__symbolic":"method"}],"startTimer":[{"__symbolic":"method"}],"endTimer":[{"__symbolic":"method"}],"logoff":[{"__symbolic":"method"}]}},"WechatyModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":4,"character":1},"arguments":[{"id":"wechaty","declarations":[{"__symbolic":"reference","name":"ɵa"}],"exports":[{"__symbolic":"reference","name":"ɵa"}]}]}],"members":{}},"VERSION":"0.7.2"},"origins":{"ɵa":"./src/wechaty/wechaty.component","ScanInfo":"./src/wechaty/wechaty.component","UserInfo":"./src/wechaty/wechaty.component","WechatyComponent":"./src/wechaty/wechaty.component","WechatyModule":"./src/wechaty/wechaty.module","VERSION":"./src/version"},"importAs":"@chatie/angular"}
{"__symbolic":"module","version":4,"metadata":{"ɵa":{"__symbolic":"reference","name":"WechatyComponent"},"ScanInfo":{"__symbolic":"interface"},"UserInfo":{"__symbolic":"interface"},"WechatyComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":47,"character":1},"arguments":[{"selector":"wechaty","template":"<ng-content></ng-content>"}]}],"members":{"message":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":66,"character":3}}]}],"scan":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":67,"character":3}}]}],"login":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":68,"character":3}}]}],"logout":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":69,"character":3}}]}],"error":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":70,"character":3}}]}],"heartbeat":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":71,"character":3}}]}],"token":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":75,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"brolog","name":"Brolog","line":108,"character":20},{"__symbolic":"reference","module":"@angular/core","name":"NgZone","line":109,"character":20}]}],"ngOnInit":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"onIo":[{"__symbolic":"method"}],"reset":[{"__symbolic":"method"}],"shutdown":[{"__symbolic":"method"}],"startSyncMessage":[{"__symbolic":"method"}],"startTimer":[{"__symbolic":"method"}],"endTimer":[{"__symbolic":"method"}],"logoff":[{"__symbolic":"method"}]}},"WechatyModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":4,"character":1},"arguments":[{"id":"wechaty","declarations":[{"__symbolic":"reference","name":"ɵa"}],"exports":[{"__symbolic":"reference","name":"ɵa"}]}]}],"members":{}},"VERSION":"0.7.3"},"origins":{"ɵa":"./src/wechaty/wechaty.component","ScanInfo":"./src/wechaty/wechaty.component","UserInfo":"./src/wechaty/wechaty.component","WechatyComponent":"./src/wechaty/wechaty.component","WechatyModule":"./src/wechaty/wechaty.module","VERSION":"./src/version"},"importAs":"@chatie/angular"}
/**
* This file was auto generated from scripts/generate-version.sh
*/
export const VERSION = '0.7.2';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIvaG9tZS9ydW5uZXIvd29yay9hbmd1bGFyL2FuZ3VsYXIvIiwic291cmNlcyI6WyJzcmMvdmVyc2lvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUNILE1BQU0sQ0FBQyxNQUFNLE9BQU8sR0FBVyxPQUFPLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFRoaXMgZmlsZSB3YXMgYXV0byBnZW5lcmF0ZWQgZnJvbSBzY3JpcHRzL2dlbmVyYXRlLXZlcnNpb24uc2hcbiAqL1xuZXhwb3J0IGNvbnN0IFZFUlNJT046IHN0cmluZyA9ICcwLjcuMidcbiJdfQ==
export const VERSION = '0.7.3';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIvaG9tZS9ydW5uZXIvd29yay9hbmd1bGFyL2FuZ3VsYXIvIiwic291cmNlcyI6WyJzcmMvdmVyc2lvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUNILE1BQU0sQ0FBQyxNQUFNLE9BQU8sR0FBVyxPQUFPLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFRoaXMgZmlsZSB3YXMgYXV0byBnZW5lcmF0ZWQgZnJvbSBzY3JpcHRzL2dlbmVyYXRlLXZlcnNpb24uc2hcbiAqL1xuZXhwb3J0IGNvbnN0IFZFUlNJT046IHN0cmluZyA9ICcwLjcuMydcbiJdfQ==

@@ -129,3 +129,3 @@ import { __awaiter } from "tslib";

args: ['message'],
script: 'return this.syncMessage(message)',
source: 'return this.syncMessage(message)',
},

@@ -210,2 +210,2 @@ };

};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"wechaty.component.js","sourceRoot":"/home/runner/work/angular/angular/","sources":["src/wechaty/wechaty.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { VERSION } from '../config'\n\nimport {\n  Component,\n  EventEmitter,\n  Input,\n  NgZone,\n  Output,\n  OnDestroy,\n  OnInit,\n}                   from '@angular/core'\n\nimport {\n  Observable,\n  Subject,\n  Subscription,\n  interval,\n}                   from 'rxjs'\nimport {\n  share,\n  tap,\n  takeUntil,\n}                   from 'rxjs/operators'\n\nimport { Brolog }   from 'brolog'\n\nimport {\n  IoEvent,\n  IoService,\n  // tslint:disable-next-line:no-unused-variable\n  ReadyState,\n}                   from './io'\n\n/**\n * for payload\n */\nexport interface ScanInfo {\n  qrcode: string\n  status: number\n  data?:  string\n}\n\nexport interface UserInfo {\n  id: number\n  name: string\n}\n\n@Component({\n  // tslint:disable-next-line:component-selector\n  selector: 'wechaty',\n  /**\n   * http://localhost:4200/app.component.html 404 (Not Found)\n   * zone.js:344 Unhandled Promise rejection: Failed to load app.component.html\n   * https://github.com/angular/angular-cli/issues/2592#issuecomment-266635266\n   * https://github.com/angular/angular-cli/issues/2293\n   *\n   * console.log from angular:\n   *   If you're using Webpack you should inline the template and the styles,\n   *   see https://goo.gl/X2J8zc.\n   */\n  template: '<ng-content></ng-content>',\n  // styleUrls: ['./wechaty.component.css'],\n  // templateUrl: 'wechaty.component.html',\n  // moduleId: module.id,\n})\nexport class WechatyComponent implements OnInit, OnDestroy {\n  @Output() message   = new EventEmitter<string>()\n  @Output() scan      = new EventEmitter<ScanInfo>()\n  @Output() login     = new EventEmitter<UserInfo>()\n  @Output() logout    = new EventEmitter<UserInfo>()\n  @Output() error     = new EventEmitter<Error>()\n  @Output() heartbeat = new EventEmitter<any>()\n\n  private _token: string\n  get token() { return this._token }\n  @Input() set token(_newToken: string) {\n    this.log.verbose('WechatyComponent', 'set token(%s)', _newToken)\n\n    const newToken = (_newToken || '').trim()\n\n    if (this._token === newToken) {\n      this.log.silly('WechatyComponent', 'set token(%s) not new', newToken)\n      return\n    }\n\n    this._token = newToken\n\n    if (!this.ioService) {\n      this.log.silly('WechatyComponent', 'set token() skip token init value')\n      this.log.silly('WechatyComponent', 'set token() because ioService will do it inside ngOnInit()')\n      return\n    }\n\n    this.log.silly('WechatyComponent', 'set token(%s) reloading ioService now...', newToken)\n    this.ioService.token(this.token)\n    this.ioService.restart() // async\n  }\n\n  private timer: Observable<any>\n  private timerSub: Subscription | null = null\n  private ender: Subject<any>\n\n  private ioService: IoService\n\n  counter = 0\n  timestamp = new Date()\n\n  constructor(\n    private log:    Brolog,\n    private ngZone: NgZone,\n  ) {\n    this.log.verbose('WechatyComponent', 'constructor() v%s', VERSION)\n  }\n\n  async ngOnInit() {\n    this.log.verbose('WechatyComponent', 'ngOnInit() with token: ' + this.token)\n\n    this.ioService = new IoService()\n    await this.ioService.init()\n\n    this.ioService.event.subscribe(this.onIo.bind(this))\n    this.log.silly('WechatyComponent', 'ngOnInit() ioService.event.subscribe()-ed')\n\n    /**\n     * @Input(token) might not initialized in constructor()\n     */\n    if (this.token) {\n      this.ioService.token(this.token)\n      await this.ioService.start()\n    }\n\n    // this.startTimer()\n  }\n\n  ngOnDestroy() {\n    this.log.verbose('WechatyComponent', 'ngOnDestroy()')\n\n    this.endTimer()\n\n    if (this.ioService) {\n      this.ioService.stop()\n      // this.ioService = null\n    }\n  }\n\n  onIo(e: IoEvent) {\n    this.log.silly('WechatyComponent', 'onIo#%d(%s)', this.counter++, e.name)\n    this.timestamp = new Date()\n\n    switch (e.name) {\n      case 'scan':\n        this.scan.emit(e.payload as ScanInfo)\n        break\n      case 'login':\n        this.login.emit(e.payload as UserInfo)\n        break\n      case 'logout':\n        this.logout.emit(e.payload as UserInfo)\n        break\n      case 'message':\n        this.message.emit(e.payload)\n        break\n      case 'error':\n        this.error.emit(e.payload)\n        break\n\n      case 'ding':\n      case 'dong':\n      case 'raw':\n        this.heartbeat.emit(e.name + '[' + e.payload + ']')\n        break\n      case 'heartbeat':\n        this.heartbeat.emit(e.payload)\n        break\n\n      case 'sys':\n        this.log.silly('WechatyComponent', 'onIo(%s): %s', e.name, e.payload)\n        break\n\n      default:\n        this.log.warn('WechatyComponent', 'onIo() unknown event name: %s[%s]', e.name, e.payload)\n        break\n    }\n  }\n\n  public reset(reason: string) {\n    this.log.verbose('WechatyComponent', 'reset(%s)', reason)\n\n    const resetEvent: IoEvent = {\n      name: 'reset',\n      payload: reason,\n    }\n    if (!this.ioService) {\n      throw new Error('no ioService')\n    }\n    this.ioService.event.next(resetEvent)\n  }\n\n  public shutdown(reason: string) {\n    this.log.verbose('WechatyComponent', 'shutdown(%s)', reason)\n\n    const shutdownEvent: IoEvent = {\n      name: 'shutdown',\n      payload: reason,\n    }\n    if (!this.ioService) {\n      throw new Error('no ioService')\n    }\n    this.ioService.event.next(shutdownEvent)\n  }\n\n  public startSyncMessage() {\n    this.log.verbose('WechatyComponent', 'startSyncMessage()')\n\n    const botieEvent: IoEvent = {\n      name: 'botie',\n      payload: {\n        args: ['message'],\n        script: 'return this.syncMessage(message)',\n      },\n    }\n    if (!this.ioService) {\n      throw new Error('no ioService')\n    }\n    this.ioService.event.next(botieEvent)\n  }\n\n  startTimer() {\n    this.log.verbose('WechatyComponent', 'startTimer()')\n    this.ender = new Subject()\n\n    // https://github.com/angular/protractor/issues/3349#issuecomment-232253059\n    // https://github.com/juliemr/ngconf-2016-zones/blob/master/src/app/main.ts#L38\n    this.ngZone.runOutsideAngular(() => {\n      this.timer = interval(3000).pipe(\n        tap(i => { this.log.verbose('do', ' %d', i) }),\n        takeUntil(this.ender),\n        share(),\n      )\n      // .publish()\n\n    })\n\n    this.timerSub = this.timer.subscribe(t => {\n      this.counter = t\n\n      if (!this.ioService) {\n        throw new Error('no ioService')\n      }\n      this.ioService.rpcDing(this.counter)\n      // this.message.emit('#' + this.token + ':' + dong)\n    })\n\n  }\n\n  endTimer() {\n    this.log.verbose('WechatyComponent', 'endTimer()')\n\n    if (this.timerSub) {\n      this.timerSub.unsubscribe()\n      this.timerSub = null\n    }\n    // this.timer = null\n\n    if (this.ender) {\n      this.ender.next(null)\n      // this.ender = null\n    }\n  }\n\n  logoff(reason?: string) { // use the name `logoff` here to prevent conflict with @Output(logout)\n    this.log.silly('WechatyComponent', 'logoff(%s)', reason)\n\n    const quitEvent: IoEvent = {\n      name: 'logout',\n      payload: reason,\n    }\n    this.ioService.event.next(quitEvent)\n  }\n\n  public get readyState() {\n    return this.ioService.readyState\n  }\n\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"wechaty.component.js","sourceRoot":"/home/runner/work/angular/angular/","sources":["src/wechaty/wechaty.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { VERSION } from '../config'\n\nimport {\n  Component,\n  EventEmitter,\n  Input,\n  NgZone,\n  Output,\n  OnDestroy,\n  OnInit,\n}                   from '@angular/core'\n\nimport {\n  Observable,\n  Subject,\n  Subscription,\n  interval,\n}                   from 'rxjs'\nimport {\n  share,\n  tap,\n  takeUntil,\n}                   from 'rxjs/operators'\n\nimport { Brolog }   from 'brolog'\n\nimport {\n  IoEvent,\n  IoService,\n  // tslint:disable-next-line:no-unused-variable\n  ReadyState,\n}                   from './io'\n\n/**\n * for payload\n */\nexport interface ScanInfo {\n  qrcode: string\n  status: number\n  data?:  string\n}\n\nexport interface UserInfo {\n  id: number\n  name: string\n}\n\n@Component({\n  // tslint:disable-next-line:component-selector\n  selector: 'wechaty',\n  /**\n   * http://localhost:4200/app.component.html 404 (Not Found)\n   * zone.js:344 Unhandled Promise rejection: Failed to load app.component.html\n   * https://github.com/angular/angular-cli/issues/2592#issuecomment-266635266\n   * https://github.com/angular/angular-cli/issues/2293\n   *\n   * console.log from angular:\n   *   If you're using Webpack you should inline the template and the styles,\n   *   see https://goo.gl/X2J8zc.\n   */\n  template: '<ng-content></ng-content>',\n  // styleUrls: ['./wechaty.component.css'],\n  // templateUrl: 'wechaty.component.html',\n  // moduleId: module.id,\n})\nexport class WechatyComponent implements OnInit, OnDestroy {\n  @Output() message   = new EventEmitter<string>()\n  @Output() scan      = new EventEmitter<ScanInfo>()\n  @Output() login     = new EventEmitter<UserInfo>()\n  @Output() logout    = new EventEmitter<UserInfo>()\n  @Output() error     = new EventEmitter<Error>()\n  @Output() heartbeat = new EventEmitter<any>()\n\n  private _token: string\n  get token() { return this._token }\n  @Input() set token(_newToken: string) {\n    this.log.verbose('WechatyComponent', 'set token(%s)', _newToken)\n\n    const newToken = (_newToken || '').trim()\n\n    if (this._token === newToken) {\n      this.log.silly('WechatyComponent', 'set token(%s) not new', newToken)\n      return\n    }\n\n    this._token = newToken\n\n    if (!this.ioService) {\n      this.log.silly('WechatyComponent', 'set token() skip token init value')\n      this.log.silly('WechatyComponent', 'set token() because ioService will do it inside ngOnInit()')\n      return\n    }\n\n    this.log.silly('WechatyComponent', 'set token(%s) reloading ioService now...', newToken)\n    this.ioService.token(this.token)\n    this.ioService.restart() // async\n  }\n\n  private timer: Observable<any>\n  private timerSub: Subscription | null = null\n  private ender: Subject<any>\n\n  private ioService: IoService\n\n  counter = 0\n  timestamp = new Date()\n\n  constructor(\n    private log:    Brolog,\n    private ngZone: NgZone,\n  ) {\n    this.log.verbose('WechatyComponent', 'constructor() v%s', VERSION)\n  }\n\n  async ngOnInit() {\n    this.log.verbose('WechatyComponent', 'ngOnInit() with token: ' + this.token)\n\n    this.ioService = new IoService()\n    await this.ioService.init()\n\n    this.ioService.event.subscribe(this.onIo.bind(this))\n    this.log.silly('WechatyComponent', 'ngOnInit() ioService.event.subscribe()-ed')\n\n    /**\n     * @Input(token) might not initialized in constructor()\n     */\n    if (this.token) {\n      this.ioService.token(this.token)\n      await this.ioService.start()\n    }\n\n    // this.startTimer()\n  }\n\n  ngOnDestroy() {\n    this.log.verbose('WechatyComponent', 'ngOnDestroy()')\n\n    this.endTimer()\n\n    if (this.ioService) {\n      this.ioService.stop()\n      // this.ioService = null\n    }\n  }\n\n  onIo(e: IoEvent) {\n    this.log.silly('WechatyComponent', 'onIo#%d(%s)', this.counter++, e.name)\n    this.timestamp = new Date()\n\n    switch (e.name) {\n      case 'scan':\n        this.scan.emit(e.payload as ScanInfo)\n        break\n      case 'login':\n        this.login.emit(e.payload as UserInfo)\n        break\n      case 'logout':\n        this.logout.emit(e.payload as UserInfo)\n        break\n      case 'message':\n        this.message.emit(e.payload)\n        break\n      case 'error':\n        this.error.emit(e.payload)\n        break\n\n      case 'ding':\n      case 'dong':\n      case 'raw':\n        this.heartbeat.emit(e.name + '[' + e.payload + ']')\n        break\n      case 'heartbeat':\n        this.heartbeat.emit(e.payload)\n        break\n\n      case 'sys':\n        this.log.silly('WechatyComponent', 'onIo(%s): %s', e.name, e.payload)\n        break\n\n      default:\n        this.log.warn('WechatyComponent', 'onIo() unknown event name: %s[%s]', e.name, e.payload)\n        break\n    }\n  }\n\n  public reset(reason: string) {\n    this.log.verbose('WechatyComponent', 'reset(%s)', reason)\n\n    const resetEvent: IoEvent = {\n      name: 'reset',\n      payload: reason,\n    }\n    if (!this.ioService) {\n      throw new Error('no ioService')\n    }\n    this.ioService.event.next(resetEvent)\n  }\n\n  public shutdown(reason: string) {\n    this.log.verbose('WechatyComponent', 'shutdown(%s)', reason)\n\n    const shutdownEvent: IoEvent = {\n      name: 'shutdown',\n      payload: reason,\n    }\n    if (!this.ioService) {\n      throw new Error('no ioService')\n    }\n    this.ioService.event.next(shutdownEvent)\n  }\n\n  public startSyncMessage() {\n    this.log.verbose('WechatyComponent', 'startSyncMessage()')\n\n    const botieEvent: IoEvent = {\n      name: 'botie',\n      payload: {\n        args: ['message'],\n        source: 'return this.syncMessage(message)',\n      },\n    }\n    if (!this.ioService) {\n      throw new Error('no ioService')\n    }\n    this.ioService.event.next(botieEvent)\n  }\n\n  startTimer() {\n    this.log.verbose('WechatyComponent', 'startTimer()')\n    this.ender = new Subject()\n\n    // https://github.com/angular/protractor/issues/3349#issuecomment-232253059\n    // https://github.com/juliemr/ngconf-2016-zones/blob/master/src/app/main.ts#L38\n    this.ngZone.runOutsideAngular(() => {\n      this.timer = interval(3000).pipe(\n        tap(i => { this.log.verbose('do', ' %d', i) }),\n        takeUntil(this.ender),\n        share(),\n      )\n      // .publish()\n\n    })\n\n    this.timerSub = this.timer.subscribe(t => {\n      this.counter = t\n\n      if (!this.ioService) {\n        throw new Error('no ioService')\n      }\n      this.ioService.rpcDing(this.counter)\n      // this.message.emit('#' + this.token + ':' + dong)\n    })\n\n  }\n\n  endTimer() {\n    this.log.verbose('WechatyComponent', 'endTimer()')\n\n    if (this.timerSub) {\n      this.timerSub.unsubscribe()\n      this.timerSub = null\n    }\n    // this.timer = null\n\n    if (this.ender) {\n      this.ender.next(null)\n      // this.ender = null\n    }\n  }\n\n  logoff(reason?: string) { // use the name `logoff` here to prevent conflict with @Output(logout)\n    this.log.silly('WechatyComponent', 'logoff(%s)', reason)\n\n    const quitEvent: IoEvent = {\n      name: 'logout',\n      payload: reason,\n    }\n    this.ioService.event.next(quitEvent)\n  }\n\n  public get readyState() {\n    return this.ioService.readyState\n  }\n\n}\n"]}

@@ -11,3 +11,3 @@ import { __awaiter } from 'tslib';

*/
const VERSION = '0.7.2';
const VERSION = '0.7.3';

@@ -485,3 +485,3 @@ var ReadyState;

args: ['message'],
script: 'return this.syncMessage(message)',
source: 'return this.syncMessage(message)',
},

@@ -488,0 +488,0 @@ };

{
"$schema": "./node_modules/ng-packagr/package.schema.json",
"name": "@chatie/angular",
"version": "0.7.2",
"version": "0.7.3",
"description": "Wechaty Component NgModule",

@@ -6,0 +6,0 @@ "license": "Apache-2.0",

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc