@webex/plugin-meetings 3.0.0-beta.11 → 3.0.0-beta.111

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 (512) hide show
  1. package/UPGRADING.md +9 -9
  2. package/browsers.js +19 -24
  3. package/dist/annotation/annotation.types.js +7 -0
  4. package/dist/annotation/annotation.types.js.map +1 -0
  5. package/dist/annotation/constants.js +48 -0
  6. package/dist/annotation/constants.js.map +1 -0
  7. package/dist/annotation/index.js +357 -0
  8. package/dist/annotation/index.js.map +1 -0
  9. package/dist/breakouts/breakout.js +176 -0
  10. package/dist/breakouts/breakout.js.map +1 -0
  11. package/dist/breakouts/collection.js +23 -0
  12. package/dist/breakouts/collection.js.map +1 -0
  13. package/dist/breakouts/edit-lock-error.js +52 -0
  14. package/dist/breakouts/edit-lock-error.js.map +1 -0
  15. package/dist/breakouts/events.js +43 -0
  16. package/dist/breakouts/events.js.map +1 -0
  17. package/dist/breakouts/index.js +944 -0
  18. package/dist/breakouts/index.js.map +1 -0
  19. package/dist/breakouts/request.js +78 -0
  20. package/dist/breakouts/request.js.map +1 -0
  21. package/dist/breakouts/utils.js +67 -0
  22. package/dist/breakouts/utils.js.map +1 -0
  23. package/dist/common/browser-detection.js +1 -20
  24. package/dist/common/browser-detection.js.map +1 -1
  25. package/dist/common/collection.js +5 -20
  26. package/dist/common/collection.js.map +1 -1
  27. package/dist/common/config.js +0 -7
  28. package/dist/common/config.js.map +1 -1
  29. package/dist/common/errors/captcha-error.js +5 -26
  30. package/dist/common/errors/captcha-error.js.map +1 -1
  31. package/dist/common/errors/intent-to-join.js +5 -26
  32. package/dist/common/errors/intent-to-join.js.map +1 -1
  33. package/dist/common/errors/join-meeting.js +6 -27
  34. package/dist/common/errors/join-meeting.js.map +1 -1
  35. package/dist/common/errors/media.js +5 -26
  36. package/dist/common/errors/media.js.map +1 -1
  37. package/dist/common/errors/parameter.js +5 -33
  38. package/dist/common/errors/parameter.js.map +1 -1
  39. package/dist/common/errors/password-error.js +5 -26
  40. package/dist/common/errors/password-error.js.map +1 -1
  41. package/dist/common/errors/permission.js +4 -25
  42. package/dist/common/errors/permission.js.map +1 -1
  43. package/dist/common/errors/reconnection-in-progress.js +0 -17
  44. package/dist/common/errors/reconnection-in-progress.js.map +1 -1
  45. package/dist/common/errors/reconnection.js +5 -26
  46. package/dist/common/errors/reconnection.js.map +1 -1
  47. package/dist/common/errors/stats.js +5 -26
  48. package/dist/common/errors/stats.js.map +1 -1
  49. package/dist/common/errors/webex-errors.js +6 -41
  50. package/dist/common/errors/webex-errors.js.map +1 -1
  51. package/dist/common/errors/webex-meetings-error.js +1 -24
  52. package/dist/common/errors/webex-meetings-error.js.map +1 -1
  53. package/dist/common/events/events-scope.js +0 -22
  54. package/dist/common/events/events-scope.js.map +1 -1
  55. package/dist/common/events/events.js +0 -23
  56. package/dist/common/events/events.js.map +1 -1
  57. package/dist/common/events/trigger-proxy.js +0 -12
  58. package/dist/common/events/trigger-proxy.js.map +1 -1
  59. package/dist/common/events/util.js +0 -15
  60. package/dist/common/events/util.js.map +1 -1
  61. package/dist/common/logs/logger-config.js +0 -4
  62. package/dist/common/logs/logger-config.js.map +1 -1
  63. package/dist/common/logs/logger-proxy.js +1 -8
  64. package/dist/common/logs/logger-proxy.js.map +1 -1
  65. package/dist/common/logs/request.js +35 -61
  66. package/dist/common/logs/request.js.map +1 -1
  67. package/dist/common/queue.js +4 -14
  68. package/dist/common/queue.js.map +1 -1
  69. package/dist/config.js +6 -6
  70. package/dist/config.js.map +1 -1
  71. package/dist/constants.js +193 -53
  72. package/dist/constants.js.map +1 -1
  73. package/dist/controls-options-manager/constants.js +14 -0
  74. package/dist/controls-options-manager/constants.js.map +1 -0
  75. package/dist/controls-options-manager/enums.js +27 -0
  76. package/dist/controls-options-manager/enums.js.map +1 -0
  77. package/dist/controls-options-manager/index.js +297 -0
  78. package/dist/controls-options-manager/index.js.map +1 -0
  79. package/dist/controls-options-manager/types.js +7 -0
  80. package/dist/controls-options-manager/types.js.map +1 -0
  81. package/dist/controls-options-manager/util.js +286 -0
  82. package/dist/controls-options-manager/util.js.map +1 -0
  83. package/dist/index.js +72 -17
  84. package/dist/index.js.map +1 -1
  85. package/dist/locus-info/controlsUtils.js +94 -29
  86. package/dist/locus-info/controlsUtils.js.map +1 -1
  87. package/dist/locus-info/embeddedAppsUtils.js +3 -26
  88. package/dist/locus-info/embeddedAppsUtils.js.map +1 -1
  89. package/dist/locus-info/fullState.js +0 -15
  90. package/dist/locus-info/fullState.js.map +1 -1
  91. package/dist/locus-info/hostUtils.js +4 -12
  92. package/dist/locus-info/hostUtils.js.map +1 -1
  93. package/dist/locus-info/index.js +383 -212
  94. package/dist/locus-info/index.js.map +1 -1
  95. package/dist/locus-info/infoUtils.js +0 -38
  96. package/dist/locus-info/infoUtils.js.map +1 -1
  97. package/dist/locus-info/mediaSharesUtils.js +12 -38
  98. package/dist/locus-info/mediaSharesUtils.js.map +1 -1
  99. package/dist/locus-info/parser.js +88 -123
  100. package/dist/locus-info/parser.js.map +1 -1
  101. package/dist/locus-info/selfUtils.js +99 -91
  102. package/dist/locus-info/selfUtils.js.map +1 -1
  103. package/dist/media/index.js +62 -147
  104. package/dist/media/index.js.map +1 -1
  105. package/dist/media/properties.js +71 -117
  106. package/dist/media/properties.js.map +1 -1
  107. package/dist/media/util.js +2 -9
  108. package/dist/media/util.js.map +1 -1
  109. package/dist/mediaQualityMetrics/config.js +505 -495
  110. package/dist/mediaQualityMetrics/config.js.map +1 -1
  111. package/dist/meeting/in-meeting-actions.js +67 -14
  112. package/dist/meeting/in-meeting-actions.js.map +1 -1
  113. package/dist/meeting/index.js +2477 -2417
  114. package/dist/meeting/index.js.map +1 -1
  115. package/dist/meeting/muteState.js +252 -113
  116. package/dist/meeting/muteState.js.map +1 -1
  117. package/dist/meeting/request.js +296 -289
  118. package/dist/meeting/request.js.map +1 -1
  119. package/dist/meeting/request.type.js +7 -0
  120. package/dist/meeting/request.type.js.map +1 -0
  121. package/dist/meeting/state.js +21 -31
  122. package/dist/meeting/state.js.map +1 -1
  123. package/dist/meeting/util.js +58 -217
  124. package/dist/meeting/util.js.map +1 -1
  125. package/dist/meeting-info/collection.js +3 -25
  126. package/dist/meeting-info/collection.js.map +1 -1
  127. package/dist/meeting-info/index.js +10 -33
  128. package/dist/meeting-info/index.js.map +1 -1
  129. package/dist/meeting-info/meeting-info-v2.js +278 -281
  130. package/dist/meeting-info/meeting-info-v2.js.map +1 -1
  131. package/dist/meeting-info/request.js +1 -16
  132. package/dist/meeting-info/request.js.map +1 -1
  133. package/dist/meeting-info/util.js +98 -183
  134. package/dist/meeting-info/util.js.map +1 -1
  135. package/dist/meeting-info/utilv2.js +155 -232
  136. package/dist/meeting-info/utilv2.js.map +1 -1
  137. package/dist/meetings/collection.js +24 -20
  138. package/dist/meetings/collection.js.map +1 -1
  139. package/dist/meetings/index.js +675 -593
  140. package/dist/meetings/index.js.map +1 -1
  141. package/dist/meetings/request.js +23 -42
  142. package/dist/meetings/request.js.map +1 -1
  143. package/dist/meetings/util.js +177 -155
  144. package/dist/meetings/util.js.map +1 -1
  145. package/dist/member/index.js +89 -88
  146. package/dist/member/index.js.map +1 -1
  147. package/dist/member/types.js +15 -0
  148. package/dist/member/types.js.map +1 -0
  149. package/dist/member/util.js +101 -69
  150. package/dist/member/util.js.map +1 -1
  151. package/dist/members/collection.js +12 -12
  152. package/dist/members/collection.js.map +1 -1
  153. package/dist/members/index.js +162 -204
  154. package/dist/members/index.js.map +1 -1
  155. package/dist/members/request.js +58 -53
  156. package/dist/members/request.js.map +1 -1
  157. package/dist/members/types.js +15 -0
  158. package/dist/members/types.js.map +1 -0
  159. package/dist/members/util.js +107 -44
  160. package/dist/members/util.js.map +1 -1
  161. package/dist/metrics/config.js +50 -16
  162. package/dist/metrics/config.js.map +1 -1
  163. package/dist/metrics/constants.js +3 -7
  164. package/dist/metrics/constants.js.map +1 -1
  165. package/dist/metrics/index.js +93 -162
  166. package/dist/metrics/index.js.map +1 -1
  167. package/dist/multistream/mediaRequestManager.js +167 -50
  168. package/dist/multistream/mediaRequestManager.js.map +1 -1
  169. package/dist/multistream/receiveSlot.js +58 -65
  170. package/dist/multistream/receiveSlot.js.map +1 -1
  171. package/dist/multistream/receiveSlotManager.js +74 -93
  172. package/dist/multistream/receiveSlotManager.js.map +1 -1
  173. package/dist/multistream/remoteMedia.js +55 -74
  174. package/dist/multistream/remoteMedia.js.map +1 -1
  175. package/dist/multistream/remoteMediaGroup.js +6 -40
  176. package/dist/multistream/remoteMediaGroup.js.map +1 -1
  177. package/dist/multistream/remoteMediaManager.js +466 -442
  178. package/dist/multistream/remoteMediaManager.js.map +1 -1
  179. package/dist/networkQualityMonitor/index.js +32 -59
  180. package/dist/networkQualityMonitor/index.js.map +1 -1
  181. package/dist/personal-meeting-room/index.js +10 -45
  182. package/dist/personal-meeting-room/index.js.map +1 -1
  183. package/dist/personal-meeting-room/request.js +2 -33
  184. package/dist/personal-meeting-room/request.js.map +1 -1
  185. package/dist/personal-meeting-room/util.js +0 -13
  186. package/dist/personal-meeting-room/util.js.map +1 -1
  187. package/dist/reachability/index.js +190 -199
  188. package/dist/reachability/index.js.map +1 -1
  189. package/dist/reachability/request.js +14 -23
  190. package/dist/reachability/request.js.map +1 -1
  191. package/dist/reactions/constants.js +13 -0
  192. package/dist/reactions/constants.js.map +1 -0
  193. package/dist/reactions/reactions.js +2 -4
  194. package/dist/reactions/reactions.js.map +1 -1
  195. package/dist/reactions/reactions.type.js +19 -23
  196. package/dist/reactions/reactions.type.js.map +1 -1
  197. package/dist/reconnection-manager/index.js +326 -465
  198. package/dist/reconnection-manager/index.js.map +1 -1
  199. package/dist/recording-controller/enums.js +17 -0
  200. package/dist/recording-controller/enums.js.map +1 -0
  201. package/dist/recording-controller/index.js +343 -0
  202. package/dist/recording-controller/index.js.map +1 -0
  203. package/dist/recording-controller/util.js +63 -0
  204. package/dist/recording-controller/util.js.map +1 -0
  205. package/dist/roap/index.js +38 -67
  206. package/dist/roap/index.js.map +1 -1
  207. package/dist/roap/request.js +143 -134
  208. package/dist/roap/request.js.map +1 -1
  209. package/dist/roap/turnDiscovery.js +149 -101
  210. package/dist/roap/turnDiscovery.js.map +1 -1
  211. package/dist/statsAnalyzer/global.js +1 -95
  212. package/dist/statsAnalyzer/global.js.map +1 -1
  213. package/dist/statsAnalyzer/index.js +369 -461
  214. package/dist/statsAnalyzer/index.js.map +1 -1
  215. package/dist/statsAnalyzer/mqaUtil.js +144 -94
  216. package/dist/statsAnalyzer/mqaUtil.js.map +1 -1
  217. package/dist/transcription/index.js +13 -45
  218. package/dist/transcription/index.js.map +1 -1
  219. package/dist/types/annotation/annotation.types.d.ts +34 -0
  220. package/dist/types/annotation/constants.d.ts +31 -0
  221. package/dist/types/annotation/index.d.ts +124 -0
  222. package/dist/types/breakouts/breakout.d.ts +8 -0
  223. package/dist/types/breakouts/collection.d.ts +5 -0
  224. package/dist/types/breakouts/edit-lock-error.d.ts +15 -0
  225. package/dist/types/breakouts/events.d.ts +2 -0
  226. package/dist/types/breakouts/index.d.ts +5 -0
  227. package/dist/types/breakouts/request.d.ts +22 -0
  228. package/dist/types/breakouts/utils.d.ts +15 -0
  229. package/dist/types/common/browser-detection.d.ts +9 -0
  230. package/dist/types/common/collection.d.ts +48 -0
  231. package/dist/types/common/config.d.ts +2 -0
  232. package/dist/types/common/errors/captcha-error.d.ts +15 -0
  233. package/dist/types/common/errors/intent-to-join.d.ts +16 -0
  234. package/dist/types/common/errors/join-meeting.d.ts +17 -0
  235. package/dist/types/common/errors/media.d.ts +15 -0
  236. package/dist/types/common/errors/parameter.d.ts +15 -0
  237. package/dist/types/common/errors/password-error.d.ts +15 -0
  238. package/dist/types/common/errors/permission.d.ts +14 -0
  239. package/dist/types/common/errors/reconnection-in-progress.d.ts +9 -0
  240. package/dist/types/common/errors/reconnection.d.ts +15 -0
  241. package/dist/types/common/errors/stats.d.ts +15 -0
  242. package/dist/types/common/errors/webex-errors.d.ts +69 -0
  243. package/dist/types/common/errors/webex-meetings-error.d.ts +20 -0
  244. package/dist/types/common/events/events-scope.d.ts +17 -0
  245. package/dist/types/common/events/events.d.ts +12 -0
  246. package/dist/types/common/events/trigger-proxy.d.ts +2 -0
  247. package/dist/types/common/events/util.d.ts +2 -0
  248. package/dist/types/common/logs/logger-config.d.ts +2 -0
  249. package/dist/types/common/logs/logger-proxy.d.ts +2 -0
  250. package/dist/types/common/logs/request.d.ts +34 -0
  251. package/dist/types/common/queue.d.ts +32 -0
  252. package/dist/types/config.d.ts +78 -0
  253. package/dist/types/constants.d.ts +984 -0
  254. package/dist/types/controls-options-manager/constants.d.ts +4 -0
  255. package/dist/types/controls-options-manager/enums.d.ts +15 -0
  256. package/dist/types/controls-options-manager/index.d.ts +136 -0
  257. package/dist/types/controls-options-manager/types.d.ts +43 -0
  258. package/dist/types/controls-options-manager/util.d.ts +1 -0
  259. package/dist/types/index.d.ts +7 -0
  260. package/dist/types/locus-info/controlsUtils.d.ts +2 -0
  261. package/dist/types/locus-info/embeddedAppsUtils.d.ts +2 -0
  262. package/dist/types/locus-info/fullState.d.ts +2 -0
  263. package/dist/types/locus-info/hostUtils.d.ts +2 -0
  264. package/dist/types/locus-info/index.d.ts +315 -0
  265. package/dist/types/locus-info/infoUtils.d.ts +2 -0
  266. package/dist/types/locus-info/mediaSharesUtils.d.ts +2 -0
  267. package/dist/types/locus-info/parser.d.ts +212 -0
  268. package/dist/types/locus-info/selfUtils.d.ts +2 -0
  269. package/dist/types/media/index.d.ts +34 -0
  270. package/dist/types/media/properties.d.ts +108 -0
  271. package/dist/types/media/util.d.ts +2 -0
  272. package/dist/types/mediaQualityMetrics/config.d.ts +365 -0
  273. package/dist/types/meeting/in-meeting-actions.d.ts +137 -0
  274. package/dist/types/meeting/index.d.ts +1753 -0
  275. package/dist/types/meeting/muteState.d.ts +185 -0
  276. package/dist/types/meeting/request.d.ts +275 -0
  277. package/dist/types/meeting/request.type.d.ts +11 -0
  278. package/dist/types/meeting/state.d.ts +9 -0
  279. package/dist/types/meeting/util.d.ts +2 -0
  280. package/dist/types/meeting-info/collection.d.ts +20 -0
  281. package/dist/types/meeting-info/index.d.ts +57 -0
  282. package/dist/types/meeting-info/meeting-info-v2.d.ts +115 -0
  283. package/dist/types/meeting-info/request.d.ts +22 -0
  284. package/dist/types/meeting-info/util.d.ts +2 -0
  285. package/dist/types/meeting-info/utilv2.d.ts +2 -0
  286. package/dist/types/meetings/collection.d.ts +31 -0
  287. package/dist/types/meetings/index.d.ts +345 -0
  288. package/dist/types/meetings/request.d.ts +27 -0
  289. package/dist/types/meetings/util.d.ts +18 -0
  290. package/dist/types/member/index.d.ts +157 -0
  291. package/dist/types/member/types.d.ts +21 -0
  292. package/dist/types/member/util.d.ts +2 -0
  293. package/dist/types/members/collection.d.ts +29 -0
  294. package/dist/types/members/index.d.ts +353 -0
  295. package/dist/types/members/request.d.ts +69 -0
  296. package/dist/types/members/types.d.ts +24 -0
  297. package/dist/types/members/util.d.ts +2 -0
  298. package/dist/types/metrics/config.d.ts +195 -0
  299. package/dist/types/metrics/constants.d.ts +54 -0
  300. package/dist/types/metrics/index.d.ts +169 -0
  301. package/dist/types/multistream/mediaRequestManager.d.ts +101 -0
  302. package/dist/types/multistream/receiveSlot.d.ts +68 -0
  303. package/dist/types/multistream/receiveSlotManager.d.ts +56 -0
  304. package/dist/types/multistream/remoteMedia.d.ts +72 -0
  305. package/dist/types/multistream/remoteMediaGroup.d.ts +47 -0
  306. package/dist/types/multistream/remoteMediaManager.d.ts +263 -0
  307. package/dist/types/networkQualityMonitor/index.d.ts +70 -0
  308. package/dist/types/personal-meeting-room/index.d.ts +47 -0
  309. package/dist/types/personal-meeting-room/request.d.ts +14 -0
  310. package/dist/types/personal-meeting-room/util.d.ts +2 -0
  311. package/dist/types/reachability/index.d.ts +152 -0
  312. package/dist/types/reachability/request.d.ts +37 -0
  313. package/dist/types/reactions/constants.d.ts +3 -0
  314. package/dist/types/reactions/reactions.d.ts +4 -0
  315. package/dist/types/reactions/reactions.type.d.ts +52 -0
  316. package/dist/types/reconnection-manager/index.d.ts +126 -0
  317. package/dist/types/recording-controller/enums.d.ts +7 -0
  318. package/dist/types/recording-controller/index.d.ts +193 -0
  319. package/dist/types/recording-controller/util.d.ts +13 -0
  320. package/dist/types/roap/index.d.ts +77 -0
  321. package/dist/types/roap/request.d.ts +38 -0
  322. package/dist/types/roap/turnDiscovery.d.ts +88 -0
  323. package/dist/types/statsAnalyzer/global.d.ts +36 -0
  324. package/dist/types/statsAnalyzer/index.d.ts +200 -0
  325. package/dist/types/statsAnalyzer/mqaUtil.d.ts +24 -0
  326. package/dist/types/transcription/index.d.ts +64 -0
  327. package/internal-README.md +7 -6
  328. package/package.json +28 -21
  329. package/src/annotation/annotation.types.ts +41 -0
  330. package/src/annotation/constants.ts +36 -0
  331. package/src/annotation/index.ts +339 -0
  332. package/src/breakouts/README.md +220 -0
  333. package/src/breakouts/breakout.ts +141 -0
  334. package/src/breakouts/collection.ts +19 -0
  335. package/src/breakouts/edit-lock-error.ts +25 -0
  336. package/src/breakouts/events.ts +37 -0
  337. package/src/breakouts/index.ts +835 -0
  338. package/src/breakouts/request.ts +55 -0
  339. package/src/breakouts/utils.ts +57 -0
  340. package/src/common/browser-detection.ts +9 -6
  341. package/src/common/collection.ts +3 -1
  342. package/src/common/errors/captcha-error.ts +6 -6
  343. package/src/common/errors/intent-to-join.ts +6 -6
  344. package/src/common/errors/join-meeting.ts +12 -8
  345. package/src/common/errors/media.ts +6 -6
  346. package/src/common/errors/parameter.ts +9 -6
  347. package/src/common/errors/password-error.ts +6 -6
  348. package/src/common/errors/permission.ts +5 -5
  349. package/src/common/errors/reconnection.ts +6 -6
  350. package/src/common/errors/stats.ts +6 -6
  351. package/src/common/errors/webex-errors.ts +7 -5
  352. package/src/common/errors/webex-meetings-error.ts +1 -1
  353. package/src/common/events/events-scope.ts +5 -1
  354. package/src/common/events/events.ts +5 -1
  355. package/src/common/events/trigger-proxy.ts +8 -3
  356. package/src/common/events/util.ts +1 -2
  357. package/src/common/logs/logger-proxy.ts +21 -10
  358. package/src/common/logs/request.ts +11 -8
  359. package/src/config.ts +16 -12
  360. package/src/constants.ts +141 -6
  361. package/src/controls-options-manager/constants.ts +5 -0
  362. package/src/controls-options-manager/enums.ts +18 -0
  363. package/src/controls-options-manager/index.ts +278 -0
  364. package/src/controls-options-manager/types.ts +59 -0
  365. package/src/controls-options-manager/util.ts +274 -0
  366. package/src/index.ts +33 -0
  367. package/src/locus-info/controlsUtils.ts +145 -24
  368. package/src/locus-info/fullState.ts +15 -11
  369. package/src/locus-info/hostUtils.ts +4 -3
  370. package/src/locus-info/index.ts +326 -55
  371. package/src/locus-info/infoUtils.ts +12 -4
  372. package/src/locus-info/mediaSharesUtils.ts +4 -4
  373. package/src/locus-info/parser.ts +46 -68
  374. package/src/locus-info/selfUtils.ts +187 -56
  375. package/src/media/index.ts +142 -172
  376. package/src/media/properties.ts +43 -36
  377. package/src/media/util.ts +1 -1
  378. package/src/mediaQualityMetrics/config.ts +380 -378
  379. package/src/meeting/in-meeting-actions.ts +139 -3
  380. package/src/meeting/index.ts +2674 -1543
  381. package/src/meeting/muteState.ts +271 -68
  382. package/src/meeting/request.ts +231 -135
  383. package/src/meeting/request.type.ts +13 -0
  384. package/src/meeting/state.ts +45 -30
  385. package/src/meeting/util.ts +119 -110
  386. package/src/meeting-info/collection.ts +2 -1
  387. package/src/meeting-info/index.ts +32 -30
  388. package/src/meeting-info/meeting-info-v2.ts +201 -113
  389. package/src/meeting-info/request.ts +9 -3
  390. package/src/meeting-info/util.ts +54 -46
  391. package/src/meeting-info/utilv2.ts +70 -55
  392. package/src/meetings/collection.ts +21 -1
  393. package/src/meetings/index.ts +749 -437
  394. package/src/meetings/request.ts +29 -25
  395. package/src/meetings/util.ts +122 -33
  396. package/src/member/index.ts +95 -49
  397. package/src/member/types.ts +24 -0
  398. package/src/member/util.ts +106 -13
  399. package/src/members/collection.ts +8 -1
  400. package/src/members/index.ts +281 -129
  401. package/src/members/request.ts +87 -14
  402. package/src/members/types.ts +28 -0
  403. package/src/members/util.ts +140 -49
  404. package/src/metrics/config.ts +302 -90
  405. package/src/metrics/constants.ts +1 -6
  406. package/src/metrics/index.ts +124 -95
  407. package/src/multistream/mediaRequestManager.ts +203 -45
  408. package/src/multistream/receiveSlot.ts +69 -26
  409. package/src/multistream/receiveSlotManager.ts +62 -38
  410. package/src/multistream/remoteMedia.ts +30 -4
  411. package/src/multistream/remoteMediaGroup.ts +4 -3
  412. package/src/multistream/remoteMediaManager.ts +230 -66
  413. package/src/networkQualityMonitor/index.ts +24 -27
  414. package/src/personal-meeting-room/index.ts +12 -16
  415. package/src/personal-meeting-room/request.ts +10 -3
  416. package/src/personal-meeting-room/util.ts +3 -3
  417. package/src/reachability/index.ts +131 -79
  418. package/src/reachability/request.ts +43 -34
  419. package/src/reactions/constants.ts +4 -0
  420. package/src/reactions/reactions.ts +8 -8
  421. package/src/reactions/reactions.type.ts +31 -5
  422. package/src/reconnection-manager/index.ts +193 -111
  423. package/src/recording-controller/enums.ts +8 -0
  424. package/src/recording-controller/index.ts +315 -0
  425. package/src/recording-controller/util.ts +58 -0
  426. package/src/roap/index.ts +63 -51
  427. package/src/roap/request.ts +86 -53
  428. package/src/roap/turnDiscovery.ts +105 -46
  429. package/src/statsAnalyzer/global.ts +8 -104
  430. package/src/statsAnalyzer/index.ts +624 -376
  431. package/src/statsAnalyzer/mqaUtil.ts +203 -90
  432. package/src/transcription/index.ts +34 -32
  433. package/test/integration/spec/converged-space-meetings.js +177 -0
  434. package/test/integration/spec/journey.js +670 -466
  435. package/test/integration/spec/space-meeting.js +320 -204
  436. package/test/integration/spec/transcription.js +7 -8
  437. package/test/unit/spec/annotation/index.ts +435 -0
  438. package/test/unit/spec/breakouts/breakout.ts +184 -0
  439. package/test/unit/spec/breakouts/collection.ts +15 -0
  440. package/test/unit/spec/breakouts/edit-lock-error.ts +30 -0
  441. package/test/unit/spec/breakouts/events.ts +77 -0
  442. package/test/unit/spec/breakouts/index.ts +1542 -0
  443. package/test/unit/spec/breakouts/request.ts +104 -0
  444. package/test/unit/spec/breakouts/utils.js +72 -0
  445. package/test/unit/spec/common/browser-detection.js +9 -28
  446. package/test/unit/spec/controls-options-manager/index.js +287 -0
  447. package/test/unit/spec/controls-options-manager/util.js +504 -0
  448. package/test/unit/spec/fixture/locus.js +93 -90
  449. package/test/unit/spec/locus-info/controlsUtils.js +289 -32
  450. package/test/unit/spec/locus-info/embeddedAppsUtils.js +8 -6
  451. package/test/unit/spec/locus-info/index.js +585 -5
  452. package/test/unit/spec/locus-info/infoUtils.js +26 -33
  453. package/test/unit/spec/locus-info/lib/BasicSeqCmp.json +88 -430
  454. package/test/unit/spec/locus-info/lib/SeqCmp.json +513 -685
  455. package/test/unit/spec/locus-info/parser.js +3 -9
  456. package/test/unit/spec/locus-info/selfConstant.js +110 -103
  457. package/test/unit/spec/locus-info/selfUtils.js +236 -12
  458. package/test/unit/spec/media/index.ts +104 -8
  459. package/test/unit/spec/media/properties.ts +9 -9
  460. package/test/unit/spec/meeting/in-meeting-actions.ts +66 -3
  461. package/test/unit/spec/meeting/index.js +2934 -946
  462. package/test/unit/spec/meeting/muteState.js +368 -70
  463. package/test/unit/spec/meeting/request.js +194 -44
  464. package/test/unit/spec/meeting/utils.js +146 -165
  465. package/test/unit/spec/meeting-info/meetinginfov2.js +333 -74
  466. package/test/unit/spec/meeting-info/request.js +7 -9
  467. package/test/unit/spec/meeting-info/util.js +11 -12
  468. package/test/unit/spec/meeting-info/utilv2.js +131 -74
  469. package/test/unit/spec/meetings/collection.js +15 -1
  470. package/test/unit/spec/meetings/index.js +1052 -329
  471. package/test/unit/spec/meetings/utils.js +163 -14
  472. package/test/unit/spec/member/index.js +24 -1
  473. package/test/unit/spec/member/util.js +383 -32
  474. package/test/unit/spec/members/index.js +402 -54
  475. package/test/unit/spec/members/request.js +76 -20
  476. package/test/unit/spec/members/utils.js +191 -4
  477. package/test/unit/spec/metrics/index.js +104 -20
  478. package/test/unit/spec/multistream/mediaRequestManager.ts +650 -105
  479. package/test/unit/spec/multistream/receiveSlot.ts +76 -17
  480. package/test/unit/spec/multistream/receiveSlotManager.ts +69 -39
  481. package/test/unit/spec/multistream/remoteMedia.ts +32 -2
  482. package/test/unit/spec/multistream/remoteMediaGroup.ts +5 -5
  483. package/test/unit/spec/multistream/remoteMediaManager.ts +549 -65
  484. package/test/unit/spec/networkQualityMonitor/index.js +24 -18
  485. package/test/unit/spec/personal-meeting-room/personal-meeting-room.js +2 -7
  486. package/test/unit/spec/reachability/index.ts +176 -27
  487. package/test/unit/spec/reachability/request.js +66 -0
  488. package/test/unit/spec/reconnection-manager/index.js +62 -31
  489. package/test/unit/spec/recording-controller/index.js +231 -0
  490. package/test/unit/spec/recording-controller/util.js +102 -0
  491. package/test/unit/spec/roap/index.ts +21 -16
  492. package/test/unit/spec/roap/request.ts +217 -0
  493. package/test/unit/spec/roap/turnDiscovery.ts +93 -49
  494. package/test/unit/spec/stats-analyzer/index.js +116 -60
  495. package/test/utils/cmr.js +44 -42
  496. package/test/utils/constants.js +9 -0
  497. package/test/utils/integrationTestUtils.js +64 -0
  498. package/test/utils/testUtils.js +63 -99
  499. package/test/utils/webex-config.js +22 -18
  500. package/test/utils/webex-test-users.js +57 -50
  501. package/tsconfig.json +6 -0
  502. package/dist/media/internal-media-core-wrapper.js +0 -22
  503. package/dist/media/internal-media-core-wrapper.js.map +0 -1
  504. package/dist/meeting/effectsState.js +0 -334
  505. package/dist/meeting/effectsState.js.map +0 -1
  506. package/dist/multistream/multistreamMedia.js +0 -116
  507. package/dist/multistream/multistreamMedia.js.map +0 -1
  508. package/src/index.js +0 -15
  509. package/src/media/internal-media-core-wrapper.ts +0 -9
  510. package/src/meeting/effectsState.ts +0 -211
  511. package/src/multistream/multistreamMedia.ts +0 -92
  512. package/test/unit/spec/meeting/effectsState.js +0 -291
@@ -0,0 +1,59 @@
1
+ import {Control} from './enums';
2
+
3
+ export interface ControlProperties {
4
+ /**
5
+ * A list of additional properties that apply to various specific settings.
6
+ *
7
+ * @remarks
8
+ * The values stored here, per the service, are fully ambiguous, an can vary
9
+ * depending on which control scope is being configured.
10
+ */
11
+ [key: string]: boolean;
12
+ }
13
+
14
+ export interface AudioProperties {
15
+ muted?: boolean;
16
+ disallowUnmute?: boolean;
17
+ muteOnEntry?: boolean;
18
+ }
19
+
20
+ export interface RaiseHandProperties {
21
+ enabled?: boolean;
22
+ }
23
+
24
+ export interface ReactionsProperties {
25
+ enabled?: boolean;
26
+ showDisplayNameWithReactions?: boolean;
27
+ }
28
+
29
+ export interface ShareControlProperties {
30
+ control?: 'ANYONE' | 'MODERATOR_PRESENTER';
31
+ }
32
+
33
+ export interface VideoProperties {
34
+ enabled?: boolean;
35
+ }
36
+
37
+ export interface ViewTheParticipantListProperties {
38
+ enabled?: boolean;
39
+ }
40
+
41
+ export type Properties =
42
+ | AudioProperties
43
+ | RaiseHandProperties
44
+ | ReactionsProperties
45
+ | ShareControlProperties
46
+ | VideoProperties
47
+ | ViewTheParticipantListProperties;
48
+
49
+ export interface ControlConfig<Props = Properties> {
50
+ /**
51
+ * The scope of the control within this object.
52
+ */
53
+ scope: Control;
54
+
55
+ /**
56
+ * The properties to assign to this control.
57
+ */
58
+ properties: Props;
59
+ }
@@ -0,0 +1,274 @@
1
+ import {DISPLAY_HINTS} from '../constants';
2
+ import {Control} from './enums';
3
+ import {
4
+ ControlConfig,
5
+ AudioProperties,
6
+ RaiseHandProperties,
7
+ ReactionsProperties,
8
+ ViewTheParticipantListProperties,
9
+ VideoProperties,
10
+ } from './types';
11
+
12
+ /**
13
+ * The Controls Options Manager utilities
14
+ *
15
+ * @internal
16
+ */
17
+ class Utils {
18
+ /**
19
+ * Validate if enabling mute on entry can be set.
20
+ *
21
+ * @param {Array<string>} displayHints - Display Hints to use when validating.
22
+ * @returns {boolean} - True if the action is allowed.
23
+ */
24
+ public static canSetMuteOnEntry(displayHints: Array<string>): boolean {
25
+ return displayHints.includes(DISPLAY_HINTS.ENABLE_MUTE_ON_ENTRY);
26
+ }
27
+
28
+ /**
29
+ * Validate if allowing unmuting can be set.
30
+ *
31
+ * @param {Array<string>} displayHints - Display Hints to use when validating.
32
+ * @returns {boolean} - True if the action is allowed.
33
+ */
34
+ public static canSetDisallowUnmute(displayHints: Array<string>): boolean {
35
+ return displayHints.includes(DISPLAY_HINTS.ENABLE_HARD_MUTE);
36
+ }
37
+
38
+ /**
39
+ * Validate if disabling mute on entry can be set.
40
+ *
41
+ * @param {Array<string>} displayHints - Display Hints to use when validating.
42
+ * @returns {boolean} - True if the action is allowed.
43
+ */
44
+ public static canUnsetMuteOnEntry(displayHints: Array<string>): boolean {
45
+ return displayHints.includes(DISPLAY_HINTS.DISABLE_MUTE_ON_ENTRY);
46
+ }
47
+
48
+ /**
49
+ * Validate if enabling muting can be set.
50
+ *
51
+ * @param {Array<string>} displayHints - Display Hints to use when validating.
52
+ * @returns {boolean} - True if the action is allowed.
53
+ */
54
+ public static canUnsetDisallowUnmute(displayHints: Array<string>): boolean {
55
+ return displayHints.includes(DISPLAY_HINTS.DISABLE_HARD_MUTE);
56
+ }
57
+
58
+ /**
59
+ * Validate if muting all can be set.
60
+ *
61
+ * @param {Array<string>} displayHints - Display Hints to use when validating.
62
+ * @returns {boolean} - True if the action is allowed.
63
+ */
64
+ public static canSetMuted(displayHints: Array<string>): boolean {
65
+ return displayHints.includes(DISPLAY_HINTS.MUTE_ALL);
66
+ }
67
+
68
+ /**
69
+ * Validate if unmuting all can be set.
70
+ *
71
+ * @param {Array<string>} displayHints - Display Hints to use when validating.
72
+ * @returns {boolean} - True if the action is allowed.
73
+ */
74
+ public static canUnsetMuted(displayHints: Array<string>): boolean {
75
+ return displayHints.includes(DISPLAY_HINTS.UNMUTE_ALL);
76
+ }
77
+
78
+ /**
79
+ * Validate an array of hints are allowed based on a full collection of hints.
80
+ *
81
+ * @param {Object} config - Configuration Object.
82
+ * @param {Array<string>} config.requiredHints - Hints required for validation.
83
+ * @param {Array<string>} config.displayHints - All available hints.
84
+ * @returns {boolean} - True if all of the actions are allowed.
85
+ */
86
+ public static hasHints(config: {requiredHints: Array<string>; displayHints: Array<string>}) {
87
+ const {requiredHints, displayHints} = config;
88
+
89
+ return requiredHints.every((hint) => displayHints.includes(hint));
90
+ }
91
+
92
+ /**
93
+ * Validate if an audio-scoped control is allowed to be sent to the service.
94
+ *
95
+ * @param {ControlConfig<AudioProperties>} control - Audio control config to validate.
96
+ * @param {Array<string>} displayHints - All available hints.
97
+ * @returns {boolean} - True if all of the actions are allowed.
98
+ */
99
+ public static canUpdateAudio(
100
+ control: ControlConfig<AudioProperties>,
101
+ displayHints: Array<string>
102
+ ) {
103
+ const requiredHints = [];
104
+
105
+ if (control.properties.muted === true) {
106
+ requiredHints.push(DISPLAY_HINTS.MUTE_ALL);
107
+ }
108
+ if (control.properties.muted === false) {
109
+ requiredHints.push(DISPLAY_HINTS.UNMUTE_ALL);
110
+ }
111
+ if (control.properties.disallowUnmute === true) {
112
+ requiredHints.push(DISPLAY_HINTS.ENABLE_HARD_MUTE);
113
+ }
114
+ if (control.properties.disallowUnmute === false) {
115
+ requiredHints.push(DISPLAY_HINTS.DISABLE_HARD_MUTE);
116
+ }
117
+ if (control.properties.muteOnEntry === true) {
118
+ requiredHints.push(DISPLAY_HINTS.ENABLE_MUTE_ON_ENTRY);
119
+ }
120
+ if (control.properties.muteOnEntry === false) {
121
+ requiredHints.push(DISPLAY_HINTS.DISABLE_MUTE_ON_ENTRY);
122
+ }
123
+
124
+ return Utils.hasHints({requiredHints, displayHints});
125
+ }
126
+
127
+ public static canUpdateRaiseHand(
128
+ control: ControlConfig<RaiseHandProperties>,
129
+ displayHints: Array<string>
130
+ ) {
131
+ const requiredHints = [];
132
+
133
+ if (control.properties.enabled === true) {
134
+ requiredHints.push(DISPLAY_HINTS.ENABLE_RAISE_HAND);
135
+ }
136
+ if (control.properties.enabled === false) {
137
+ requiredHints.push(DISPLAY_HINTS.DISABLE_RAISE_HAND);
138
+ }
139
+
140
+ return Utils.hasHints({requiredHints, displayHints});
141
+ }
142
+
143
+ /**
144
+ * Validate if an reactions-scoped control is allowed to be sent to the service.
145
+ *
146
+ * @param {ControlConfig<ReactionsProperties>} control - Reaction control config to validate.
147
+ * @param {Array<string>} displayHints - All available hints.
148
+ * @returns {boolean} - True if all of the actions are allowed.
149
+ */
150
+ public static canUpdateReactions(
151
+ control: ControlConfig<ReactionsProperties>,
152
+ displayHints: Array<string>
153
+ ) {
154
+ const requiredHints = [];
155
+
156
+ if (control.properties.enabled === true) {
157
+ requiredHints.push(DISPLAY_HINTS.ENABLE_REACTIONS);
158
+ }
159
+ if (control.properties.enabled === false) {
160
+ requiredHints.push(DISPLAY_HINTS.DISABLE_REACTIONS);
161
+ }
162
+ if (control.properties.showDisplayNameWithReactions === true) {
163
+ requiredHints.push(DISPLAY_HINTS.ENABLE_SHOW_DISPLAY_NAME);
164
+ }
165
+ if (control.properties.showDisplayNameWithReactions === false) {
166
+ requiredHints.push(DISPLAY_HINTS.DISABLE_SHOW_DISPLAY_NAME);
167
+ }
168
+
169
+ return Utils.hasHints({requiredHints, displayHints});
170
+ }
171
+
172
+ /**
173
+ * Validate if an share-control-scoped control is allowed to be sent to the service.
174
+ *
175
+ * @param {Array<string>} displayHints - All available hints.
176
+ * @returns {boolean} - True if all of the actions are allowed.
177
+ */
178
+ public static canUpdateShareControl(displayHints: Array<string>) {
179
+ return Utils.hasHints({requiredHints: [DISPLAY_HINTS.SHARE_CONTROL], displayHints});
180
+ }
181
+
182
+ /**
183
+ * Validate if an view-the-participants-list-scoped control is allowed to be sent to the service.
184
+ *
185
+ * @param {ControlConfig<ViewTheParticipantListProperties>} control - View Participants List control config to validate.
186
+ * @param {Array<string>} displayHints - All available hints.
187
+ * @returns {boolean} - True if all of the actions are allowed.
188
+ */
189
+ public static canUpdateViewTheParticipantsList(
190
+ control: ControlConfig<ViewTheParticipantListProperties>,
191
+ displayHints: Array<string>
192
+ ) {
193
+ const requiredHints = [];
194
+
195
+ if (control.properties.enabled === true) {
196
+ requiredHints.push(DISPLAY_HINTS.ENABLE_VIEW_THE_PARTICIPANT_LIST);
197
+ }
198
+ if (control.properties.enabled === false) {
199
+ requiredHints.push(DISPLAY_HINTS.DISABLE_VIEW_THE_PARTICIPANT_LIST);
200
+ }
201
+
202
+ return Utils.hasHints({requiredHints, displayHints});
203
+ }
204
+
205
+ public static canUpdateVideo(
206
+ control: ControlConfig<VideoProperties>,
207
+ displayHints: Array<string>
208
+ ) {
209
+ const requiredHints = [];
210
+
211
+ if (control.properties.enabled === true) {
212
+ requiredHints.push(DISPLAY_HINTS.ENABLE_VIDEO);
213
+ }
214
+ if (control.properties.enabled === false) {
215
+ requiredHints.push(DISPLAY_HINTS.DISABLE_VIDEO);
216
+ }
217
+
218
+ return Utils.hasHints({requiredHints, displayHints});
219
+ }
220
+
221
+ /**
222
+ * Validate that a control can be sent to the service based on the provided
223
+ * display hints.
224
+ *
225
+ * @param {ControlConfig} control - Control to validate.
226
+ * @param {Array<string>} displayHints - All available hints.
227
+ * @returns {boolean} - True if all of the actions are allowed.
228
+ */
229
+ public static canUpdate(control: ControlConfig, displayHints: Array<string>) {
230
+ let determinant: boolean;
231
+
232
+ switch (control.scope) {
233
+ case Control.audio:
234
+ determinant = Utils.canUpdateAudio(control as ControlConfig<AudioProperties>, displayHints);
235
+ break;
236
+
237
+ case Control.raiseHand:
238
+ determinant = Utils.canUpdateRaiseHand(
239
+ control as ControlConfig<RaiseHandProperties>,
240
+ displayHints
241
+ );
242
+ break;
243
+
244
+ case Control.reactions:
245
+ determinant = Utils.canUpdateReactions(
246
+ control as ControlConfig<ReactionsProperties>,
247
+ displayHints
248
+ );
249
+ break;
250
+
251
+ case Control.shareControl:
252
+ determinant = Utils.canUpdateShareControl(displayHints);
253
+ break;
254
+
255
+ case Control.video:
256
+ determinant = Utils.canUpdateVideo(control as ControlConfig<VideoProperties>, displayHints);
257
+ break;
258
+
259
+ case Control.viewTheParticipantList:
260
+ determinant = Utils.canUpdateViewTheParticipantsList(
261
+ control as ControlConfig<ViewTheParticipantListProperties>,
262
+ displayHints
263
+ );
264
+ break;
265
+
266
+ default:
267
+ determinant = false;
268
+ }
269
+
270
+ return determinant;
271
+ }
272
+ }
273
+
274
+ export default Utils;
package/src/index.ts ADDED
@@ -0,0 +1,33 @@
1
+ /* eslint-env browser */
2
+ import {registerPlugin} from '@webex/webex-core';
3
+
4
+ import Meetings from './meetings';
5
+ import config from './config';
6
+
7
+ registerPlugin('meetings', Meetings, {
8
+ config,
9
+ });
10
+
11
+ export {
12
+ LocalTrack,
13
+ LocalDisplayTrack,
14
+ LocalTrackEvents,
15
+ type TrackMuteEvent,
16
+ type ServerMuteReason,
17
+ LocalMicrophoneTrackEvents,
18
+ LocalCameraTrackEvents,
19
+ LocalMicrophoneTrack,
20
+ LocalCameraTrack,
21
+ createMicrophoneTrack,
22
+ createCameraTrack,
23
+ createDisplayTrack,
24
+ } from '@webex/media-helpers';
25
+
26
+ export default Meetings;
27
+
28
+ export * as CONSTANTS from './constants';
29
+ export * as REACTIONS from './reactions/reactions';
30
+
31
+ export {RemoteMedia} from './multistream/remoteMedia';
32
+
33
+ export {default as TriggerProxy} from './common/events/trigger-proxy';
@@ -1,4 +1,5 @@
1
1
  import {isEqual} from 'lodash';
2
+ import {BREAKOUTS} from '../constants';
2
3
 
3
4
  const ControlsUtils: any = {};
4
5
 
@@ -25,25 +26,58 @@ ControlsUtils.parse = (controls: any) => {
25
26
  modifiedBy: ControlsUtils.getId(controls),
26
27
  paused: controls.record.paused ? controls.record.paused : false,
27
28
  recording: controls.record.recording,
28
- lastModified: controls.record.meta.lastModified
29
+ lastModified: controls.record.meta.lastModified,
29
30
  };
30
31
  }
31
32
 
32
33
  if (controls && controls.meetingContainer) {
33
34
  parsedControls.meetingContainer = {
34
- meetingContainerUrl: controls.meetingContainer.meetingContainerUrl
35
+ meetingContainerUrl: controls.meetingContainer.meetingContainerUrl,
35
36
  };
36
37
  }
37
38
 
38
39
  if (controls && controls.transcribe) {
39
40
  parsedControls.transcribe = {
40
41
  transcribing: controls.transcribe.transcribing,
41
- caption: controls.transcribe.caption
42
+ caption: controls.transcribe.caption,
42
43
  };
43
44
  }
44
45
 
45
46
  if (controls && controls.entryExitTone) {
46
- parsedControls.entryExitTone = controls.entryExitTone.enabled ? controls.entryExitTone.mode : null;
47
+ parsedControls.entryExitTone = controls.entryExitTone.enabled
48
+ ? controls.entryExitTone.mode
49
+ : null;
50
+ }
51
+
52
+ if (controls && controls.video) {
53
+ parsedControls.videoEnabled = controls.video.enabled;
54
+ }
55
+
56
+ if (controls?.muteOnEntry) {
57
+ parsedControls.muteOnEntry = {enabled: controls.muteOnEntry.enabled};
58
+ }
59
+
60
+ if (controls?.shareControl) {
61
+ parsedControls.shareControl = {control: controls.shareControl.control};
62
+ }
63
+
64
+ if (controls?.disallowUnmute) {
65
+ parsedControls.disallowUnmute = {enabled: controls.disallowUnmute.enabled};
66
+ }
67
+
68
+ if (controls?.reactions) {
69
+ parsedControls.reactions = {
70
+ enabled: controls.reactions.enabled,
71
+ showDisplayNameWithReactions: controls.reactions.showDisplayNameWithReactions,
72
+ };
73
+ }
74
+
75
+ if (controls?.viewTheParticipantList) {
76
+ parsedControls.viewTheParticipantList = {enabled: controls.viewTheParticipantList.enabled};
77
+ }
78
+
79
+ if (controls?.raiseHand) {
80
+ parsedControls.raiseHand = {enabled: controls.raiseHand.enabled};
47
81
  }
48
82
 
49
83
  return parsedControls;
@@ -63,26 +97,67 @@ ControlsUtils.getControls = (oldControls: any, newControls: any) => {
63
97
  previous,
64
98
  current,
65
99
  updates: {
66
- hasRecordingPausedChanged: current?.record &&
67
- !isEqual(previous?.record?.paused, current.record.paused) &&
68
- (previous?.record?.recording || current?.record?.recording), // see comments directly below
69
-
70
- hasRecordingChanged: current?.record &&
71
- !isEqual(previous?.record?.recording, current?.record?.recording) && // upon first join, previous?.record?.recording = undefined; thus, never going to be equal and will always return true
72
- (previous?.record?.recording || current?.record?.recording), // therefore, condition added to prevent false firings of #meeting:recording:stopped upon first joining a meeting
73
-
74
- hasMeetingContainerChanged: current?.meetingContainer &&
75
- !isEqual(previous?.meetingContainer?.meetingContainerUrl,
76
- current?.meetingContainer?.meetingContainerUrl),
77
-
78
- hasTranscribeChanged: current?.transcribe &&
79
- !isEqual(previous?.transcribe?.transcribing, current?.transcribe?.transcribing) && // upon first join, previous?.record?.recording = undefined; thus, never going to be equal and will always return true
80
- (previous?.transcribe?.transcribing || current?.transcribe?.transcribing), // therefore, condition added to prevent false firings of #meeting:recording:stopped upon first joining a meeting
81
-
82
- hasEntryExitToneChanged: !!(newControls.entryExitTone &&
83
- !isEqual(previous?.entryExitTone, current?.entryExitTone) &&
84
- (previous?.entryExitTone || current?.entryExitTone)),
85
- }
100
+ hasMuteOnEntryChanged:
101
+ current?.muteOnEntry?.enabled &&
102
+ current?.muteOnEntry?.enabled !== previous?.muteOnEntry?.enabled,
103
+
104
+ hasShareControlChanged:
105
+ current?.shareControl?.control &&
106
+ current?.shareControl?.control !== previous?.shareControl?.control,
107
+
108
+ hasDisallowUnmuteChanged:
109
+ current?.disallowUnmute?.enabled &&
110
+ current?.disallowUnmute?.enabled !== previous?.disallowUnmute?.enabled,
111
+
112
+ hasReactionsChanged:
113
+ current?.reactions?.enabled && current?.reactions?.enabled !== previous?.reactions?.enabled,
114
+
115
+ hasReactionDisplayNamesChanged:
116
+ current?.reactions?.showDisplayNameWithReactions &&
117
+ current?.reactions?.showDisplayNameWithReactions !==
118
+ previous?.reactions?.showDisplayNameWithReactions,
119
+
120
+ hasViewTheParticipantListChanged:
121
+ current?.viewTheParticipantList?.enabled &&
122
+ current?.viewTheParticipantList?.enabled !== previous?.viewTheParticipantList?.enabled,
123
+
124
+ hasRaiseHandChanged:
125
+ current?.raiseHand?.enabled && current?.raiseHand?.enabled !== previous?.raiseHand?.enabled,
126
+
127
+ hasRecordingPausedChanged:
128
+ current?.record &&
129
+ !isEqual(previous?.record?.paused, current.record.paused) &&
130
+ (previous?.record?.recording || current?.record?.recording), // see comments directly below
131
+
132
+ hasRecordingChanged:
133
+ current?.record &&
134
+ !isEqual(previous?.record?.recording, current?.record?.recording) && // upon first join, previous?.record?.recording = undefined; thus, never going to be equal and will always return true
135
+ (previous?.record?.recording || current?.record?.recording), // therefore, condition added to prevent false firings of #meeting:recording:stopped upon first joining a meeting
136
+
137
+ hasMeetingContainerChanged:
138
+ current?.meetingContainer &&
139
+ !isEqual(
140
+ previous?.meetingContainer?.meetingContainerUrl,
141
+ current?.meetingContainer?.meetingContainerUrl
142
+ ),
143
+
144
+ hasTranscribeChanged:
145
+ current?.transcribe &&
146
+ !isEqual(previous?.transcribe?.transcribing, current?.transcribe?.transcribing) && // upon first join, previous?.record?.recording = undefined; thus, never going to be equal and will always return true
147
+ (previous?.transcribe?.transcribing || current?.transcribe?.transcribing), // therefore, condition added to prevent false firings of #meeting:recording:stopped upon first joining a meeting
148
+
149
+ hasEntryExitToneChanged: !!(
150
+ newControls.entryExitTone &&
151
+ !isEqual(previous?.entryExitTone, current?.entryExitTone) &&
152
+ (previous?.entryExitTone || current?.entryExitTone)
153
+ ),
154
+
155
+ hasBreakoutChanged: !isEqual(previous?.breakout, current?.breakout),
156
+
157
+ hasVideoEnabledChanged:
158
+ newControls.video?.enabled !== undefined &&
159
+ !isEqual(previous?.videoEnabled, current?.videoEnabled),
160
+ },
86
161
  };
87
162
  };
88
163
 
@@ -99,4 +174,50 @@ ControlsUtils.getId = (controls: any) => {
99
174
  return null;
100
175
  };
101
176
 
177
+ /**
178
+ * check whether to replace the meeting's members or not.
179
+ * For case joined breakout session, need replace meeting's members
180
+ * @param {LocusControls} oldControls
181
+ * @param {LocusControls} controls
182
+ * @returns {Boolean}
183
+ */
184
+ ControlsUtils.isNeedReplaceMembers = (oldControls: any, controls: any) => {
185
+ // no breakout case
186
+ if (!oldControls?.breakout || !controls?.breakout) {
187
+ return false;
188
+ }
189
+
190
+ return (
191
+ oldControls.breakout.groupId !== controls.breakout.groupId ||
192
+ oldControls.breakout.sessionId !== controls.breakout.sessionId
193
+ );
194
+ };
195
+
196
+ /**
197
+ * determine the switch status between breakout session and main session.
198
+ * @param {LocusControls} oldControls
199
+ * @param {LocusControls} controls
200
+ * @returns {Object}
201
+ */
202
+ ControlsUtils.getSessionSwitchStatus = (oldControls: any, controls: any) => {
203
+ const status = {isReturnToMain: false, isJoinToBreakout: false};
204
+ // no breakout case
205
+ if (!oldControls?.breakout || !controls?.breakout) {
206
+ return status;
207
+ }
208
+
209
+ status.isReturnToMain =
210
+ oldControls.breakout.sessionType === BREAKOUTS.SESSION_TYPES.BREAKOUT &&
211
+ controls.breakout.sessionType === BREAKOUTS.SESSION_TYPES.MAIN;
212
+ status.isJoinToBreakout =
213
+ oldControls.breakout.sessionType === BREAKOUTS.SESSION_TYPES.MAIN &&
214
+ controls.breakout.sessionType === BREAKOUTS.SESSION_TYPES.BREAKOUT;
215
+
216
+ return status;
217
+ };
218
+
219
+ ControlsUtils.isMainSessionDTO = (locus: any) => {
220
+ return locus?.controls?.breakout?.sessionType !== BREAKOUTS.SESSION_TYPES.BREAKOUT;
221
+ };
222
+
102
223
  export default ControlsUtils;
@@ -5,10 +5,9 @@ const FullState: any = {};
5
5
  FullState.parse = (fullState) => ({
6
6
  type: fullState.type || FULL_STATE.UNKNOWN,
7
7
  meetingState: fullState.state,
8
- locked: fullState.locked
8
+ locked: fullState.locked,
9
9
  });
10
10
 
11
-
12
11
  FullState.getFullState = (oldFullState, newFullState) => {
13
12
  const previous = oldFullState && FullState.parse(oldFullState);
14
13
  const current = newFullState && FullState.parse(newFullState);
@@ -20,16 +19,19 @@ FullState.getFullState = (oldFullState, newFullState) => {
20
19
  isMeetingEnded: FullState.isMeetingEnded(previous, current),
21
20
  isMeetingTerminating: FullState.isMeetingTerminating(previous, current),
22
21
  meetingTypeChangedTo: FullState.isTypeChanged(previous, current),
23
- meetingStateChangedTo: FullState.meetingStateChange(previous, current)
24
- }
22
+ meetingStateChangedTo: FullState.meetingStateChange(previous, current),
23
+ },
25
24
  };
26
25
  };
27
26
 
28
27
  FullState.isMeetingEnded = (previous, current) => {
29
- if (current.state === FULL_STATE.INACTIVE && previous &&
30
- (previous.state === FULL_STATE.ACTIVE ||
31
- previous.state === FULL_STATE.INITIALIZING ||
32
- previous.state === FULL_STATE.TERMINATING)) {
28
+ if (
29
+ current.state === FULL_STATE.INACTIVE &&
30
+ previous &&
31
+ (previous.state === FULL_STATE.ACTIVE ||
32
+ previous.state === FULL_STATE.INITIALIZING ||
33
+ previous.state === FULL_STATE.TERMINATING)
34
+ ) {
33
35
  return true;
34
36
  }
35
37
 
@@ -37,9 +39,11 @@ FullState.isMeetingEnded = (previous, current) => {
37
39
  };
38
40
 
39
41
  FullState.isMeetingTerminating = (previous, current) => {
40
- if (current.state === FULL_STATE.TERMINATING && previous &&
41
- (previous.state === FULL_STATE.ACTIVE ||
42
- previous.state === FULL_STATE.INITIALIZING)) {
42
+ if (
43
+ current.state === FULL_STATE.TERMINATING &&
44
+ previous &&
45
+ (previous.state === FULL_STATE.ACTIVE || previous.state === FULL_STATE.INITIALIZING)
46
+ ) {
43
47
  return true;
44
48
  }
45
49
 
@@ -8,7 +8,7 @@ const HostUtils: any = {};
8
8
  HostUtils.parse = (host: object) => {
9
9
  if (host) {
10
10
  return {
11
- hostId: HostUtils.getId(host)
11
+ hostId: HostUtils.getId(host),
12
12
  };
13
13
  }
14
14
 
@@ -30,8 +30,9 @@ HostUtils.getHosts = (oldHost: object, newHost: object) => {
30
30
  previous,
31
31
  current,
32
32
  updates: {
33
- isNewHost: previous && current ? HostUtils.isDifferentHosts(previous.hostId, current.hostId) : true
34
- }
33
+ isNewHost:
34
+ previous && current ? HostUtils.isDifferentHosts(previous.hostId, current.hostId) : true,
35
+ },
35
36
  };
36
37
  };
37
38