podchat-browser 12.9.14-snapshot.9 → 12.9.14

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 (50) hide show
  1. package/changelog.md +28 -0
  2. package/dist/node/buildConfig.json +1 -1
  3. package/dist/node/call.module.js +29 -11
  4. package/dist/node/chat.js +55 -115
  5. package/dist/node/lib/app.js +6 -0
  6. package/dist/node/lib/call/deviceManager.js +43 -4
  7. package/dist/node/lib/call/multitrack/callManager.js +216 -164
  8. package/dist/node/lib/call/multitrack/callUser.js +288 -141
  9. package/dist/node/lib/call/multitrack/peerConnectionManager.js +365 -92
  10. package/dist/node/lib/call/preferredMediaDeviceManager.js +38 -0
  11. package/dist/node/lib/chat/call/inquiryCallParticipants.js +1 -2
  12. package/dist/node/lib/chat/contactsMethods.js +1 -1
  13. package/dist/node/lib/chat/reactionsMethods.js +6 -4
  14. package/dist/node/lib/chat/threadHistoryMethods.js +2 -3
  15. package/dist/node/lib/chat/threadMethods.js +32 -0
  16. package/dist/node/lib/chat/threadParticipantsMethods.js +111 -1
  17. package/dist/node/lib/constants.js +4 -1
  18. package/dist/node/lib/requestBlocker.js +1 -1
  19. package/dist/node/lib/sdkParams.js +4 -0
  20. package/dist/node/lib/social/typeCodes.js +189 -0
  21. package/dist/node/lib/store/contactsList.js +6 -6
  22. package/dist/node/lib/store/messageQueues.js +10 -4
  23. package/dist/node/lib/store/typecodes.js +4 -1
  24. package/dist/podchat-browser-bundle.js +1585 -567
  25. package/examples/index.html +54 -2
  26. package/package.json +2 -2
  27. package/src/buildConfig.json +1 -1
  28. package/src/call.module.js +33 -12
  29. package/src/chat.js +64 -121
  30. package/src/lib/app.js +7 -1
  31. package/src/lib/call/callsList.js +0 -1
  32. package/src/lib/call/deviceManager.js +36 -4
  33. package/src/lib/call/multitrack/callManager.js +94 -26
  34. package/src/lib/call/multitrack/callUser.js +311 -135
  35. package/src/lib/call/multitrack/peerConnectionManager.js +346 -58
  36. package/src/lib/call/preferredMediaDeviceManager.js +22 -0
  37. package/src/lib/call/sharedData.js +0 -1
  38. package/src/lib/chat/call/inquiryCallParticipants.js +1 -1
  39. package/src/lib/chat/contactsMethods.js +1 -1
  40. package/src/lib/chat/reactionsMethods.js +6 -4
  41. package/src/lib/chat/threadHistoryMethods.js +3 -2
  42. package/src/lib/chat/threadMethods.js +33 -0
  43. package/src/lib/chat/threadParticipantsMethods.js +120 -2
  44. package/src/lib/constants.js +4 -1
  45. package/src/lib/requestBlocker.js +1 -1
  46. package/src/lib/sdkParams.js +6 -0
  47. package/src/lib/social/typeCodes.js +211 -0
  48. package/src/lib/store/contactsList.js +6 -9
  49. package/src/lib/store/messageQueues.js +4 -4
  50. package/src/lib/store/typecodes.js +2 -1
package/changelog.md CHANGED
@@ -5,6 +5,34 @@ to see complete list of changelog please visit [ChangeLog](http://gp.fanapsoft.i
5
5
 
6
6
  ## [Unreleased]
7
7
 
8
+ ## [12.9.14] 09-09-2024
9
+
10
+ ### Added
11
+ - Possibility to remember last chosen media device on changeMediaDevice functionality in calls
12
+ - New validations to prevent fire call messages when call not exists
13
+ - Field callId to all call events
14
+ - Stream to callEvents type CALL_DIVS
15
+ - Events for already existing functionality Archive and unArchive thread
16
+ - threadId to reactionsMethods
17
+ - Method: addParticipants2 with new possibility to add user and let them see history from specific time
18
+ - Added typeCode in new, edit, delete message events
19
+ - Added event GET_CALLS_TO_JOIN
20
+ - Added parameter typeCode to method seen
21
+ - Added chatMessageTypes 17, 18, 19
22
+
23
+ ### Fixed
24
+ - Minor bug in build
25
+ - Minor bug in changeMediaDevice functionality
26
+ - UnHandeled exceptions on some call scenarios
27
+ - Improvements on janus calls
28
+ - Bug on moving to new call functionality
29
+ - Major bug fixes in multiple typeCode functionality
30
+ - REMOVE_ADMIN_ROLE result was incomplete
31
+
32
+ ### Changed
33
+ - Refactored deviceManager access from outside
34
+ - Call requests blocking timeout
35
+
8
36
  ## [12.9.13] 07-07-2024
9
37
 
10
38
  ### Added
@@ -1 +1 @@
1
- {"version":"12.9.14-snapshot.9","date":"۱۴۰۳/۵/۹","VersionInfo":"Release: false, Snapshot: true, Is For Test: true"}
1
+ {"version":"12.9.14","date":"۱۴۰۳/۶/۲۰","VersionInfo":"Release: true, Snapshot: false, Is For Test: false"}
@@ -30,6 +30,7 @@ function ChatCall(app, params) {
30
30
  var inquiryCallModule = new _inquiryCallParticipants["default"](app);
31
31
  app.call.inquiryCallParticipants = inquiryCallModule;
32
32
  var callServerController = new _callServerManager["default"](app);
33
+ if (!app.call.sharedVariables.deviceManager) app.call.sharedVariables.deviceManager = new _deviceManager.DeviceManager(app);
33
34
  var
34
35
  //Utility = params.Utility,
35
36
  currentModuleInstance = this,
@@ -911,6 +912,12 @@ function ChatCall(app, params) {
911
912
  if (app.store.messagesCallbacks[uniqueId]) {
912
913
  app.store.messagesCallbacks[uniqueId](_utility["default"].createReturnData(chatMessage.typeCode, chatMessage.ownerId, false, '', 0, messageContent, contentCount));
913
914
  }
915
+ app.chatEvents.fireEvent('callEvents', {
916
+ type: 'GET_CALLS_TO_JOIN',
917
+ callId: threadId,
918
+ uniqueId: uniqueId,
919
+ result: messageContent
920
+ });
914
921
  break;
915
922
 
916
923
  /**
@@ -1035,11 +1042,11 @@ function ChatCall(app, params) {
1035
1042
  // janus
1036
1043
  this.getDevicesList = function () {
1037
1044
  var callback = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null;
1038
- if (!app.call.currentCall()) {
1039
- raiseCallError(_errorHandler.errorList.INVALID_CALLID, callback, true);
1040
- return;
1041
- }
1042
- app.call.currentCall().deviceManager().getMediaDevices(callback);
1045
+ // if (!app.call.currentCall()) {
1046
+ // raiseCallError(errorList.INVALID_CALLID, callback, true);
1047
+ // return;
1048
+ // }
1049
+ app.call.sharedVariables.deviceManager.getMediaDevices(callback);
1043
1050
  };
1044
1051
  this.changeMediaDevice = function (params) {
1045
1052
  var call = app.call.currentCall();
@@ -1049,6 +1056,10 @@ function ChatCall(app, params) {
1049
1056
  }
1050
1057
  try {
1051
1058
  call.deviceManager().changeMediaDevice(params, function () {
1059
+ if (['videoIn', 'audioIn', 'audioOut'].includes(params.deviceType)) {
1060
+ app.preferredMediaDevices.save(params.deviceType, params.deviceId);
1061
+ }
1062
+ app.call.currentCall().sendCallDivs();
1052
1063
  app.chatEvents.fireEvent('callEvents', {
1053
1064
  type: 'MEDIA_DEVICE_CHANGED',
1054
1065
  result: params
@@ -1062,6 +1073,16 @@ function ChatCall(app, params) {
1062
1073
  }, null, true);
1063
1074
  }
1064
1075
  };
1076
+
1077
+ /**
1078
+ * @param deviceType = ['videoIn', 'audioIn', 'audioOut']
1079
+ * @param deviceId
1080
+ */
1081
+ this.setActiveDeviceInCall = function (deviceType, deviceId) {
1082
+ if (['videoIn', 'audioIn', 'audioOut'].includes(deviceType)) {
1083
+ app.preferredMediaDevices.save(deviceType, deviceId);
1084
+ }
1085
+ };
1065
1086
  this.startCall = /*#__PURE__*/function () {
1066
1087
  var _ref2 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee(params, callback) {
1067
1088
  var startCallData, content, audioObject, i, tempInvitee;
@@ -1140,7 +1161,6 @@ function ChatCall(app, params) {
1140
1161
  case 24:
1141
1162
  app.call.joinCallParams.cameraPaused = typeof params.cameraPaused === 'boolean' ? params.cameraPaused : false;
1142
1163
  callRequestController.iRequestedCall = true;
1143
- if (!app.call.sharedVariables.deviceManager) app.call.sharedVariables.deviceManager = new _deviceManager.DeviceManager(app);
1144
1164
  app.call.sharedVariables.deviceManager.grantUserMediaDevicesPermissions({
1145
1165
  video: params.type == 'video',
1146
1166
  audio: audioObject,
@@ -1178,7 +1198,7 @@ function ChatCall(app, params) {
1178
1198
  }
1179
1199
  });
1180
1200
  });
1181
- case 28:
1201
+ case 27:
1182
1202
  case "end":
1183
1203
  return _context.stop();
1184
1204
  }
@@ -1265,7 +1285,6 @@ function ChatCall(app, params) {
1265
1285
  case 22:
1266
1286
  app.call.joinCallParams.cameraPaused = typeof params.cameraPaused === 'boolean' ? params.cameraPaused : false;
1267
1287
  callRequestController.iRequestedCall = true;
1268
- if (!app.call.sharedVariables.deviceManager) app.call.sharedVariables.deviceManager = new _deviceManager.DeviceManager(app);
1269
1288
  app.call.sharedVariables.deviceManager.grantUserMediaDevicesPermissions({
1270
1289
  video: params.type == 'video',
1271
1290
  audio: !params.mute,
@@ -1302,7 +1321,7 @@ function ChatCall(app, params) {
1302
1321
  }
1303
1322
  });
1304
1323
  });
1305
- case 26:
1324
+ case 25:
1306
1325
  case "end":
1307
1326
  return _context2.stop();
1308
1327
  }
@@ -1402,7 +1421,6 @@ function ChatCall(app, params) {
1402
1421
  case 19:
1403
1422
  app.call.sharedVariables.acceptedCallId = parseInt(params.callId);
1404
1423
  callRequestController.iAcceptedCall = true;
1405
- if (!app.call.sharedVariables.deviceManager) app.call.sharedVariables.deviceManager = new _deviceManager.DeviceManager(app);
1406
1424
  app.call.sharedVariables.deviceManager.grantUserMediaDevicesPermissions({
1407
1425
  video: params.video,
1408
1426
  audio: audioObject,
@@ -1422,7 +1440,7 @@ function ChatCall(app, params) {
1422
1440
  }
1423
1441
  });
1424
1442
  });
1425
- case 23:
1443
+ case 22:
1426
1444
  case "end":
1427
1445
  return _context3.stop();
1428
1446
  }
package/dist/node/chat.js CHANGED
@@ -41,7 +41,6 @@ function Chat(params) {
41
41
  var reactionsMethods = new _reactionsMethods["default"](app);
42
42
  var contactsMethods = new _contactsMethods["default"](app);
43
43
  var threadParticipantsMethods = new _threadParticipantsMethods["default"](app);
44
- var threadMethods = new _threadMethods["default"](app);
45
44
  app.sdkParams.appId = params.appId || 'PodChat';
46
45
  app.sdkParams.token = params.token || "111";
47
46
  app.sdkParams.mapApiKey = params.mapApiKey || '8b77db18704aa646ee5aaea13e7370f4f88b9e8c';
@@ -106,6 +105,14 @@ function Chat(params) {
106
105
  }),
107
106
  asyncLogCallback = typeof params.asyncLogCallback == "function" ? params.asyncLogCallback : null,
108
107
  msgLogCallback = typeof params.msgLogCallback == "function" ? params.msgLogCallback : null;
108
+
109
+ /**
110
+ * Minimum value for messageTtl is 2000
111
+ */
112
+ if (app.sdkParams.messageTtl < 2000) {
113
+ app.sdkParams.messageTtl = 2000;
114
+ console.warn("[SDK] messageTtl can not be less than 2000, we changed it to 2000");
115
+ }
109
116
  if (!app.sdkParams.consoleLogging) {
110
117
  /**
111
118
  * Disable kurento-utils logs
@@ -613,7 +620,8 @@ function Chat(params) {
613
620
  if (app.messenger.chatState) {
614
621
  for (var key in app.sdkParams.messagesSeen) {
615
622
  seen({
616
- messageId: app.sdkParams.messagesSeen[key]
623
+ messageId: app.sdkParams.messagesSeen[key].messageId,
624
+ typeCode: app.sdkParams.messagesSeen[key].typeCode
617
625
  });
618
626
  delete app.sdkParams.messagesSeen[key];
619
627
  }
@@ -695,10 +703,10 @@ function Chat(params) {
695
703
  case _constants.chatMessageVOTypes.CREATE_THREAD:
696
704
  messageContent.uniqueId = uniqueId;
697
705
  if (app.store.messagesCallbacks[uniqueId]) {
698
- createThread(messageContent, true, true);
706
+ app.threadMethods.createThread(messageContent, true, true);
699
707
  app.store.messagesCallbacks[uniqueId](_utility["default"].createReturnData(chatMessage.typeCode, chatMessage.ownerId, false, '', 0, messageContent, contentCount));
700
708
  } else {
701
- createThread(messageContent, true, false);
709
+ app.threadMethods.createThread(messageContent, true, false);
702
710
  }
703
711
  break;
704
712
 
@@ -706,7 +714,7 @@ function Chat(params) {
706
714
  * Type 2 Message
707
715
  */
708
716
  case _constants.chatMessageVOTypes.MESSAGE:
709
- newMessageHandler(threadId, messageContent);
717
+ newMessageHandler(threadId, messageContent, chatMessage);
710
718
  break;
711
719
 
712
720
  /**
@@ -1097,7 +1105,7 @@ function Chat(params) {
1097
1105
  * Type 22 Forward Multiple Messages
1098
1106
  */
1099
1107
  case _constants.chatMessageVOTypes.FORWARD_MESSAGE:
1100
- newMessageHandler(threadId, messageContent);
1108
+ newMessageHandler(threadId, messageContent, chatMessage);
1101
1109
  break;
1102
1110
 
1103
1111
  /**
@@ -1140,7 +1148,7 @@ function Chat(params) {
1140
1148
  if (app.store.messagesCallbacks[uniqueId]) {
1141
1149
  app.store.messagesCallbacks[uniqueId](_utility["default"].createReturnData(chatMessage.typeCode, chatMessage.ownerId, false, '', 0, messageContent, contentCount));
1142
1150
  }
1143
- chatEditMessageHandler(threadId, messageContent);
1151
+ chatEditMessageHandler(threadId, messageContent, chatMessage);
1144
1152
  break;
1145
1153
 
1146
1154
  /**
@@ -1176,6 +1184,7 @@ function Chat(params) {
1176
1184
  app.chatEvents.fireEvent('messageEvents', {
1177
1185
  type: 'MESSAGE_DELETE',
1178
1186
  result: {
1187
+ typeCode: chatMessage.typeCode,
1179
1188
  message: {
1180
1189
  id: messageContent.id,
1181
1190
  pinned: messageContent.pinned,
@@ -1200,6 +1209,7 @@ function Chat(params) {
1200
1209
  app.chatEvents.fireEvent('messageEvents', {
1201
1210
  type: 'MESSAGE_DELETE',
1202
1211
  result: {
1212
+ typeCode: chatMessage.typeCode,
1203
1213
  message: {
1204
1214
  id: messageContent.id,
1205
1215
  pinned: messageContent.pinned,
@@ -1423,7 +1433,7 @@ function Chat(params) {
1423
1433
  }
1424
1434
  if (app.sdkParams.fullResponseObject) {
1425
1435
  getThreads({
1426
- threadIds: [messageContent.id]
1436
+ threadIds: [threadId]
1427
1437
  }, function (threadsResult) {
1428
1438
  var threads = threadsResult.result.threads;
1429
1439
  if (!threadsResult.cache) {
@@ -2130,6 +2140,10 @@ function Chat(params) {
2130
2140
  if (app.store.messagesCallbacks[uniqueId]) {
2131
2141
  app.store.messagesCallbacks[uniqueId](_utility["default"].createReturnData(chatMessage.typeCode, chatMessage.ownerId, false, '', 0, messageContent, contentCount, uniqueId));
2132
2142
  }
2143
+ app.chatEvents.fireEvent('threadEvents', {
2144
+ type: 'THREAD_ARCHIVE',
2145
+ result: messageContent
2146
+ });
2133
2147
  break;
2134
2148
 
2135
2149
  /**
@@ -2140,6 +2154,10 @@ function Chat(params) {
2140
2154
  if (app.store.messagesCallbacks[uniqueId]) {
2141
2155
  app.store.messagesCallbacks[uniqueId](_utility["default"].createReturnData(chatMessage.typeCode, chatMessage.ownerId, false, '', 0, messageContent, contentCount, uniqueId));
2142
2156
  }
2157
+ app.chatEvents.fireEvent('threadEvents', {
2158
+ type: 'THREAD_UNARCHIVE',
2159
+ result: messageContent
2160
+ });
2143
2161
  break;
2144
2162
 
2145
2163
  /**
@@ -2164,7 +2182,7 @@ function Chat(params) {
2164
2182
  * Type 236 GET PIN MESSAGE
2165
2183
  */
2166
2184
  case _constants.chatMessageVOTypes.GET_PIN_MESSAGE:
2167
- threadMethods.onGetPinMessages(uniqueId, messageContent, contentCount);
2185
+ app.threadMethods.onGetPinMessages(uniqueId, messageContent, contentCount);
2168
2186
  break;
2169
2187
 
2170
2188
  /**
@@ -2232,7 +2250,7 @@ function Chat(params) {
2232
2250
  * Type 245 CUSTOMIZE_REACTION
2233
2251
  */
2234
2252
  case _constants.chatMessageVOTypes.CUSTOMIZE_REACTION:
2235
- reactionsMethods.onCustomizeReaction(uniqueId, messageContent);
2253
+ reactionsMethods.onCustomizeReaction(uniqueId, threadId, messageContent);
2236
2254
  break;
2237
2255
 
2238
2256
  /**
@@ -2265,7 +2283,7 @@ function Chat(params) {
2265
2283
  * Type 252 LAST_ACTION_IN_THREAD
2266
2284
  */
2267
2285
  case _constants.chatMessageVOTypes.LAST_ACTION_IN_THREAD:
2268
- threadMethods.onGetLastActionInThread(uniqueId, messageContent, null);
2286
+ app.threadMethods.onGetLastActionInThread(uniqueId, messageContent, null);
2269
2287
  break;
2270
2288
  /**
2271
2289
  * Type 253 ADD_USER_TO_USER_GROUP
@@ -2285,7 +2303,7 @@ function Chat(params) {
2285
2303
  * Type 255 GET_THREAD_ALLOWED_REACTIONS
2286
2304
  */
2287
2305
  case _constants.chatMessageVOTypes.GET_THREAD_ALLOWED_REACTIONS:
2288
- reactionsMethods.onGetThreadAllowedReactions(uniqueId, messageContent);
2306
+ reactionsMethods.onGetThreadAllowedReactions(uniqueId, threadId, messageContent);
2289
2307
  break;
2290
2308
 
2291
2309
  /**
@@ -2418,7 +2436,7 @@ function Chat(params) {
2418
2436
  *
2419
2437
  * @return {undefined}
2420
2438
  */
2421
- newMessageHandler = function newMessageHandler(threadId, messageContent) {
2439
+ newMessageHandler = function newMessageHandler(threadId, messageContent, chatMessage) {
2422
2440
  var message = (0, _dataFormatters.formatDataToMakeMessage)(threadId, messageContent);
2423
2441
  var threadObject = message.conversation;
2424
2442
  var lastMessageVoCopy = Object.assign({}, message);
@@ -2435,6 +2453,7 @@ function Chat(params) {
2435
2453
  type: 'MESSAGE_NEW',
2436
2454
  cache: false,
2437
2455
  result: {
2456
+ typeCode: chatMessage.typeCode,
2438
2457
  message: stringMsg
2439
2458
  }
2440
2459
  });
@@ -2529,7 +2548,7 @@ function Chat(params) {
2529
2548
  *
2530
2549
  * @return {undefined}
2531
2550
  */
2532
- chatEditMessageHandler = function chatEditMessageHandler(threadId, messageContent) {
2551
+ chatEditMessageHandler = function chatEditMessageHandler(threadId, messageContent, chatMessage) {
2533
2552
  var message = (0, _dataFormatters.formatDataToMakeMessage)(threadId, messageContent);
2534
2553
  app.store.history.saveMessage(threadId, message);
2535
2554
  if (app.sdkParams.fullResponseObject) {
@@ -2541,6 +2560,7 @@ function Chat(params) {
2541
2560
  app.chatEvents.fireEvent('messageEvents', {
2542
2561
  type: 'MESSAGE_EDIT',
2543
2562
  result: {
2563
+ typeCode: chatMessage.typeCode,
2544
2564
  message: message
2545
2565
  }
2546
2566
  });
@@ -2558,6 +2578,7 @@ function Chat(params) {
2558
2578
  app.chatEvents.fireEvent('messageEvents', {
2559
2579
  type: 'MESSAGE_EDIT',
2560
2580
  result: {
2581
+ typeCode: chatMessage.typeCode,
2561
2582
  message: message
2562
2583
  }
2563
2584
  });
@@ -2571,35 +2592,6 @@ function Chat(params) {
2571
2592
  }
2572
2593
  }
2573
2594
  },
2574
- /**
2575
- * Create Thread
2576
- *
2577
- * Makes formatted Thread Object out of given contentCount,
2578
- * If Thread has been newly created, a THREAD_NEW event
2579
- * will be emitted
2580
- *
2581
- * @access private
2582
- *
2583
- * @param {object} messageContent Json object of thread taken from chat server
2584
- * @param {boolean} addFromService if this is a newly created Thread, addFromService should be True
2585
- *
2586
- * @param showThread
2587
- * @return {object} Formatted Thread Object
2588
- */
2589
- createThread = function createThread(messageContent, addFromService, showThread) {
2590
- var threadData = (0, _dataFormatters.formatDataToMakeConversation)(messageContent);
2591
- var redirectToThread = showThread === true ? showThread : false;
2592
- if (addFromService) {
2593
- app.chatEvents.fireEvent('threadEvents', {
2594
- type: 'THREAD_NEW',
2595
- redirectToThread: redirectToThread,
2596
- result: {
2597
- thread: threadData
2598
- }
2599
- });
2600
- }
2601
- return threadData;
2602
- },
2603
2595
  /**
2604
2596
  * Unset Not Seen Duration
2605
2597
  *
@@ -2751,7 +2743,7 @@ function Chat(params) {
2751
2743
  },
2752
2744
  threadData;
2753
2745
  for (var i = 0; i < messageLength; i++) {
2754
- threadData = createThread(messageContent[i], false);
2746
+ threadData = app.threadMethods.createThread(messageContent[i], false);
2755
2747
  if (threadData) {
2756
2748
  resultData.threads.push(threadData);
2757
2749
  }
@@ -3264,7 +3256,7 @@ function Chat(params) {
3264
3256
  return {
3265
3257
  uniqueId: downloadUniqueId,
3266
3258
  cancel: function cancel() {
3267
- app.httpReuqest.cancelFileDownload({
3259
+ app.httpRequest.cancelFileDownload({
3268
3260
  uniqueId: downloadUniqueId
3269
3261
  }, function () {
3270
3262
  app.sdkParams.consoleLogging && console.log("\"".concat(downloadUniqueId, "\" - File download has been canceled!"));
@@ -5523,64 +5515,8 @@ function Chat(params) {
5523
5515
  typeCode: params.typeCode
5524
5516
  }, callback);
5525
5517
  };
5526
- publicized.addParticipants = function (params, callback) {
5527
- /**
5528
- * + AddParticipantsRequest {object}
5529
- * - subjectId {int}
5530
- * + content {list} List of CONTACT IDs or inviteeVO Objects
5531
- * - uniqueId {string}
5532
- */
5533
- var sendMessageParams = {
5534
- chatMessageVOType: _constants.chatMessageVOTypes.ADD_PARTICIPANT,
5535
- typeCode: params.typeCode,
5536
- content: []
5537
- };
5538
- if (params) {
5539
- if (parseInt(params.threadId) > 0) {
5540
- sendMessageParams.subjectId = params.threadId;
5541
- }
5542
- if (Array.isArray(params.contactIds)) {
5543
- sendMessageParams.content = params.contactIds;
5544
- }
5545
- if (Array.isArray(params.usernames)) {
5546
- sendMessageParams.content = [];
5547
- for (var i = 0; i < params.usernames.length; i++) {
5548
- sendMessageParams.content.push({
5549
- id: params.usernames[i],
5550
- idType: _constants.inviteeVOidTypes.TO_BE_USER_USERNAME
5551
- });
5552
- }
5553
- }
5554
- if (Array.isArray(params.coreUserids)) {
5555
- sendMessageParams.content = [];
5556
- for (var i = 0; i < params.coreUserids.length; i++) {
5557
- sendMessageParams.content.push({
5558
- id: params.coreUserids[i],
5559
- idType: _constants.inviteeVOidTypes.TO_BE_CORE_USER_ID
5560
- });
5561
- }
5562
- }
5563
- }
5564
- return app.messenger.sendMessage(sendMessageParams, {
5565
- onResult: function onResult(result) {
5566
- var returnData = {
5567
- typeCode: result.typeCode,
5568
- ownerId: result.ownerId,
5569
- hasError: result.hasError,
5570
- cache: false,
5571
- errorMessage: result.errorMessage,
5572
- errorCode: result.errorCode
5573
- };
5574
- if (!returnData.hasError) {
5575
- var messageContent = result.result;
5576
- returnData.result = {
5577
- thread: createThread(messageContent)
5578
- };
5579
- }
5580
- callback && callback(returnData);
5581
- }
5582
- });
5583
- };
5518
+ publicized.addParticipants = threadParticipantsMethods.addParticipants;
5519
+ publicized.addParticipants2 = threadParticipantsMethods.addParticipants2;
5584
5520
  publicized.removeParticipants = function (params, callback) {
5585
5521
  /**
5586
5522
  * + RemoveParticipantsRequest {object}
@@ -5624,7 +5560,7 @@ function Chat(params) {
5624
5560
  if (!returnData.hasError) {
5625
5561
  var messageContent = result.result;
5626
5562
  returnData.result = {
5627
- thread: createThread(messageContent)
5563
+ thread: app.threadMethods.createThread(messageContent)
5628
5564
  };
5629
5565
  }
5630
5566
  callback && callback(returnData);
@@ -5670,7 +5606,7 @@ function Chat(params) {
5670
5606
  if (!returnData.hasError) {
5671
5607
  var messageContent = result.result;
5672
5608
  returnData.result = {
5673
- thread: createThread(messageContent)
5609
+ thread: app.threadMethods.createThread(messageContent)
5674
5610
  };
5675
5611
  }
5676
5612
  callback && callback(returnData);
@@ -5787,7 +5723,7 @@ function Chat(params) {
5787
5723
  if (!returnData.hasError) {
5788
5724
  var messageContent = result.result;
5789
5725
  returnData.result = {
5790
- thread: createThread(messageContent)
5726
+ thread: app.threadMethods.createThread(messageContent)
5791
5727
  };
5792
5728
  }
5793
5729
  callback && callback(returnData);
@@ -5862,7 +5798,7 @@ function Chat(params) {
5862
5798
  if (!returnData.hasError) {
5863
5799
  var messageContent = result.result;
5864
5800
  returnData.result = {
5865
- thread: createThread(messageContent)
5801
+ thread: app.threadMethods.createThread(messageContent)
5866
5802
  };
5867
5803
  }
5868
5804
  callback && callback(returnData);
@@ -6028,7 +5964,7 @@ function Chat(params) {
6028
5964
  if (!returnData.hasError) {
6029
5965
  var messageContent = result.result;
6030
5966
  returnData.result = {
6031
- thread: createThread(messageContent)
5967
+ thread: app.threadMethods.createThread(messageContent)
6032
5968
  };
6033
5969
  }
6034
5970
  createThreadCallback && createThreadCallback(returnData);
@@ -6571,7 +6507,7 @@ function Chat(params) {
6571
6507
  };
6572
6508
  publicized.deliver = deliver;
6573
6509
  publicized.seen = function (params) {
6574
- return app.messageQueues.putInMessagesSeenQueue(params.threadId, params.messageId);
6510
+ return app.messageQueues.putInMessagesSeenQueue(params.threadId, params.messageId, params.typeCode);
6575
6511
  };
6576
6512
  publicized.startTyping = function (params) {
6577
6513
  var uniqueId = _utility["default"].generateUUID();
@@ -8525,6 +8461,7 @@ function Chat(params) {
8525
8461
  // janus and kurento
8526
8462
  publicized.getDevicesList = callModule.getDevicesList; // get all devices list
8527
8463
  publicized.changeMediaDevice = callModule.changeMediaDevice; //mic camera speaker
8464
+ publicized.setActiveDeviceInCall = callModule.setActiveDeviceInCall; //mic camera speaker
8528
8465
 
8529
8466
  publicized.startCall = callModule.startCall;
8530
8467
  publicized.startGroupCall = callModule.startGroupCall;
@@ -8619,7 +8556,7 @@ function Chat(params) {
8619
8556
  },
8620
8557
  threadData;
8621
8558
  for (var i = 0; i < messageLength; i++) {
8622
- threadData = createThread(messageContent[i], false);
8559
+ threadData = app.threadMethods.createThread(messageContent[i], false);
8623
8560
  if (threadData) {
8624
8561
  resultData.threads.push(threadData);
8625
8562
  }
@@ -8864,7 +8801,7 @@ function Chat(params) {
8864
8801
  },
8865
8802
  threadData;
8866
8803
  for (var i = 0; i < messageLength; i++) {
8867
- threadData = createThread(messageContent[i], false);
8804
+ threadData = app.threadMethods.createThread(messageContent[i], false);
8868
8805
  if (threadData) {
8869
8806
  resultData.threads.push(threadData);
8870
8807
  }
@@ -8935,8 +8872,8 @@ function Chat(params) {
8935
8872
  console.error("Protocol ".concat(proto, " is not supported in SDK. Valid protocols: \"webrtc\", \"websocket\""));
8936
8873
  }
8937
8874
  };
8938
- publicized.getPinMessages = threadMethods.getPinMessages;
8939
- publicized.getLastActionInthread = threadMethods.getLastActionInthread;
8875
+ publicized.getPinMessages = app.threadMethods.getPinMessages;
8876
+ publicized.getLastActionInthread = app.threadMethods.getLastActionInthread;
8940
8877
  publicized.lastMessageInfo = function (params, callback) {
8941
8878
  var sendData = {
8942
8879
  chatMessageVOType: _constants.chatMessageVOTypes.LAST_MESSAGE_INFO,
@@ -8967,7 +8904,7 @@ function Chat(params) {
8967
8904
  subjectId: params.threadId,
8968
8905
  content: params.content
8969
8906
  };
8970
- return chatMessaging.sendMessage(sendData, {
8907
+ return app.messenger.sendMessage(sendData, {
8971
8908
  onResult: function onResult(result) {
8972
8909
  callback && callback(result);
8973
8910
  }
@@ -8981,7 +8918,7 @@ function Chat(params) {
8981
8918
  subjectId: params.threadId,
8982
8919
  content: params.content
8983
8920
  };
8984
- return chatMessaging.sendMessage(sendData, {
8921
+ return app.messenger.sendMessage(sendData, {
8985
8922
  onResult: function onResult(result) {
8986
8923
  callback && callback(result);
8987
8924
  }
@@ -8999,6 +8936,9 @@ function Chat(params) {
8999
8936
  publicized.resetVideoSendStream = callModule.resetVideoSendStream;
9000
8937
  publicized.stopPrintStatus = callModule.stopPrintStatus;
9001
8938
  publicized.startPrintStatus = callModule.startPrintStatus;
8939
+ publicized.addTypeCodeToBusiness = app.typeCodeApiMethods.addTypeCodeToBusiness;
8940
+ publicized.registerTypeCodeInChat = app.typeCodeApiMethods.registerTypeCodeInChat;
8941
+ publicized.registerTypeCodeInChat = app.typeCodeApiMethods.registerTypeCodeInChat;
9002
8942
  app.store.events.on(app.store.threads.eventsList.UNREAD_COUNT_UPDATED, function (thread) {
9003
8943
  app.chatEvents.fireEvent('threadEvents', {
9004
8944
  type: 'UNREAD_COUNT_UPDATED',
@@ -15,6 +15,9 @@ var _messageQueues = _interopRequireDefault(require("./store/messageQueues"));
15
15
  var _httpRequest = _interopRequireDefault(require("./helpers/httpRequest"));
16
16
  var _podspaceMethods = _interopRequireDefault(require("./files/podspaceMethods"));
17
17
  var _threadHistoryMethods = _interopRequireDefault(require("./chat/threadHistoryMethods"));
18
+ var _preferredMediaDeviceManager = _interopRequireDefault(require("./call/preferredMediaDeviceManager"));
19
+ var _threadMethods = _interopRequireDefault(require("./chat/threadMethods"));
20
+ var _typeCodes = _interopRequireDefault(require("../lib/social/typeCodes"));
18
21
  function App() {
19
22
  var app = {};
20
23
  app.store = new _store.Store(app);
@@ -27,6 +30,9 @@ function App() {
27
30
  app.httpRequest = new _httpRequest["default"](app);
28
31
  app.podspaceMethods = new _podspaceMethods["default"](app);
29
32
  app.threadHistory = new _threadHistoryMethods["default"](app);
33
+ app.preferredMediaDevices = new _preferredMediaDeviceManager["default"](app);
34
+ app.threadMethods = new _threadMethods["default"](app);
35
+ app.typeCodeApiMethods = new _typeCodes["default"](app);
30
36
  return app;
31
37
  }
32
38
  var _default = App;
@@ -6,6 +6,7 @@ Object.defineProperty(exports, "__esModule", {
6
6
  });
7
7
  exports.DeviceManager = DeviceManager;
8
8
  var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
9
+ var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
9
10
  var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
10
11
  var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
11
12
  require("../constants.js");
@@ -201,7 +202,7 @@ function DeviceManager(app) {
201
202
  } else {
202
203
  // List cameras and microphones.
203
204
  deviceManager.grantUserMediaDevicesPermissions({
204
- audio: config,
205
+ audio: true,
205
206
  video: false
206
207
  }, function (result) {
207
208
  if (!result.hasError) {
@@ -215,20 +216,28 @@ function DeviceManager(app) {
215
216
  };
216
217
  devices.forEach(function (device) {
217
218
  var _my_devices$kind;
218
- // if (device.deviceId !== "default") {
219
219
  var kind = device.kind,
220
220
  label = device.label,
221
221
  deviceId = device.deviceId,
222
222
  groupId = device.groupId;
223
+ var active;
224
+ if (kind == 'videoinput') {
225
+ active = deviceId == app.preferredMediaDevices.get('videoIn');
226
+ } else if (kind == 'audioinput') {
227
+ active = deviceId == app.preferredMediaDevices.get('audioIn');
228
+ } else if (kind == 'audiooutput') {
229
+ active = deviceId == app.preferredMediaDevices.get('audioOut');
230
+ }
223
231
  (_my_devices$kind = my_devices[kind]) === null || _my_devices$kind === void 0 ? void 0 : _my_devices$kind.push({
224
232
  label: label,
225
233
  deviceId: deviceId,
226
234
  groupId: groupId,
227
- "default": false
235
+ active: active
228
236
  });
229
- // }
230
237
  });
231
238
 
239
+ // deviceManager.mediaStreams.stopVideoInput();
240
+ deviceManager.mediaStreams.stopAudioInput();
232
241
  // const filteredDevices = deviceManager.removeDuplicateGroupIds(my_devices);
233
242
  callback && callback({
234
243
  hasError: false,
@@ -432,6 +441,36 @@ function DeviceManager(app) {
432
441
  _ref6$closeStream = _ref6.closeStream,
433
442
  closeStream = _ref6$closeStream === void 0 ? false : _ref6$closeStream;
434
443
  var callback = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null;
444
+ if (app.preferredMediaDevices.get('videoIn')) {
445
+ if (video) {
446
+ if ((0, _typeof2["default"])(video) == 'object') {
447
+ if (!video.deviceId) video.deviceId = {
448
+ exact: app.preferredMediaDevices.get('videoIn')
449
+ };
450
+ } else {
451
+ video = {
452
+ deviceId: {
453
+ exact: app.preferredMediaDevices.get('videoIn')
454
+ }
455
+ };
456
+ }
457
+ }
458
+ }
459
+ if (app.preferredMediaDevices.get('audioIn')) {
460
+ if (audio) {
461
+ if ((0, _typeof2["default"])(audio) == 'object') {
462
+ if (!audio.deviceId) audio.deviceId = {
463
+ exact: app.preferredMediaDevices.get('audioIn')
464
+ };
465
+ } else {
466
+ audio = {
467
+ deviceId: {
468
+ exact: app.preferredMediaDevices.get('audioIn')
469
+ }
470
+ };
471
+ }
472
+ }
473
+ }
435
474
  config.permissionRequests.push({
436
475
  video: video,
437
476
  audio: audio,