jugglechat-websdk 1.7.9 → 1.7.11

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (3) hide show
  1. package/index.d.ts +23 -6
  2. package/index.js +8 -8
  3. package/package.json +1 -1
package/index.d.ts CHANGED
@@ -267,8 +267,8 @@ declare class TimeZone{
267
267
  end: string;
268
268
  }
269
269
  declare class DisturbInfo {
270
- type: UNDISTURB_TYPE,
271
- timezone: string,
270
+ type: UNDISTURB_TYPE;
271
+ timezone: string;
272
272
  times: TimeZone[];
273
273
  }
274
274
  declare class TagInfo {
@@ -276,11 +276,15 @@ declare class TagInfo {
276
276
  name?: string;
277
277
  conversations?: Conversation[]
278
278
  }
279
+ interface SendMsgCbData { message: Message, percent?: number, count?: number, total?: number }
280
+ interface SendMsgCbCompleteData {
281
+ messages: Message[]
282
+ }
279
283
  interface SendMsgCallbacks{
280
- onbefore?(message: Message): any;
281
- onerror?(error: Error): any;
282
- onprogress?({ percent?: number, message: Message, count?: number, total?: number }):any;
283
- oncompleted?({ messages: Message[] }): any;
284
+ onbefore?(message: Message): void;
285
+ onerror?(error: Error): void;
286
+ onprogress?(data: SendMsgCbData):void;
287
+ oncompleted?(data: SendMsgCbCompleteData): void;
284
288
  }
285
289
  interface GetMsgByIdOptions{
286
290
  conversationType: CONVERATION_TYPE,
@@ -347,6 +351,13 @@ interface ReactionOptions{
347
351
  messageId: string;
348
352
  reactionId: string;
349
353
  }
354
+ interface CustomMsgOption{
355
+ name: string;
356
+ isCount?: boolean;
357
+ isStorage?: boolean;
358
+ isCommand?: boolean;
359
+ }
360
+
350
361
  declare class IMProvider {
351
362
  connect: (user: IMUser) => Promise<>;
352
363
  disconnect: () => Promise<any>;
@@ -405,6 +416,12 @@ declare class IMProvider {
405
416
  searchMessages: (options: SearchOptions) => Promise<SearchResult>;
406
417
  addMessageReaction: (message: ReactionOptions) => Promise<any>;
407
418
  removeMessageReaction: (message: ReactionOptions) => Promise<any>;
419
+ registerMessage: (names: CustomMsgOption[]) => any;
420
+ isDesktop: () => boolean;
421
+ on: (name: string, event: any) => any;
422
+ off: (name: string) => any;
423
+ clear: () => any;
424
+ once: (name: string, event: any) => any;
408
425
  Event: EVENT;
409
426
  ConnectionState: CONNECT_STATE;
410
427
  ConversationType: CONVERATION_TYPE;
package/index.js CHANGED
@@ -1,5 +1,5 @@
1
1
  /*
2
- * JuggleIM.js v1.7.9
2
+ * JuggleIM.js v1.7.11
3
3
  * (c) 2022-2024 JuggleIM
4
4
  * Released under the MIT License.
5
5
  */const noop=()=>{},isObject=e=>"[object Object]"===Object.prototype.toString.call(e),isArray=e=>"[object Array]"===Object.prototype.toString.call(e),isFunction=e=>"[object Function]"===Object.prototype.toString.call(e),isString=e=>"[object String]"===Object.prototype.toString.call(e),isBoolean=e=>"[object Boolean]"===Object.prototype.toString.call(e),isUndefined=e=>"[object Undefined]"===Object.prototype.toString.call(e),isNull=e=>"[object Null]"===Object.prototype.toString.call(e),isNumber=e=>"[object Number]"===Object.prototype.toString.call(e),stringify=e=>JSON.stringify(e),parse=t=>{let n={};try{n=JSON.parse(t)}catch(s){n=t}return n},forEach=(e,t)=>{t=t||noop;isObject(e)&&(()=>{for(var n in e)t(e[n],n,e)})(),isArray(e)&&(()=>{for(var n=0,s=e.length;n<s;n++)t(e[n],n,e)})()},isEmpty=e=>{let t=!0;return isObject(e)&&forEach(e,()=>{t=!1}),(isString(e)||isArray(e))&&(t=0===e.length),isNumber(e)&&(t=-1===e),t},rename=(e,t)=>{var n=isObject(e);n&&(e=[e]),e=parse(stringify(e));var s=function(e,n,s){delete s[n],n=t[n],s[n]=e};return forEach(e,e=>{forEach(e,(e,n,o)=>{var i=(n in t);(i?s:noop)(e,n,o)})}),isObject?e[0]:e},extend=(e,t)=>(t=isArray(t)?t:[t],forEach(t,t=>{for(let n in t){let s=t[n];isUndefined(s)||(e[n]=s)}}),e),Defer=Promise,deferred=e=>new Defer(e),templateFormat=(e,t,n)=>{isArray(t)||(t=[t]);let s=[],o=t=>e.replace(n||/\\?\{([^}]+)\}/g,(e,n)=>"\\"===e.charAt(0)?e.slice(1):void 0===t[n]?"{"+n+"}":t[n]);for(let r=0,i=t.length;r<i;r++)s.push(o(t[r]));return s.join("")},isContain=(e,t)=>-1<e.indexOf(t),isEqual=(e,t)=>e===t,Cache$1=e=>{isObject(e)||(e={});let t=(t,n)=>{e[t]=n},n=t=>e[t],s=t=>{delete e[t]},o=()=>{let t=[];for(let n in e)t.push(n);return t},i=()=>{e={}};return{set:t,get:n,remove:s,getKeys:o,clear:i}},request=(e,t)=>deferred((n,s)=>{requestNormal(e,t,{success:n,fail:s})}),requestNormal=(e,t,n)=>{t=t||{},n=n||{success:noop,fail:noop,progress:noop};let s=new XMLHttpRequest,o=t.method||"GET";s.open(o,e,!0);let i=t.headers||{};forEach(i,(e,t)=>{s.setRequestHeader(t,e)});let r=t.body||{},a=()=>/^(200|202)$/.test(s.status),d=t.timeout;return d&&(s.timeout=d),s.onreadystatechange=function(){if(isEqual(s.readyState,4)){let{responseText:e}=s;e=e||"{}";let t=parse(e);if(a())n.success(t,s);else{let{status:e}=s,o={status:e,result:t};n.fail(o)}}},s.upload.onprogress=function(e){e.lengthComputable&&n.progress(e)},s.onerror=e=>{n.fail(e)},s.send(r),s},map=(e,t)=>e.map(t),filter=(e,t)=>e.filter(t),uniq=(e,t)=>{let n=[],s={};return e.forEach(e=>{let n=t(e);s[n.key]=n.value}),forEach(s,e=>{n.push(e)}),n},some=(e,t)=>e.some(t),toJSON=e=>JSON.stringify(e),toArray=e=>{let t=[];return forEach(e,(e,n)=>{t.push([n,e])}),t},isInclude=(e,t)=>-1<e.indexOf(t),clone$1=e=>JSON.parse(JSON.stringify(e));// 暂时支持 String
@@ -76,15 +76,15 @@ if(utils.isUndefined(R.name)){let e=UserCacher.get(A);R=utils.isEmpty(e)?{id:A}:
76
76
  utils.isEmpty(m)||Storage.setPrefix(`${d}_${m}`);let l=common.getNaviStorageKey(d,m),E=Storage.get(l);return utils.isEmpty(E)?void utils.forEach(e,t=>{let m=t.replaceAll(/http:\/\/|https:\/\/|file:\/\//g,""),{http:E}=utils.getProtocol(t);m=`${E}//${m}/navigator/general`;let u={headers:{"x-appkey":d,"x-token":p}},g=utils.requestNormal(m,u,{success:function(e,t){if(!r){let{responseURL:i}=t,a=i.replace(/(\/navigator\/general)/g,"");r=!0;let{code:p,data:m={}}=e,{servers:E,user_id:u}=m,g={servers:E,userId:u,code:p,url:a};// 默认规则:导航和 CMP 的协议必须一致
77
77
  utils.isEmpty(E)||(Storage.set(c,u),Storage.setPrefix(`${d}_${u}`),l=common.getNaviStorageKey(),Storage.set(l,g),o.info({tag:LOG_MODULE.NAV_REQEST,remote:g})),n(g),s()}},fail:function(t){a.push(t),utils.isEqual(a.length,e.length)&&n(t.result)}});i.push(g)}):(o.info({tag:LOG_MODULE.NAV_REQEST,local:E}),n(E))};var Network={detect,getNavis};function Consumer(){let e=[],t=!1,n=!1,s=(t,n)=>n?e.unshift(t):void e.push(t),o=s=>{// 如果正在执行,终止本次任务,执行任务结束后自动消费队列 ntf, 1 是首次,所以判断大于 1
78
78
  if(n)return;n=!0,t=utils.isEqual(e.length,0);let i=e.shift(),r={item:i},a=()=>{n=!1,o(s)};t?n=!1:s(r,a)};return{consume:o,produce:s}}function MessageSyncer(e,t,n,{logger:s}){let o=Consumer(),i=i=>{function r(s,o){let{msg:i}=s,r=common.updateSyncTime({...i,io:n});if(r){let{msgIndex:n,ackIndex:s}=i,o={msgIndex:n,ackIndex:s};e(SIGNAL_CMD.PUBLISH_ACK,o),t.emit(SIGNAL_NAME.CMD_RECEIVED,i)}o()}function a(i,r){let{user:a,msg:d,name:p,$message:c}=i,m=Storage.get(STORAGE.SYNC_RECEIVED_MSG_TIME).time||1700927161470,l=Storage.get(STORAGE.SYNC_SENT_MSG_TIME).time||1700927161470;// 如果本地记录时间戳大于 ntf 中的接收时间,认为消息已被当前端接收过,不再执行拉取动作
79
- if(m>=d.receiveTime)return s.info({tag:LOG_MODULE.MSG_SYNC,syncReceiveTime:m,msg:d}),r();let E={userId:a.id,syncTime:m,containsSendBox:!0,sendBoxSyncTime:l,topic:COMMAND_TOPICS.SYNC_MESSAGES};e(SIGNAL_CMD.QUERY,E,({isFinished:e,messages:a,code:p})=>{if(s.info({tag:LOG_MODULE.MSG_SYNC,data:E,msg:d,code:p,count:a.length}),!utils.isEqual(p,ErrorType.COMMAND_SUCCESS.code))return r();let m=[];utils.forEach(a,(e,t)=>{let{flags:n,sentTime:s,isSender:o}=e,i=common.formatter.toMsg(n);i.isStorage&&m.push(e)}),c.insertBatchMsgs({msgs:utils.clone(m)}).then(()=>{utils.forEach(a,(s,o)=>{let{sentTime:i,isSender:r}=s,d=common.updateSyncTime({sentTime:i,isSender:r,io:n});if(d){let n=e&&utils.isEqual(a.length-1,o);t.emit(SIGNAL_NAME.CMD_RECEIVED,[s,n])}});let s=!e;s&&o.produce(i,s),r()})})}function d(n,i){let{user:r,name:a,time:d,$conversation:p}=n,c=Storage.get(STORAGE.SYNC_CONVERSATION_TIME).time||0;if(c>d)return s.info({tag:LOG_MODULE.CONV_SYNC,syncTime:c,time:d}),i();let m={userId:r.id,syncTime:c,topic:COMMAND_TOPICS.SYNC_CONVERSATIONS,count:200};e(SIGNAL_CMD.QUERY,m,e=>{let{isFinished:r,conversations:a,code:d}=e;if(s.info({tag:LOG_MODULE.CONV_SYNC,data:m,code:d,count:a.length}),!utils.isEqual(d,ErrorType.COMMAND_SUCCESS.code))return t.emit(SIGNAL_NAME.CMD_SYNC_CONVERSATION_FINISHED,{}),i();let l=a.length,E=a[l-1]||{syncTime:0},{syncTime:u}=E;u>c&&(Storage.set(STORAGE.SYNC_CONVERSATION_TIME,{time:u}),n=utils.extend(n,{time:u})),a=utils.clone(a),p._batchInsertConversations({conversations:a,syncTime:u}).then(e=>{t.emit(SIGNAL_NAME.CMD_SYNC_CONVERSATIONS_PROGRESS,e);let s=!r;s?o.produce(n,s):t.emit(SIGNAL_NAME.CMD_SYNC_CONVERSATION_FINISHED,{}),i()})})}o.produce(i),o.consume(({item:e},t)=>{let{name:n}=e;utils.isEqual(n,SIGNAL_NAME.CMD_RECEIVED)&&r(e,t),utils.isEqual(n,SIGNAL_NAME.S_SYNC_CONVERSATION_NTF)&&d(e,t),utils.isEqual(n,SIGNAL_NAME.S_NTF)&&a(e,t)})};return{exec:i}}let chatroomCacher=Cache();var chatroomCacher$1={set:(e,t)=>{let n=chatroomCacher.get(e),{msgs:s=[]}=t;200<=s.length&&(s.shift(0),t=utils.extend(t,{msgs:s})),n=utils.extend(n,t),chatroomCacher.set(e,n)},get:e=>{let t=chatroomCacher.get(e);return t},remove:e=>{chatroomCacher.remove(e)},getAll:()=>chatroomCacher.getAll()};function ChatroomSyncer(e,t,n,{logger:s}){let o=Consumer(),i=n=>{function i(e,t){s.info({tag:LOG_MODULE.MSG_SYNC,...e});let{msg:n}=e,o=chatroomCacher$1.get(n.targetId),{isJoined:i}=o;utils.isEqual(n.type,NOTIFY_TYPE.CHATROOM)&&i&&a(e,t),utils.isEqual(n.type,NOTIFY_TYPE.CHATROOM_DESTORY)&&i&&r(e,t)}function r(e,n){let{msg:s}=e,o=s.targetId;t.emit(SIGNAL_NAME.CMD_CHATROOM_DESTROY,{id:o}),n()}function a(n,o){let{msg:i}=n,r=i.targetId,a=d(r);if(a>=i.receiveTime&&0<i.receiveTime)return s.info({tag:LOG_MODULE.MSG_SYNC,syncTime:a,msg:i}),o();let c={syncTime:a,chatroomId:r,topic:COMMAND_TOPICS.SYNC_CHATROOM_MESSAGES};e(SIGNAL_CMD.QUERY,c,({messages:e,code:n})=>{if(s.info({tag:LOG_MODULE.MSG_SYNC,data:c,msg:i,code:n,count:e.length}),!utils.isEqual(n,ErrorType.COMMAND_SUCCESS.code))return o();let{msgs:a=[]}=chatroomCacher$1.get(r);utils.forEach(e,e=>{p(e.conversationId,e.sentTime);let{messageId:n}=e,s=utils.isInclude(a,n);s||(a.push(n),t.emit(SIGNAL_NAME.CMD_RECEIVED,[e]))}),chatroomCacher$1.set(r,{msgs:a}),o()})}function d(e){let t=chatroomCacher$1.get(e);return t.syncMsgTime||0}function p(e,t){let n=d(e);t>n&&chatroomCacher$1.set(e,{syncMsgTime:t})}o.produce(n),o.consume(({item:e},t)=>{let{name:n}=e;utils.isEqual(n,SIGNAL_NAME.S_NTF)&&i(e,t)})};return{exec:i}}function ChatroomAttSyncer(e,t,n,{logger:s}){let o=Consumer(),i=n=>{function i(e,t){s.info({tag:LOG_MODULE.MSG_SYNC,...e});let{msg:n}=e,o=chatroomCacher$1.get(n.targetId),{isJoined:i}=o;utils.isEqual(n.type,NOTIFY_TYPE.CHATROOM_ATTR)&&i&&r(e,t)}function r(n,o){let{msg:i}=n,r=i.targetId,p=a(r);if(p>=i.receiveTime&&0<i.receiveTime)return o();let c={syncTime:p,chatroomId:r,targetId:r,topic:COMMAND_TOPICS.SYNC_CHATROOM_ATTRS};e(SIGNAL_CMD.QUERY,c,e=>{let{code:n,attrs:r,chatroomId:a}=e;return s.info({tag:LOG_MODULE.MSG_SYNC,data:c,msg:i,code:n,count:r.length}),utils.isEqual(n,ErrorType.COMMAND_SUCCESS.code)?void(utils.forEach(r,e=>{d(a,e.updateTime)}),t.emit(SIGNAL_NAME.CMD_CHATROOM_ATTR_RECEIVED,{attrs:r,chatroomId:a}),o()):o()})}function a(e){let t=chatroomCacher$1.get(e);return t.syncAttTime||0}function d(e,t){let n=a(e);t>n&&chatroomCacher$1.set(e,{syncAttTime:t})}o.produce(n),o.consume(({item:e},t)=>{let{name:n}=e;utils.isEqual(n,SIGNAL_NAME.S_NTF)&&i(e,t)})};return{exec:i}}function TagSyncer(e,t,n,{logger:s}){let o=({$conversation:e})=>{let{id:s}=n.getCurrentUser(),o={topic:COMMAND_TOPICS.CONVERSATION_TAG_QUERY,userId:s};n.sendCommand(SIGNAL_CMD.QUERY,o,n=>{let{code:s,tags:o}=n;utils.isEqual(ErrorType.COMMAND_SUCCESS.code,s)&&(utils.map(o,e=>{let t=CONVERSATION_TAG[e.id]||{};return utils.extend(e,t),e}),e._batchInsertTags(o).then(e=>{t.emit(SIGNAL_NAME.CMD_SYNC_TAG_FINISHED,e)}))})};return{exec:o}}function Timer(e={}){let t={timeout:60000};utils.extend(t,e);let{timeout:n}=t,s=0,o=utils.noop,i=e=>{o=e,s=setInterval(()=>{o()},n)},r=()=>{clearInterval(s)},a=()=>{r(),i(o)};return{resume:i,pause:r,reset:a}}function Counter(e={}){let t={timeout:10000};utils.extend(t,e);let{timeout:n}=t,s=0,o=e=>{s=setTimeout(()=>{e(t)},n)},i=()=>{clearTimeout(s)};return{start:o,clear:i}}let VERSION="1.7.5";/*
79
+ if(m>=d.receiveTime)return s.info({tag:LOG_MODULE.MSG_SYNC,syncReceiveTime:m,msg:d}),r();let E={userId:a.id,syncTime:m,containsSendBox:!0,sendBoxSyncTime:l,topic:COMMAND_TOPICS.SYNC_MESSAGES};e(SIGNAL_CMD.QUERY,E,({isFinished:e,messages:a,code:p})=>{if(s.info({tag:LOG_MODULE.MSG_SYNC,data:E,msg:d,code:p,count:a.length}),!utils.isEqual(p,ErrorType.COMMAND_SUCCESS.code))return r();let m=[];utils.forEach(a,(e,t)=>{let{flags:n,sentTime:s,isSender:o}=e,i=common.formatter.toMsg(n);i.isStorage&&m.push(e)}),c.insertBatchMsgs({msgs:utils.clone(m)}).then(()=>{utils.forEach(a,(s,o)=>{let{sentTime:i,isSender:r}=s,d=common.updateSyncTime({sentTime:i,isSender:r,io:n});if(d){let n=e&&utils.isEqual(a.length-1,o);t.emit(SIGNAL_NAME.CMD_RECEIVED,[s,n])}});let s=!e;s&&o.produce(i,s),r()})})}function d(n,i){let{user:r,name:a,time:d,$conversation:p}=n,c=Storage.get(STORAGE.SYNC_CONVERSATION_TIME).time||0;if(c>d)return s.info({tag:LOG_MODULE.CONV_SYNC,syncTime:c,time:d}),i();let m={userId:r.id,syncTime:c,topic:COMMAND_TOPICS.SYNC_CONVERSATIONS,count:200};e(SIGNAL_CMD.QUERY,m,e=>{let{isFinished:r,conversations:a,code:d}=e;if(s.info({tag:LOG_MODULE.CONV_SYNC,data:m,code:d,count:a.length}),!utils.isEqual(d,ErrorType.COMMAND_SUCCESS.code))return t.emit(SIGNAL_NAME.CMD_SYNC_CONVERSATION_FINISHED,{}),i();let l=a.length,E=a[l-1]||{syncTime:0},{syncTime:u}=E;u>c&&(Storage.set(STORAGE.SYNC_CONVERSATION_TIME,{time:u}),n=utils.extend(n,{time:u})),a=utils.clone(a),p._batchInsertConversations({conversations:a,syncTime:u}).then(e=>{t.emit(SIGNAL_NAME.CMD_SYNC_CONVERSATIONS_PROGRESS,e);let s=!r;s?o.produce(n,s):t.emit(SIGNAL_NAME.CMD_SYNC_CONVERSATION_FINISHED,{}),i()})})}o.produce(i),o.consume(({item:e},t)=>{let{name:n}=e;utils.isEqual(n,SIGNAL_NAME.CMD_RECEIVED)&&r(e,t),utils.isEqual(n,SIGNAL_NAME.S_SYNC_CONVERSATION_NTF)&&d(e,t),utils.isEqual(n,SIGNAL_NAME.S_NTF)&&a(e,t)})};return{exec:i}}let chatroomCacher=Cache();var chatroomCacher$1={set:(e,t)=>{let n=chatroomCacher.get(e),{msgs:s=[]}=t;200<=s.length&&(s.shift(0),t=utils.extend(t,{msgs:s})),n=utils.extend(n,t),chatroomCacher.set(e,n)},get:e=>{let t=chatroomCacher.get(e);return t},remove:e=>{chatroomCacher.remove(e)},getAll:()=>chatroomCacher.getAll()};function ChatroomSyncer(e,t,n,{logger:s}){let o=Consumer(),i=n=>{function i(e,t){s.info({tag:LOG_MODULE.MSG_SYNC,...e});let{msg:n}=e,o=chatroomCacher$1.get(n.targetId),{isJoined:i}=o;utils.isEqual(n.type,NOTIFY_TYPE.CHATROOM)&&i&&a(e,t),utils.isEqual(n.type,NOTIFY_TYPE.CHATROOM_DESTORY)&&i&&r(e,t)}function r(e,n){let{msg:s}=e,o=s.targetId;t.emit(SIGNAL_NAME.CMD_CHATROOM_DESTROY,{id:o}),n()}function a(n,o){let{msg:i}=n,r=i.targetId,a=d(r);if(a>=i.receiveTime&&0<i.receiveTime)return s.info({tag:LOG_MODULE.MSG_SYNC,syncTime:a,msg:i}),o();let c={syncTime:a,chatroomId:r,topic:COMMAND_TOPICS.SYNC_CHATROOM_MESSAGES};e(SIGNAL_CMD.QUERY,c,({messages:e,code:n})=>{if(s.info({tag:LOG_MODULE.MSG_SYNC,data:c,msg:i,code:n,count:e.length}),!utils.isEqual(n,ErrorType.COMMAND_SUCCESS.code))return o();let{msgs:a=[]}=chatroomCacher$1.get(r);utils.forEach(e,e=>{p(e.conversationId,e.sentTime);let{messageId:n}=e,s=utils.isInclude(a,n);s||(a.push(n),t.emit(SIGNAL_NAME.CMD_RECEIVED,[e]))}),chatroomCacher$1.set(r,{msgs:a}),o()})}function d(e){let t=chatroomCacher$1.get(e);return t.syncMsgTime||0}function p(e,t){let n=d(e);t>n&&chatroomCacher$1.set(e,{syncMsgTime:t})}o.produce(n),o.consume(({item:e},t)=>{let{name:n}=e;utils.isEqual(n,SIGNAL_NAME.S_NTF)&&i(e,t)})};return{exec:i}}function ChatroomAttSyncer(e,t,n,{logger:s}){let o=Consumer(),i=n=>{function i(e,t){s.info({tag:LOG_MODULE.MSG_SYNC,...e});let{msg:n}=e,o=chatroomCacher$1.get(n.targetId),{isJoined:i}=o;utils.isEqual(n.type,NOTIFY_TYPE.CHATROOM_ATTR)&&i&&r(e,t)}function r(n,o){let{msg:i}=n,r=i.targetId,p=a(r);if(p>=i.receiveTime&&0<i.receiveTime)return o();let c={syncTime:p,chatroomId:r,targetId:r,topic:COMMAND_TOPICS.SYNC_CHATROOM_ATTRS};e(SIGNAL_CMD.QUERY,c,e=>{let{code:n,attrs:r,chatroomId:a}=e;return s.info({tag:LOG_MODULE.MSG_SYNC,data:c,msg:i,code:n,count:r.length}),utils.isEqual(n,ErrorType.COMMAND_SUCCESS.code)?void(utils.forEach(r,e=>{d(a,e.updateTime)}),t.emit(SIGNAL_NAME.CMD_CHATROOM_ATTR_RECEIVED,{attrs:r,chatroomId:a}),o()):o()})}function a(e){let t=chatroomCacher$1.get(e);return t.syncAttTime||0}function d(e,t){let n=a(e);t>n&&chatroomCacher$1.set(e,{syncAttTime:t})}o.produce(n),o.consume(({item:e},t)=>{let{name:n}=e;utils.isEqual(n,SIGNAL_NAME.S_NTF)&&i(e,t)})};return{exec:i}}function TagSyncer(e,t,n,{logger:s}){let o=({$conversation:e})=>{let{id:s}=n.getCurrentUser(),o={topic:COMMAND_TOPICS.CONVERSATION_TAG_QUERY,userId:s};n.sendCommand(SIGNAL_CMD.QUERY,o,n=>{let{code:s,tags:o}=n;utils.isEqual(ErrorType.COMMAND_SUCCESS.code,s)&&(utils.map(o,e=>{let t=CONVERSATION_TAG[e.id]||{};return utils.extend(e,t),e}),e._batchInsertTags(o).then(e=>{t.emit(SIGNAL_NAME.CMD_SYNC_TAG_FINISHED,e)}))})};return{exec:o}}function Timer(e={}){let t={timeout:60000};utils.extend(t,e);let{timeout:n}=t,s=0,o=utils.noop,i=e=>{o=e,s=setInterval(()=>{o()},n)},r=()=>{clearInterval(s)},a=()=>{r(),i(o)};return{resume:i,pause:r,reset:a}}function Counter(e={}){let t={timeout:10000};utils.extend(t,e);let{timeout:n}=t,s=0,o=e=>{s=setTimeout(()=>{e(t)},n)},i=()=>{clearTimeout(s)};return{start:o,clear:i}}let VERSION="1.7.11";/*
80
80
  fileCompressLimit: 图片缩略图压缩限制,小于设置数值将不执行压缩,单位 KB
81
81
  config = { appkey, nav, isSync, upload, uploadType, fileCompressLimit }
82
- */function IO(e){function t(){m&&k.exec({msg:{type:NOTIFY_TYPE.MSG},name:SIGNAL_NAME.S_NTF,$message:e.$message,user:{id:R.id}})}function n(){return R}function s(){return e}function o(t){utils.extend(e,t)}function i(e,t){let n={topic:COMMAND_TOPICS.GET_USER_INFO,userId:e.id};G(SIGNAL_CMD.QUERY,n,e=>{t(e)})}let r=Emitter(),{appkey:a,navList:d,serverList:c=[],isSync:m=!0,reconnectCount:l=100,logger:p}=e;utils.isArray(d)||(d=["https://nav.fake.com"]);let E={},u={},g=Cache(),y=Decoder(g,u),T=Encoder(g),_=Timer({timeout:HEART_TIMEOUT}),C=Timer({timeout:SYNC_MESSAGE_TIME}),f=CONNECT_STATE.DISCONNECTED,S=[ErrorType.CONNECT_APPKEY_IS_REQUIRE.code,ErrorType.CONNECT_TOKEN_NOT_EXISTS.code,ErrorType.CONNECT_APPKEY_NOT_EXISTS.code,ErrorType.CONNECT_TOKEN_ILLEGAL.code,ErrorType.CONNECT_TOKEN_UNAUTHORIZED.code,ErrorType.CONNECT_TOKEN_EXPIRE.code,ErrorType.CONNECT_APP_BLOCKED.code,ErrorType.CONNECT_USER_BLOCKED.code,ErrorType.CONNECT_USER_KICKED.code,ErrorType.CONNECT_USER_LOGOUT.code],O=e=>{f=e.state,r.emit(SIGNAL_NAME.CONN_CHANGED,{...e})},I=()=>{_.pause(),C.pause()},A=!1,N=(e={})=>{let{code:t}=e;if(!A&&!utils.isInclude(S,t)&&!utils.isEqual(f,CONNECT_STATE.DISCONNECTED)){let e=n();return I(),D(e,({next:e})=>{e()})}if(!utils.isEqual(f,CONNECT_STATE.DISCONNECTED)){let t=n();O({state:CONNECT_STATE.DISCONNECTED,...e,user:t}),I()}},R={},M=e=>{utils.extend(R,e)},v=e=>{let t=common.getNaviStorageKey(a,e);Storage.remove(t)},h=({token:e,deviceId:t,_isReconnect:n=!1},s)=>{function o({servers:n,userId:o}){M({id:o,token:e,deviceId:t}),g.set(SIGNAL_NAME.S_CONNECT_ACK,s),Network.detect(n,(n,i)=>{// 如果嗅探失败,返回连接断开,同时清理已缓存的 CMP 地址
83
- if(i)return v(o),D({token:e,userId:o,deviceId:t},s);n=n.replaceAll(/http:\/\/|https:\/\/|file:\/\/|wss:\/\/|ws:\/\//g,"");let{ws:r}=utils.getProtocol(),d=`${r}//${n}/im`;E=new WebSocket(d),p.info({tag:LOG_MODULE.WS_CONNECT}),E.onopen=function(){let n=PLATFORM.WEB;common.isDesktop()&&(n=PLATFORM.DESKTOP);let s=common.getClientSession();G(SIGNAL_CMD.CONNECT,{appkey:a,token:e,deviceId:t,platform:n,clientSession:s,sdkVerion:VERSION})},E.onclose=t=>{N({type:DISCONNECT_TYPE.CLOSE})},E.onerror=()=>{N({type:DISCONNECT_TYPE.ERROR})},E.onmessage=function({data:e}){let t=new FileReader;t.onload=function(){P(this.result)},t.readAsArrayBuffer(e)}})}g.set(STORAGE.CRYPTO_RANDOM,utils.getRandoms(8));let i=n?CONNECT_STATE.RECONNECTING:CONNECT_STATE.CONNECTING;return O({state:i}),utils.isEmpty(c)?Network.getNavis(d,{appkey:a,token:e,logger:p},e=>{let{code:t,servers:n,userId:i}=e;if(!utils.isEqual(t,ErrorType.COMMAND_SUCCESS.code)){let e=common.getError(t);return v(i),t||(e=ErrorType.IM_SERVER_CONNECT_ERROR),O({state:CONNECT_STATE.DISCONNECTED,code:e.code}),s({error:e})}o({servers:n,userId:i})}):o({servers:c})},D=({token:e,userId:t,deviceId:n},s)=>{p.info({tag:LOG_MODULE.CON_RECONNECT,userId:t,deviceId:n});let o=g.get(CONNECT_TOOL.RECONNECT_COUNT),i=o.count||1,a=i>l;if(a)return g.remove(CONNECT_TOOL.RECONNECT_COUNT),g.remove(CONNECT_TOOL.RECONNECT_FREQUENCY),O({state:CONNECT_STATE.DISCONNECTED,code:ErrorType.IM_SERVER_CONNECT_ERROR.code});let d=g.get(CONNECT_TOOL.RECONNECT_FREQUENCY),c=d.frequency||1,m=1e3*c;setTimeout(()=>{i+=1,g.set(CONNECT_TOOL.RECONNECT_COUNT,{count:i}),c*=2,g.set(CONNECT_TOOL.RECONNECT_FREQUENCY,{frequency:c}),h({token:e,userId:t,deviceId:n,_isReconnect:!0},e=>{let{error:t}=e;utils.isEqual(t.code,ErrorType.COMMAND_SUCCESS.code)&&r.emit(SIGNAL_NAME.CMD_CHATROOM_REJOIN,{}),s(e)})},m)},U=[],x=()=>{E&&E.close&&E.close(),_.pause(),C.pause(),U.length=0},b=()=>{A=!0,x()},G=(e,t,n)=>{n=n||utils.noop;let s=common.getNum();utils.isEqual(e,SIGNAL_CMD.CONNECT)&&(s=CONNECT_ACK_INDEX),utils.isEqual(e,SIGNAL_CMD.PING)&&(s=PONG_INDEX);let o=Counter({cmd:e}),i=T.encode(e,{callback:n,data:t,index:s,counter:o});E.send(i);let r=utils.clone(t);delete r.messages,p.info({tag:LOG_MODULE.WS_SEND,cmd:e,...r}),utils.isEqual(SIGNAL_CMD.PUBLISH_ACK,e)||o.start(({cmd:e})=>utils.isEqual(e,SIGNAL_CMD.PING)&&3>U.length?U.push({cmd:e}):void(n(ErrorType.COMMAND_FAILED),x()))},k=MessageSyncer(G,r,u,{logger:p}),L=ChatroomSyncer(G,r,u,{logger:p}),q=ChatroomAttSyncer(G,r,u,{logger:p}),V=TagSyncer(G,r,u,{logger:p}),P=n=>{let{cmd:s,result:o,name:d}=y.decode(n);p.info({tag:LOG_MODULE.WS_RECEIVE,cmd:s,code:o.code});let{index:c}=o,{callback:m,data:l,counter:E}=g.get(c);// 清空计时器,与 counter.start 对应
84
- if(E&&(E.clear(),U.length=0),utils.isEqual(d,SIGNAL_NAME.S_CHATROOM_USER_NTF)){let{chatroomId:e,time:t,type:n}=o;r.emit(SIGNAL_NAME.CMD_CHATROOM_EVENT,{chatroomId:e,time:t,type:n})}if(utils.isEqual(d,SIGNAL_NAME.CMD_RECEIVED)&&(k.exec({msg:o,name:d,$message:e.$message,user:{id:R.id}}),C.reset()),utils.isEqual(d,SIGNAL_NAME.S_NTF)){let{type:t}=o,n={msg:o,name:d,$message:e.$message,user:{id:R.id}};utils.isEqual(t,NOTIFY_TYPE.MSG)&&k.exec(n),(utils.isEqual(t,NOTIFY_TYPE.CHATROOM)||utils.isEqual(t,NOTIFY_TYPE.CHATROOM_DESTORY))&&L.exec(n),utils.isEqual(t,NOTIFY_TYPE.CHATROOM_ATTR)&&q.exec(n),C.reset()}if(utils.isEqual(s,SIGNAL_CMD.PUBLISH_ACK)){utils.extend(l,o);let{conversationType:e}=l;// 单群聊和聊天室通知和拉取消息时间戳分开计算,只有发送单群聊消息更新发件箱
85
- utils.isEqual(e,CONVERATION_TYPE.CHATROOM)||common.updateSyncTime({...l,io:u}),m(l)}if(utils.isEqual(s,SIGNAL_CMD.QUERY_ACK)&&m(o),utils.isEqual(s,SIGNAL_CMD.CONNECT_ACK)){A=!1;let n=g.get(SIGNAL_NAME.S_CONNECT_ACK)||utils.noop,{ack:{code:s,userId:r}}=o,d=CONNECT_STATE.CONNECT_FAILED,c=common.getError(s);if(utils.isEqual(s,ErrorType.CONNECT_SUCCESS.code))return d=CONNECT_STATE.CONNECTED,M({id:r}),Storage.setPrefix(`${a}_${r}`),g.remove(CONNECT_TOOL.RECONNECT_FREQUENCY),i({id:r},({user:s})=>{s=s||{};let o=s.nickname,i=s.userPortrait,m=utils.toObject(s.extFields);// 同步会话和同步消息顺序不能调整,保证先同步会话再同步消息,规避会话列表最后一条消息不是最新的
86
- if(M({name:o,portrait:i,exts:m,updatedTime:s.updatedTime}),n({user:R,error:c,next:()=>{O({state:d,user:R})}}),e.isPC){let n=()=>{k.exec({time:Storage.get(STORAGE.SYNC_CONVERSATION_TIME).time||0,name:SIGNAL_NAME.S_SYNC_CONVERSATION_NTF,user:{id:R.id},$conversation:e.$conversation}),t(),V.exec({$conversation:e.$conversation})},s=Storage.get(STORAGE.SYNC_CONVERSATION_TIME).time||0;// PC 中先连接后打开数据库,优先将本地数据库中的同步时间更新至 LocalStorage 中,避免换 Token 不换用户 Id 重复同步会话
87
- utils.isEqual(s,0)?e.$socket.openDB({appkey:a,userId:r,token:R.token}).then(()=>{n()}):n()}else t();_.resume(()=>{G(SIGNAL_CMD.PING,{}),p.info({tag:LOG_MODULE.HB_START})}),C.resume(()=>{k.exec({msg:{type:NOTIFY_TYPE.MSG},name:SIGNAL_NAME.S_NTF,$message:e.$message,user:{id:R.id}})})});O({state:d,user:R}),n({user:R,error:c})}if(utils.isEqual(s,SIGNAL_CMD.DISCONNECT)){let{code:e,extra:t}=o;N({code:e,extra:t,type:DISCONNECT_TYPE.SERVER})}utils.isEqual(d,SIGNAL_NAME.S_PONG)&&p.info({tag:LOG_MODULE.HB_STOP}),g.remove(c)},F=()=>utils.isEqual(f,CONNECT_STATE.CONNECTED),B=()=>utils.isEqual(f,CONNECT_STATE.DISCONNECTED);return utils.extend(u,{getConfig:s,setConfig:o,connect:h,disconnect:b,sendCommand:G,isConnected:F,isNeedConnect:B,getCurrentUser:n,getVersion:()=>VERSION,sync:e=>{e=utils.isArray(e)?e:[e];let t=s();utils.forEach(e,e=>{let n={...e,$message:t.$message},{msg:{type:s}}=e;utils.isEqual(s,NOTIFY_TYPE.CHATROOM)&&L.exec(n),utils.isEqual(s,NOTIFY_TYPE.CHATROOM_ATTR)&&q.exec(n)})},...r}),u}let isGroup=e=>utils.isEqual(CONVERATION_TYPE.GROUP,e),formatMsg=({message:e,senders:t,groups:n})=>{let{content:p="{}",senderId:s,conversationType:o,conversationId:i,mentionInfo:c="{}",isRead:r,isSender:a,isUpdated:d,referMsg:m="{}",mergeMsg:l="{}",reactions:E="{}",attribute:u=""}=e;p=utils.parse(p),c=utils.parse(c);let g=utils.filter(t,e=>utils.isEqual(e.id,s))[0]||{},y={};return y=isGroup(o)?utils.filter(n,e=>utils.isEqual(e.id,i))[0]||{}:utils.filter(t,e=>utils.isEqual(e.id,i))[0]||{},e=utils.extend(e,{mergeMsg:utils.parse(l),referMsg:utils.parse(m),reactions:utils.parse(E),conversationTitle:y.name,conversationPortrait:y.portrait,conversationExts:y.exts,content:p,sender:g,mentionInfo:c,sentTime:+e.sentTime,isRead:!!r,isSender:!!a,isUpdated:!!d,attribute:u}),e},formatMsgs=({messages:e,senders:t,groups:n})=>{let s=utils.map(e,e=>{let s=formatMsg({message:e,senders:t,groups:n});return s});return s},formatConversation=({conversation:e,users:t,groups:n})=>{if(utils.isEmpty(e))return e;let{id:s,type:o,draft:i,unreadCount:r,isTop:a,undisturbType:d,sortTime:p,mentions:c,latestMessageTid:m,latestMessageId:l,latestMessageName:E,latestMessageIsSender:u,latestMessageIsUpdated:g,latestMessageSentTime:y,latestMessageSenderId:T,latestMessageContent:_,latestMessageMessageIndex:C,latestMessageIsRead:f,latestMessageIsMass:S,latestUnreadCount:O,latestReadCount:I,latestReadIndex:A,latestUnreadIndex:N,latestMentionInfo:R,unreadTag:M}=e;c=c||"{}";let v=utils.filter(t,e=>utils.isEqual(e.id,T))[0]||{id:T},h={};h=isGroup(o)?utils.filter(n,e=>utils.isEqual(e.id,s))[0]||{id:s}:utils.filter(t,e=>utils.isEqual(e.id,s))[0]||{id:s},r=0<r?r:0;let D={conversationId:s,conversationType:o,conversationPortrait:h.portrait,conversationTitle:h.name,conversationExts:h.exts,draft:i||"",isTop:!!a,undisturbType:d,latestReadIndex:+A,latestUnreadIndex:+N,latestMessage:{conversationId:s,conversationType:o,conversationPortrait:h.portrait,conversationTitle:h.name,conversationExts:h.exts,content:utils.parse(_),isRead:!!f,isSender:!!u,isUpdated:!!g,isMass:!!S,messageId:l,tid:m,mentionInfo:utils.parse(R),messageIndex:C,name:E,readCount:+(I||0),unreadCount:+(O||0),sentTime:+y,referMsg:{},sender:v},sortTime:+p||0,unreadCount:r||0,mentions:utils.parse(c),unreadTag:M||UNREAD_TAG.READ};return utils.isEmpty(l)&&(D.latestMessage={}),D},formatConversations=({conversations:e,users:t,groups:n})=>{let s=utils.map(e,e=>{let s=formatConversation({conversation:e,users:t,groups:n});return s});return s},createMentions=(e,t,n)=>{let{mentionInfo:s}=t,{senders:o=[],msgs:i=[]}=e;if(utils.isEqual(t.name,MESSAGE_TYPE.RECALL_INFO)){let{content:{messageId:n},sender:e}=t,s=utils.find(i,e=>utils.isEqual(e.messageId,n));-1<s&&i.splice(s,1);// 如果没有消息撤回发送人的消息,移除 senders 中的发送人信息
82
+ */function IO(e){function t(){m&&L.exec({msg:{type:NOTIFY_TYPE.MSG},name:SIGNAL_NAME.S_NTF,$message:e.$message,user:{id:M.id}})}function n(){return M}function s(){return e}function o(t){utils.extend(e,t)}function i(e,t){let n={topic:COMMAND_TOPICS.GET_USER_INFO,userId:e.id};k(SIGNAL_CMD.QUERY,n,e=>{t(e)})}let r=Emitter(),{appkey:a,navList:d,serverList:c=[],isSync:m=!0,reconnectCount:l=100,logger:p}=e;utils.isArray(d)||(d=["https://nav.fake.com"]);let E={},u={},g=Cache(),y=Decoder(g,u),T=Encoder(g),_=Timer({timeout:HEART_TIMEOUT}),C=Timer({timeout:SYNC_MESSAGE_TIME}),f=!0,S=CONNECT_STATE.DISCONNECTED,O=[ErrorType.CONNECT_APPKEY_IS_REQUIRE.code,ErrorType.CONNECT_TOKEN_NOT_EXISTS.code,ErrorType.CONNECT_APPKEY_NOT_EXISTS.code,ErrorType.CONNECT_TOKEN_ILLEGAL.code,ErrorType.CONNECT_TOKEN_UNAUTHORIZED.code,ErrorType.CONNECT_TOKEN_EXPIRE.code,ErrorType.CONNECT_APP_BLOCKED.code,ErrorType.CONNECT_USER_BLOCKED.code,ErrorType.CONNECT_USER_KICKED.code,ErrorType.CONNECT_USER_LOGOUT.code],I=e=>{S=e.state,r.emit(SIGNAL_NAME.CONN_CHANGED,{...e})},A=()=>{_.pause(),C.pause()},N=!1,R=(e={})=>{let{code:t}=e;if(!N&&!utils.isInclude(O,t)&&!utils.isEqual(S,CONNECT_STATE.DISCONNECTED)){let e=n();return A(),U(e,({next:e})=>{e()})}if(!utils.isEqual(S,CONNECT_STATE.DISCONNECTED)){let t=n();I({state:CONNECT_STATE.DISCONNECTED,...e,user:t}),A()}},M={},v=e=>{utils.extend(M,e)},h=e=>{let t=common.getNaviStorageKey(a,e);Storage.remove(t)},D=({token:e,deviceId:t,_isReconnect:n=!1},s)=>{function o({servers:n,userId:o}){v({id:o,token:e,deviceId:t}),g.set(SIGNAL_NAME.S_CONNECT_ACK,s),Network.detect(n,(n,i)=>{// 如果嗅探失败,返回连接断开,同时清理已缓存的 CMP 地址
83
+ if(i)return h(o),U({token:e,userId:o,deviceId:t},s);n=n.replaceAll(/http:\/\/|https:\/\/|file:\/\/|wss:\/\/|ws:\/\//g,"");let{ws:r}=utils.getProtocol(),d=`${r}//${n}/im`;E=new WebSocket(d),p.info({tag:LOG_MODULE.WS_CONNECT}),E.onopen=function(){let n=PLATFORM.WEB;common.isDesktop()&&(n=PLATFORM.DESKTOP);let s=common.getClientSession();k(SIGNAL_CMD.CONNECT,{appkey:a,token:e,deviceId:t,platform:n,clientSession:s,sdkVerion:VERSION})},E.onclose=t=>{R({type:DISCONNECT_TYPE.CLOSE})},E.onerror=()=>{R({type:DISCONNECT_TYPE.ERROR})},E.onmessage=function({data:e}){let t=new FileReader;t.onload=function(){F(this.result)},t.readAsArrayBuffer(e)}})}g.set(STORAGE.CRYPTO_RANDOM,utils.getRandoms(8));let i=n?CONNECT_STATE.RECONNECTING:CONNECT_STATE.CONNECTING;return I({state:i}),utils.isEmpty(c)?Network.getNavis(d,{appkey:a,token:e,logger:p},e=>{let{code:t,servers:n,userId:i}=e;if(!utils.isEqual(t,ErrorType.COMMAND_SUCCESS.code)){let e=common.getError(t);return h(i),t||(e=ErrorType.IM_SERVER_CONNECT_ERROR),I({state:CONNECT_STATE.DISCONNECTED,code:e.code}),s({error:e})}o({servers:n,userId:i})}):o({servers:c})},U=({token:e,userId:t,deviceId:n},s)=>{p.info({tag:LOG_MODULE.CON_RECONNECT,userId:t,deviceId:n});let o=g.get(CONNECT_TOOL.RECONNECT_COUNT),i=o.count||1,a=i>l;if(a)return g.remove(CONNECT_TOOL.RECONNECT_COUNT),g.remove(CONNECT_TOOL.RECONNECT_FREQUENCY),I({state:CONNECT_STATE.DISCONNECTED,code:ErrorType.IM_SERVER_CONNECT_ERROR.code});let d=g.get(CONNECT_TOOL.RECONNECT_FREQUENCY),c=d.frequency||1,m=1e3*c;setTimeout(()=>{i+=1,g.set(CONNECT_TOOL.RECONNECT_COUNT,{count:i}),c*=2,g.set(CONNECT_TOOL.RECONNECT_FREQUENCY,{frequency:c}),D({token:e,userId:t,deviceId:n,_isReconnect:!0},e=>{let{error:t}=e;utils.isEqual(t.code,ErrorType.COMMAND_SUCCESS.code)&&r.emit(SIGNAL_NAME.CMD_CHATROOM_REJOIN,{}),s(e)})},m)},x=[],b=()=>{E&&E.close&&E.close(),_.pause(),C.pause(),x.length=0},G=()=>{N=!0,b()},k=(e,t,n)=>{n=n||utils.noop;let s=common.getNum();utils.isEqual(e,SIGNAL_CMD.CONNECT)&&(s=CONNECT_ACK_INDEX),utils.isEqual(e,SIGNAL_CMD.PING)&&(s=PONG_INDEX);let o=Counter({cmd:e}),i=T.encode(e,{callback:n,data:t,index:s,counter:o});E.send(i);let r=utils.clone(t);delete r.messages,p.info({tag:LOG_MODULE.WS_SEND,cmd:e,...r}),utils.isEqual(SIGNAL_CMD.PUBLISH_ACK,e)||o.start(({cmd:e})=>utils.isEqual(e,SIGNAL_CMD.PING)&&3>x.length?x.push({cmd:e}):void(n(ErrorType.COMMAND_FAILED),b()))},L=MessageSyncer(k,r,u,{logger:p}),q=ChatroomSyncer(k,r,u,{logger:p}),V=ChatroomAttSyncer(k,r,u,{logger:p}),P=TagSyncer(k,r,u,{logger:p}),F=n=>{let{cmd:s,result:o,name:d}=y.decode(n);p.info({tag:LOG_MODULE.WS_RECEIVE,cmd:s,code:o.code});let{index:c}=o,{callback:m,data:l,counter:E}=g.get(c);// 清空计时器,与 counter.start 对应
84
+ if(E&&(E.clear(),x.length=0),utils.isEqual(d,SIGNAL_NAME.S_CHATROOM_USER_NTF)){let{chatroomId:e,time:t,type:n}=o;r.emit(SIGNAL_NAME.CMD_CHATROOM_EVENT,{chatroomId:e,time:t,type:n})}if(utils.isEqual(d,SIGNAL_NAME.CMD_RECEIVED)&&(L.exec({msg:o,name:d,$message:e.$message,user:{id:M.id}}),C.reset()),utils.isEqual(d,SIGNAL_NAME.S_NTF)){let{type:t}=o,n={msg:o,name:d,$message:e.$message,user:{id:M.id}};utils.isEqual(t,NOTIFY_TYPE.MSG)&&L.exec(n),(utils.isEqual(t,NOTIFY_TYPE.CHATROOM)||utils.isEqual(t,NOTIFY_TYPE.CHATROOM_DESTORY))&&q.exec(n),utils.isEqual(t,NOTIFY_TYPE.CHATROOM_ATTR)&&V.exec(n),C.reset()}if(utils.isEqual(s,SIGNAL_CMD.PUBLISH_ACK)){utils.extend(l,o);let{conversationType:e}=l;// 单群聊和聊天室通知和拉取消息时间戳分开计算,只有发送单群聊消息更新发件箱
85
+ utils.isEqual(e,CONVERATION_TYPE.CHATROOM)||common.updateSyncTime({...l,io:u}),m(l)}if(utils.isEqual(s,SIGNAL_CMD.QUERY_ACK)&&m(o),utils.isEqual(s,SIGNAL_CMD.CONNECT_ACK)){N=!1;let n=g.get(SIGNAL_NAME.S_CONNECT_ACK)||utils.noop,{ack:{code:s,userId:r,timestamp:d}}=o,c=CONNECT_STATE.CONNECT_FAILED,m=common.getError(s);if(utils.isEqual(s,ErrorType.CONNECT_SUCCESS.code))return f&&!e.isPC&&(common.updateSyncTime({sentTime:d,isSender:!0,io:u}),common.updateSyncTime({sentTime:d,isSender:!1,io:u})),f=!1,c=CONNECT_STATE.CONNECTED,v({id:r}),Storage.setPrefix(`${a}_${r}`),g.remove(CONNECT_TOOL.RECONNECT_FREQUENCY),i({id:r},({user:s})=>{s=s||{};let o=s.nickname,i=s.userPortrait,d=utils.toObject(s.extFields);// 同步会话和同步消息顺序不能调整,保证先同步会话再同步消息,规避会话列表最后一条消息不是最新的
86
+ if(v({name:o,portrait:i,exts:d,updatedTime:s.updatedTime}),n({user:M,error:m,next:()=>{I({state:c,user:M})}}),e.isPC){let n=()=>{L.exec({time:Storage.get(STORAGE.SYNC_CONVERSATION_TIME).time||0,name:SIGNAL_NAME.S_SYNC_CONVERSATION_NTF,user:{id:M.id},$conversation:e.$conversation}),t(),P.exec({$conversation:e.$conversation})},s=Storage.get(STORAGE.SYNC_CONVERSATION_TIME).time||0;// PC 中先连接后打开数据库,优先将本地数据库中的同步时间更新至 LocalStorage 中,避免换 Token 不换用户 Id 重复同步会话
87
+ utils.isEqual(s,0)?e.$socket.openDB({appkey:a,userId:r,token:M.token}).then(()=>{n()}):n()}else t();_.resume(()=>{k(SIGNAL_CMD.PING,{}),p.info({tag:LOG_MODULE.HB_START})}),C.resume(()=>{L.exec({msg:{type:NOTIFY_TYPE.MSG},name:SIGNAL_NAME.S_NTF,$message:e.$message,user:{id:M.id}})})});I({state:c,user:M}),n({user:M,error:m})}if(utils.isEqual(s,SIGNAL_CMD.DISCONNECT)){let{code:e,extra:t}=o;R({code:e,extra:t,type:DISCONNECT_TYPE.SERVER})}utils.isEqual(d,SIGNAL_NAME.S_PONG)&&p.info({tag:LOG_MODULE.HB_STOP}),g.remove(c)},B=()=>utils.isEqual(S,CONNECT_STATE.CONNECTED),j=()=>utils.isEqual(S,CONNECT_STATE.DISCONNECTED);return utils.extend(u,{getConfig:s,setConfig:o,connect:D,disconnect:G,sendCommand:k,isConnected:B,isNeedConnect:j,getCurrentUser:n,getVersion:()=>VERSION,sync:e=>{e=utils.isArray(e)?e:[e];let t=s();utils.forEach(e,e=>{let n={...e,$message:t.$message},{msg:{type:s}}=e;utils.isEqual(s,NOTIFY_TYPE.CHATROOM)&&q.exec(n),utils.isEqual(s,NOTIFY_TYPE.CHATROOM_ATTR)&&V.exec(n)})},...r}),u}let isGroup=e=>utils.isEqual(CONVERATION_TYPE.GROUP,e),formatMsg=({message:e,senders:t,groups:n})=>{let{content:p="{}",senderId:s,conversationType:o,conversationId:i,mentionInfo:c="{}",isRead:r,isSender:a,isUpdated:d,referMsg:m="{}",mergeMsg:l="{}",reactions:E="{}",attribute:u=""}=e;p=utils.parse(p),c=utils.parse(c);let g=utils.filter(t,e=>utils.isEqual(e.id,s))[0]||{},y={};return y=isGroup(o)?utils.filter(n,e=>utils.isEqual(e.id,i))[0]||{}:utils.filter(t,e=>utils.isEqual(e.id,i))[0]||{},e=utils.extend(e,{mergeMsg:utils.parse(l),referMsg:utils.parse(m),reactions:utils.parse(E),conversationTitle:y.name,conversationPortrait:y.portrait,conversationExts:y.exts,content:p,sender:g,mentionInfo:c,sentTime:+e.sentTime,isRead:!!r,isSender:!!a,isUpdated:!!d,attribute:u}),e},formatMsgs=({messages:e,senders:t,groups:n})=>{let s=utils.map(e,e=>{let s=formatMsg({message:e,senders:t,groups:n});return s});return s},formatConversation=({conversation:e,users:t,groups:n})=>{if(utils.isEmpty(e))return e;let{id:s,type:o,draft:i,unreadCount:r,isTop:a,undisturbType:d,sortTime:p,mentions:c,latestMessageTid:m,latestMessageId:l,latestMessageName:E,latestMessageIsSender:u,latestMessageIsUpdated:g,latestMessageSentTime:y,latestMessageSenderId:T,latestMessageContent:_,latestMessageMessageIndex:C,latestMessageIsRead:f,latestMessageIsMass:S,latestUnreadCount:O,latestReadCount:I,latestReadIndex:A,latestUnreadIndex:N,latestMentionInfo:R,unreadTag:M}=e;c=c||"{}";let v=utils.filter(t,e=>utils.isEqual(e.id,T))[0]||{id:T},h={};h=isGroup(o)?utils.filter(n,e=>utils.isEqual(e.id,s))[0]||{id:s}:utils.filter(t,e=>utils.isEqual(e.id,s))[0]||{id:s},r=0<r?r:0;let D={conversationId:s,conversationType:o,conversationPortrait:h.portrait,conversationTitle:h.name,conversationExts:h.exts,draft:i||"",isTop:!!a,undisturbType:d,latestReadIndex:+A,latestUnreadIndex:+N,latestMessage:{conversationId:s,conversationType:o,conversationPortrait:h.portrait,conversationTitle:h.name,conversationExts:h.exts,content:utils.parse(_),isRead:!!f,isSender:!!u,isUpdated:!!g,isMass:!!S,messageId:l,tid:m,mentionInfo:utils.parse(R),messageIndex:C,name:E,readCount:+(I||0),unreadCount:+(O||0),sentTime:+y,referMsg:{},sender:v},sortTime:+p||0,unreadCount:r||0,mentions:utils.parse(c),unreadTag:M||UNREAD_TAG.READ};return utils.isEmpty(l)&&(D.latestMessage={}),D},formatConversations=({conversations:e,users:t,groups:n})=>{let s=utils.map(e,e=>{let s=formatConversation({conversation:e,users:t,groups:n});return s});return s},createMentions=(e,t,n)=>{let{mentionInfo:s}=t,{senders:o=[],msgs:i=[]}=e;if(utils.isEqual(t.name,MESSAGE_TYPE.RECALL_INFO)){let{content:{messageId:n},sender:e}=t,s=utils.find(i,e=>utils.isEqual(e.messageId,n));-1<s&&i.splice(s,1);// 如果没有消息撤回发送人的消息,移除 senders 中的发送人信息
88
88
  let r=-1<utils.find(i,t=>utils.isEqual(t.senderId,e.id));if(!r){let e=utils.find(o,e=>utils.isEqual(t.sender.id,e.id));utils.isEqual(e,-1)||o.splice(e,1)}let a=i.length;return{isMentioned:0<a,senders:o,msgs:i,count:a}}if(utils.isEqual(t.name,MESSAGE_TYPE.CLIENT_REMOVE_MSGS)){let{content:{messages:n},sender:e}=t,s={};utils.forEach(n,({messageId:e})=>{let t=utils.find(i,t=>{let n=utils.isEqual(t.messageId,e);return n&&(s[t.senderId]=t.senderId),n});-1<t&&i.splice(t,1)}),utils.forEach(s,e=>{let t=-1<utils.find(i,t=>utils.isEqual(t.senderId,e));if(!t){let t=utils.find(o,t=>utils.isEqual(e,t.id));utils.isEqual(t,-1)||o.splice(t,1)}});let r=i.length;return{isMentioned:0<r,senders:o,msgs:i,count:r}}if(utils.isEmpty(s))return e;let{members:r,mentionType:a}=s,d=utils.find(r,e=>utils.isEqual(n.id,e.id));if(-1<d||utils.isEqual(a,MENTION_TYPE.ALL)){i.push({senderId:t.sender.id,messageId:t.messageId,sentTime:t.sentTime});let e=utils.find(o,e=>utils.isEqual(t.sender.id,e.id));utils.isEqual(e,-1)&&o.push(t.sender)}let p=i.length;return{isMentioned:0<p,senders:o,msgs:i,count:p}};function isNestInclude(e,t,n){let s=!1;for(var o=0;o<e.length;o++)for(var r=0;r<t.length&&(s=n(e[o],t[r]),!s);r++);return s}var tools={isGroup,formatMsg,formatMsgs,formatConversations,formatConversation,createMentions,isNestInclude};function Conversation$1(e,t){function n(t){let{conversationId:n,conversationType:o,conversationTitle:i,conversationPortrait:r,conversationExts:a,mentionInfo:d,messageId:p}=t,c={conversationId:n,conversationType:o,conversationTitle:i,conversationPortrait:r,conversationExts:a,latestMessage:t,unreadCount:0,updatedTime:0,undisturbType:t.undisturbType},m=s.getPer(t),l=m.mentions||{},E=e.getCurrentUser();if(l=tools.createMentions(l,t,E),t.isSender){let e=s.getPer(t);utils.extend(c,{conversationTitle:e.conversationTitle,conversationPortrait:e.conversationPortrait,conversationExts:e.conversationExts})}return utils.extend(c,{mentions:l}),c}/*
89
89
  let params = {
90
90
  type: UNDISTURB_TYPE.DISTURB,
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
 
2
2
  {
3
3
  "name": "jugglechat-websdk",
4
- "version": "1.7.9",
4
+ "version": "1.7.11",
5
5
  "description": "JuggleChat SDK, IM, Chat",
6
6
  "main": "index.js",
7
7
  "types": "index.d.ts",