@webex/plugin-meetings 3.0.0-beta.12 → 3.0.0-beta.120

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