@webex/plugin-meetings 3.0.0-beta.31 → 3.0.0-beta.310

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 (378) hide show
  1. package/README.md +46 -8
  2. package/dist/annotation/annotation.types.js +7 -0
  3. package/dist/annotation/annotation.types.js.map +1 -0
  4. package/dist/annotation/constants.js +49 -0
  5. package/dist/annotation/constants.js.map +1 -0
  6. package/dist/annotation/index.js +342 -0
  7. package/dist/annotation/index.js.map +1 -0
  8. package/dist/breakouts/breakout.js +94 -15
  9. package/dist/breakouts/breakout.js.map +1 -1
  10. package/dist/breakouts/edit-lock-error.js +52 -0
  11. package/dist/breakouts/edit-lock-error.js.map +1 -0
  12. package/dist/breakouts/events.js +45 -0
  13. package/dist/breakouts/events.js.map +1 -0
  14. package/dist/breakouts/index.js +709 -35
  15. package/dist/breakouts/index.js.map +1 -1
  16. package/dist/breakouts/utils.js +45 -1
  17. package/dist/breakouts/utils.js.map +1 -1
  18. package/dist/common/errors/no-meeting-info.js +51 -0
  19. package/dist/common/errors/no-meeting-info.js.map +1 -0
  20. package/dist/common/errors/reclaim-host-role-errors.js +158 -0
  21. package/dist/common/errors/reclaim-host-role-errors.js.map +1 -0
  22. package/dist/common/errors/webex-errors.js +48 -7
  23. package/dist/common/errors/webex-errors.js.map +1 -1
  24. package/dist/common/logs/logger-proxy.js +1 -1
  25. package/dist/common/logs/logger-proxy.js.map +1 -1
  26. package/dist/common/logs/request.js +5 -1
  27. package/dist/common/logs/request.js.map +1 -1
  28. package/dist/common/queue.js +24 -9
  29. package/dist/common/queue.js.map +1 -1
  30. package/dist/config.js +5 -11
  31. package/dist/config.js.map +1 -1
  32. package/dist/constants.js +233 -29
  33. package/dist/constants.js.map +1 -1
  34. package/dist/controls-options-manager/enums.js +14 -2
  35. package/dist/controls-options-manager/enums.js.map +1 -1
  36. package/dist/controls-options-manager/index.js +109 -15
  37. package/dist/controls-options-manager/index.js.map +1 -1
  38. package/dist/controls-options-manager/types.js +7 -0
  39. package/dist/controls-options-manager/types.js.map +1 -0
  40. package/dist/controls-options-manager/util.js +309 -18
  41. package/dist/controls-options-manager/util.js.map +1 -1
  42. package/dist/index.js +112 -1
  43. package/dist/index.js.map +1 -1
  44. package/dist/interpretation/collection.js +23 -0
  45. package/dist/interpretation/collection.js.map +1 -0
  46. package/dist/interpretation/index.js +366 -0
  47. package/dist/interpretation/index.js.map +1 -0
  48. package/dist/interpretation/siLanguage.js +25 -0
  49. package/dist/interpretation/siLanguage.js.map +1 -0
  50. package/dist/locus-info/controlsUtils.js +91 -2
  51. package/dist/locus-info/controlsUtils.js.map +1 -1
  52. package/dist/locus-info/index.js +383 -62
  53. package/dist/locus-info/index.js.map +1 -1
  54. package/dist/locus-info/infoUtils.js +7 -1
  55. package/dist/locus-info/infoUtils.js.map +1 -1
  56. package/dist/locus-info/mediaSharesUtils.js +57 -1
  57. package/dist/locus-info/mediaSharesUtils.js.map +1 -1
  58. package/dist/locus-info/parser.js +249 -72
  59. package/dist/locus-info/parser.js.map +1 -1
  60. package/dist/locus-info/selfUtils.js +89 -14
  61. package/dist/locus-info/selfUtils.js.map +1 -1
  62. package/dist/media/index.js +61 -116
  63. package/dist/media/index.js.map +1 -1
  64. package/dist/media/properties.js +73 -124
  65. package/dist/media/properties.js.map +1 -1
  66. package/dist/meeting/in-meeting-actions.js +82 -2
  67. package/dist/meeting/in-meeting-actions.js.map +1 -1
  68. package/dist/meeting/index.js +3777 -2929
  69. package/dist/meeting/index.js.map +1 -1
  70. package/dist/meeting/locusMediaRequest.js +292 -0
  71. package/dist/meeting/locusMediaRequest.js.map +1 -0
  72. package/dist/meeting/muteState.js +230 -124
  73. package/dist/meeting/muteState.js.map +1 -1
  74. package/dist/meeting/request.js +260 -196
  75. package/dist/meeting/request.js.map +1 -1
  76. package/dist/meeting/util.js +601 -417
  77. package/dist/meeting/util.js.map +1 -1
  78. package/dist/meeting-info/index.js +73 -7
  79. package/dist/meeting-info/index.js.map +1 -1
  80. package/dist/meeting-info/meeting-info-v2.js +192 -51
  81. package/dist/meeting-info/meeting-info-v2.js.map +1 -1
  82. package/dist/meeting-info/util.js +1 -1
  83. package/dist/meeting-info/util.js.map +1 -1
  84. package/dist/meeting-info/utilv2.js +36 -36
  85. package/dist/meeting-info/utilv2.js.map +1 -1
  86. package/dist/meetings/collection.js +39 -0
  87. package/dist/meetings/collection.js.map +1 -1
  88. package/dist/meetings/index.js +415 -115
  89. package/dist/meetings/index.js.map +1 -1
  90. package/dist/meetings/meetings.types.js +7 -0
  91. package/dist/meetings/meetings.types.js.map +1 -0
  92. package/dist/meetings/request.js +2 -0
  93. package/dist/meetings/request.js.map +1 -1
  94. package/dist/meetings/util.js +72 -6
  95. package/dist/meetings/util.js.map +1 -1
  96. package/dist/member/index.js +58 -0
  97. package/dist/member/index.js.map +1 -1
  98. package/dist/member/types.js +25 -0
  99. package/dist/member/types.js.map +1 -0
  100. package/dist/member/util.js +132 -25
  101. package/dist/member/util.js.map +1 -1
  102. package/dist/members/collection.js +10 -0
  103. package/dist/members/collection.js.map +1 -1
  104. package/dist/members/index.js +102 -6
  105. package/dist/members/index.js.map +1 -1
  106. package/dist/members/request.js +106 -38
  107. package/dist/members/request.js.map +1 -1
  108. package/dist/members/types.js +15 -0
  109. package/dist/members/types.js.map +1 -0
  110. package/dist/members/util.js +326 -232
  111. package/dist/members/util.js.map +1 -1
  112. package/dist/metrics/constants.js +13 -5
  113. package/dist/metrics/constants.js.map +1 -1
  114. package/dist/metrics/index.js +1 -468
  115. package/dist/metrics/index.js.map +1 -1
  116. package/dist/multistream/mediaRequestManager.js +238 -49
  117. package/dist/multistream/mediaRequestManager.js.map +1 -1
  118. package/dist/multistream/receiveSlot.js +29 -16
  119. package/dist/multistream/receiveSlot.js.map +1 -1
  120. package/dist/multistream/receiveSlotManager.js +39 -36
  121. package/dist/multistream/receiveSlotManager.js.map +1 -1
  122. package/dist/multistream/remoteMedia.js +44 -18
  123. package/dist/multistream/remoteMedia.js.map +1 -1
  124. package/dist/multistream/remoteMediaGroup.js +60 -3
  125. package/dist/multistream/remoteMediaGroup.js.map +1 -1
  126. package/dist/multistream/remoteMediaManager.js +209 -59
  127. package/dist/multistream/remoteMediaManager.js.map +1 -1
  128. package/dist/multistream/sendSlotManager.js +233 -0
  129. package/dist/multistream/sendSlotManager.js.map +1 -0
  130. package/dist/reachability/index.js +225 -59
  131. package/dist/reachability/index.js.map +1 -1
  132. package/dist/reachability/request.js +17 -8
  133. package/dist/reachability/request.js.map +1 -1
  134. package/dist/reconnection-manager/index.js +201 -156
  135. package/dist/reconnection-manager/index.js.map +1 -1
  136. package/dist/recording-controller/index.js +21 -2
  137. package/dist/recording-controller/index.js.map +1 -1
  138. package/dist/recording-controller/util.js +9 -8
  139. package/dist/recording-controller/util.js.map +1 -1
  140. package/dist/roap/index.js +62 -32
  141. package/dist/roap/index.js.map +1 -1
  142. package/dist/roap/request.js +112 -97
  143. package/dist/roap/request.js.map +1 -1
  144. package/dist/roap/turnDiscovery.js +95 -36
  145. package/dist/roap/turnDiscovery.js.map +1 -1
  146. package/dist/rtcMetrics/constants.js +12 -0
  147. package/dist/rtcMetrics/constants.js.map +1 -0
  148. package/dist/rtcMetrics/index.js +117 -0
  149. package/dist/rtcMetrics/index.js.map +1 -0
  150. package/dist/statsAnalyzer/index.js +86 -78
  151. package/dist/statsAnalyzer/index.js.map +1 -1
  152. package/dist/statsAnalyzer/mqaUtil.js +11 -10
  153. package/dist/statsAnalyzer/mqaUtil.js.map +1 -1
  154. package/dist/types/annotation/annotation.types.d.ts +42 -0
  155. package/dist/types/annotation/constants.d.ts +31 -0
  156. package/dist/types/annotation/index.d.ts +117 -0
  157. package/dist/types/breakouts/edit-lock-error.d.ts +15 -0
  158. package/dist/types/breakouts/events.d.ts +8 -0
  159. package/dist/types/breakouts/utils.d.ts +14 -0
  160. package/dist/types/common/errors/no-meeting-info.d.ts +14 -0
  161. package/dist/types/common/errors/reclaim-host-role-errors.d.ts +60 -0
  162. package/dist/types/common/errors/webex-errors.d.ts +25 -1
  163. package/dist/types/common/logs/request.d.ts +2 -0
  164. package/dist/types/common/queue.d.ts +9 -7
  165. package/dist/types/config.d.ts +1 -7
  166. package/dist/types/constants.d.ts +194 -24
  167. package/dist/types/controls-options-manager/enums.d.ts +11 -1
  168. package/dist/types/controls-options-manager/index.d.ts +17 -1
  169. package/dist/types/controls-options-manager/types.d.ts +43 -0
  170. package/dist/types/controls-options-manager/util.d.ts +1 -7
  171. package/dist/types/index.d.ts +6 -4
  172. package/dist/types/interpretation/collection.d.ts +5 -0
  173. package/dist/types/interpretation/index.d.ts +5 -0
  174. package/dist/types/interpretation/siLanguage.d.ts +5 -0
  175. package/dist/types/locus-info/index.d.ts +57 -4
  176. package/dist/types/locus-info/parser.d.ts +67 -6
  177. package/dist/types/media/index.d.ts +2 -0
  178. package/dist/types/media/properties.d.ts +34 -48
  179. package/dist/types/meeting/in-meeting-actions.d.ts +82 -2
  180. package/dist/types/meeting/index.d.ts +463 -510
  181. package/dist/types/meeting/locusMediaRequest.d.ts +74 -0
  182. package/dist/types/meeting/muteState.d.ts +99 -23
  183. package/dist/types/meeting/request.d.ts +72 -43
  184. package/dist/types/meeting/util.d.ts +101 -1
  185. package/dist/types/meeting-info/index.d.ts +13 -1
  186. package/dist/types/meeting-info/meeting-info-v2.d.ts +31 -1
  187. package/dist/types/meetings/collection.d.ts +17 -0
  188. package/dist/types/meetings/index.d.ts +98 -20
  189. package/dist/types/meetings/meetings.types.d.ts +4 -0
  190. package/dist/types/member/index.d.ts +14 -0
  191. package/dist/types/member/types.d.ts +32 -0
  192. package/dist/types/members/collection.d.ts +5 -0
  193. package/dist/types/members/index.d.ts +35 -2
  194. package/dist/types/members/request.d.ts +73 -9
  195. package/dist/types/members/types.d.ts +25 -0
  196. package/dist/types/members/util.d.ts +214 -1
  197. package/dist/types/metrics/constants.d.ts +12 -4
  198. package/dist/types/metrics/index.d.ts +4 -119
  199. package/dist/types/multistream/mediaRequestManager.d.ts +73 -5
  200. package/dist/types/multistream/receiveSlot.d.ts +13 -11
  201. package/dist/types/multistream/receiveSlotManager.d.ts +14 -4
  202. package/dist/types/multistream/remoteMedia.d.ts +8 -29
  203. package/dist/types/multistream/remoteMediaGroup.d.ts +0 -9
  204. package/dist/types/multistream/remoteMediaManager.d.ts +46 -2
  205. package/dist/types/multistream/sendSlotManager.d.ts +61 -0
  206. package/dist/types/reachability/index.d.ts +61 -7
  207. package/dist/types/reachability/request.d.ts +7 -3
  208. package/dist/types/reconnection-manager/index.d.ts +9 -0
  209. package/dist/types/recording-controller/index.d.ts +15 -1
  210. package/dist/types/recording-controller/util.d.ts +5 -4
  211. package/dist/types/roap/index.d.ts +2 -1
  212. package/dist/types/roap/request.d.ts +15 -11
  213. package/dist/types/roap/turnDiscovery.d.ts +21 -3
  214. package/dist/types/rtcMetrics/constants.d.ts +4 -0
  215. package/dist/types/rtcMetrics/index.d.ts +47 -0
  216. package/dist/types/statsAnalyzer/index.d.ts +7 -1
  217. package/dist/types/webinar/collection.d.ts +16 -0
  218. package/dist/types/webinar/index.d.ts +5 -0
  219. package/dist/webinar/collection.js +44 -0
  220. package/dist/webinar/collection.js.map +1 -0
  221. package/dist/webinar/index.js +69 -0
  222. package/dist/webinar/index.js.map +1 -0
  223. package/package.json +23 -20
  224. package/src/annotation/annotation.types.ts +50 -0
  225. package/src/annotation/constants.ts +36 -0
  226. package/src/annotation/index.ts +328 -0
  227. package/src/breakouts/README.md +42 -12
  228. package/src/breakouts/breakout.ts +67 -9
  229. package/src/breakouts/edit-lock-error.ts +25 -0
  230. package/src/breakouts/events.ts +56 -0
  231. package/src/breakouts/index.ts +592 -20
  232. package/src/breakouts/utils.ts +42 -0
  233. package/src/common/errors/no-meeting-info.ts +24 -0
  234. package/src/common/errors/reclaim-host-role-errors.ts +134 -0
  235. package/src/common/errors/webex-errors.ts +44 -2
  236. package/src/common/logs/logger-proxy.ts +1 -1
  237. package/src/common/logs/request.ts +5 -1
  238. package/src/common/queue.ts +22 -8
  239. package/src/config.ts +4 -10
  240. package/src/constants.ts +221 -19
  241. package/src/controls-options-manager/enums.ts +12 -0
  242. package/src/controls-options-manager/index.ts +116 -21
  243. package/src/controls-options-manager/types.ts +59 -0
  244. package/src/controls-options-manager/util.ts +294 -14
  245. package/src/index.ts +40 -0
  246. package/src/interpretation/README.md +60 -0
  247. package/src/interpretation/collection.ts +19 -0
  248. package/src/interpretation/index.ts +332 -0
  249. package/src/interpretation/siLanguage.ts +18 -0
  250. package/src/locus-info/controlsUtils.ts +108 -0
  251. package/src/locus-info/index.ts +413 -59
  252. package/src/locus-info/infoUtils.ts +10 -2
  253. package/src/locus-info/mediaSharesUtils.ts +64 -0
  254. package/src/locus-info/parser.ts +258 -47
  255. package/src/locus-info/selfUtils.ts +81 -5
  256. package/src/media/index.ts +102 -122
  257. package/src/media/properties.ts +87 -110
  258. package/src/meeting/in-meeting-actions.ts +163 -3
  259. package/src/meeting/index.ts +3132 -2541
  260. package/src/meeting/locusMediaRequest.ts +313 -0
  261. package/src/meeting/muteState.ts +229 -131
  262. package/src/meeting/request.ts +177 -121
  263. package/src/meeting/util.ts +588 -394
  264. package/src/meeting-info/index.ts +81 -8
  265. package/src/meeting-info/meeting-info-v2.ts +170 -14
  266. package/src/meeting-info/util.ts +1 -1
  267. package/src/meeting-info/utilv2.ts +23 -23
  268. package/src/meetings/collection.ts +33 -0
  269. package/src/meetings/index.ts +445 -123
  270. package/src/meetings/meetings.types.ts +12 -0
  271. package/src/meetings/request.ts +2 -0
  272. package/src/meetings/util.ts +80 -11
  273. package/src/member/index.ts +58 -0
  274. package/src/member/types.ts +38 -0
  275. package/src/member/util.ts +141 -25
  276. package/src/members/collection.ts +8 -0
  277. package/src/members/index.ts +134 -8
  278. package/src/members/request.ts +97 -17
  279. package/src/members/types.ts +29 -0
  280. package/src/members/util.ts +333 -240
  281. package/src/metrics/constants.ts +12 -4
  282. package/src/metrics/index.ts +1 -490
  283. package/src/multistream/mediaRequestManager.ts +289 -79
  284. package/src/multistream/receiveSlot.ts +31 -17
  285. package/src/multistream/receiveSlotManager.ts +34 -24
  286. package/src/multistream/remoteMedia.ts +27 -2
  287. package/src/multistream/remoteMediaGroup.ts +59 -0
  288. package/src/multistream/remoteMediaManager.ts +148 -30
  289. package/src/multistream/sendSlotManager.ts +170 -0
  290. package/src/reachability/index.ts +228 -37
  291. package/src/reachability/request.ts +17 -8
  292. package/src/reconnection-manager/index.ts +83 -56
  293. package/src/recording-controller/index.ts +20 -3
  294. package/src/recording-controller/util.ts +26 -9
  295. package/src/roap/index.ts +63 -32
  296. package/src/roap/request.ts +100 -104
  297. package/src/roap/turnDiscovery.ts +48 -26
  298. package/src/rtcMetrics/constants.ts +3 -0
  299. package/src/rtcMetrics/index.ts +100 -0
  300. package/src/statsAnalyzer/index.ts +105 -91
  301. package/src/statsAnalyzer/mqaUtil.ts +13 -14
  302. package/src/webinar/collection.ts +31 -0
  303. package/src/webinar/index.ts +62 -0
  304. package/test/integration/spec/converged-space-meetings.js +60 -3
  305. package/test/integration/spec/journey.js +320 -261
  306. package/test/integration/spec/space-meeting.js +76 -3
  307. package/test/unit/spec/annotation/index.ts +418 -0
  308. package/test/unit/spec/breakouts/breakout.ts +118 -28
  309. package/test/unit/spec/breakouts/edit-lock-error.ts +30 -0
  310. package/test/unit/spec/breakouts/events.ts +89 -0
  311. package/test/unit/spec/breakouts/index.ts +1395 -69
  312. package/test/unit/spec/breakouts/utils.js +52 -1
  313. package/test/unit/spec/common/queue.js +31 -2
  314. package/test/unit/spec/controls-options-manager/index.js +163 -0
  315. package/test/unit/spec/controls-options-manager/util.js +576 -60
  316. package/test/unit/spec/fixture/locus.js +1 -0
  317. package/test/unit/spec/interpretation/collection.ts +15 -0
  318. package/test/unit/spec/interpretation/index.ts +589 -0
  319. package/test/unit/spec/interpretation/siLanguage.ts +28 -0
  320. package/test/unit/spec/locus-info/controlsUtils.js +316 -43
  321. package/test/unit/spec/locus-info/index.js +1304 -33
  322. package/test/unit/spec/locus-info/infoUtils.js +37 -15
  323. package/test/unit/spec/locus-info/lib/SeqCmp.json +16 -0
  324. package/test/unit/spec/locus-info/mediaSharesUtils.ts +32 -0
  325. package/test/unit/spec/locus-info/parser.js +116 -35
  326. package/test/unit/spec/locus-info/selfConstant.js +27 -4
  327. package/test/unit/spec/locus-info/selfUtils.js +208 -17
  328. package/test/unit/spec/media/index.ts +104 -37
  329. package/test/unit/spec/media/properties.ts +2 -2
  330. package/test/unit/spec/meeting/in-meeting-actions.ts +81 -3
  331. package/test/unit/spec/meeting/index.js +5216 -1956
  332. package/test/unit/spec/meeting/locusMediaRequest.ts +442 -0
  333. package/test/unit/spec/meeting/muteState.js +408 -208
  334. package/test/unit/spec/meeting/request.js +483 -49
  335. package/test/unit/spec/meeting/utils.js +679 -64
  336. package/test/unit/spec/meeting-info/index.js +300 -0
  337. package/test/unit/spec/meeting-info/meetinginfov2.js +526 -5
  338. package/test/unit/spec/meeting-info/utilv2.js +21 -0
  339. package/test/unit/spec/meetings/collection.js +26 -0
  340. package/test/unit/spec/meetings/index.js +1011 -205
  341. package/test/unit/spec/meetings/utils.js +202 -2
  342. package/test/unit/spec/member/index.js +61 -6
  343. package/test/unit/spec/member/util.js +510 -34
  344. package/test/unit/spec/members/index.js +432 -1
  345. package/test/unit/spec/members/request.js +206 -27
  346. package/test/unit/spec/members/utils.js +210 -0
  347. package/test/unit/spec/metrics/index.js +1 -50
  348. package/test/unit/spec/multistream/mediaRequestManager.ts +803 -162
  349. package/test/unit/spec/multistream/receiveSlot.ts +28 -20
  350. package/test/unit/spec/multistream/receiveSlotManager.ts +32 -30
  351. package/test/unit/spec/multistream/remoteMedia.ts +30 -0
  352. package/test/unit/spec/multistream/remoteMediaGroup.ts +266 -0
  353. package/test/unit/spec/multistream/remoteMediaManager.ts +326 -0
  354. package/test/unit/spec/multistream/sendSlotManager.ts +242 -0
  355. package/test/unit/spec/reachability/index.ts +549 -9
  356. package/test/unit/spec/reachability/request.js +68 -0
  357. package/test/unit/spec/reconnection-manager/index.js +85 -9
  358. package/test/unit/spec/recording-controller/index.js +294 -218
  359. package/test/unit/spec/recording-controller/util.js +223 -96
  360. package/test/unit/spec/roap/index.ts +178 -64
  361. package/test/unit/spec/roap/request.ts +203 -85
  362. package/test/unit/spec/roap/turnDiscovery.ts +82 -36
  363. package/test/unit/spec/rtcMetrics/index.ts +73 -0
  364. package/test/unit/spec/stats-analyzer/index.js +136 -2
  365. package/test/unit/spec/webinar/collection.ts +13 -0
  366. package/test/unit/spec/webinar/index.ts +60 -0
  367. package/test/utils/integrationTestUtils.js +46 -0
  368. package/test/utils/testUtils.js +0 -52
  369. package/dist/meeting/effectsState.js +0 -262
  370. package/dist/meeting/effectsState.js.map +0 -1
  371. package/dist/metrics/config.js +0 -299
  372. package/dist/metrics/config.js.map +0 -1
  373. package/dist/types/meeting/effectsState.d.ts +0 -42
  374. package/dist/types/metrics/config.d.ts +0 -178
  375. package/src/index.js +0 -16
  376. package/src/meeting/effectsState.ts +0 -211
  377. package/src/metrics/config.ts +0 -495
  378. package/test/unit/spec/meeting/effectsState.js +0 -285
@@ -5,11 +5,13 @@ import {WebexPlugin} from '@webex/webex-core';
5
5
  import {debounce, forEach} from 'lodash';
6
6
  import LoggerProxy from '../common/logs/logger-proxy';
7
7
 
8
- import {BREAKOUTS, HTTP_VERBS, MEETINGS} from '../constants';
8
+ import {BREAKOUTS, MEETINGS, HTTP_VERBS, _ID_} from '../constants';
9
9
 
10
10
  import Breakout from './breakout';
11
11
  import BreakoutCollection from './collection';
12
12
  import BreakoutRequest from './request';
13
+ import breakoutEvent from './events';
14
+ import {boServiceErrorHandler, isSessionTypeChangedFromSessionToMain} from './utils';
13
15
 
14
16
  /**
15
17
  * @class Breakouts
@@ -25,6 +27,7 @@ const Breakouts = WebexPlugin.extend({
25
27
  allowBackToMain: 'boolean', // only present when in a breakout session
26
28
  delayCloseTime: 'number', // appears once breakouts start
27
29
  enableBreakoutSession: 'boolean', // appears from the moment you enable breakouts
30
+ hasBreakoutPreAssignments: 'boolean', // appears from the moment you enable breakouts
28
31
  groupId: 'string', // appears from the moment you enable breakouts
29
32
  name: 'string', // only present when in a breakout session
30
33
  sessionId: 'string', // appears from the moment you enable breakouts
@@ -33,15 +36,23 @@ const Breakouts = WebexPlugin.extend({
33
36
  status: 'string', // only present when in a breakout session
34
37
  url: 'string', // appears from the moment you enable breakouts
35
38
  locusUrl: 'string', // the current locus url
36
- breakoutServiceUrl: 'string', // the current breakout resouce url
39
+ breakoutServiceUrl: 'string', // the current breakout resource url
40
+ mainLocusUrl: 'string', // the locus url of the main session
41
+ groups: 'array', // appears when create breakouts
42
+ manageGroups: 'array', // appears when manage breakouts
43
+ preAssignments: 'array', // appears when getPreAssignments info hasBreakoutPreAssignments = true
44
+ editLock: 'object', // appears when getBreakout info editlock = true
45
+ intervalID: 'number',
46
+ meetingId: 'string',
47
+ canManageBreakouts: 'boolean', // appear the ability to manage breakouts
37
48
  },
38
-
39
49
  children: {
40
50
  currentBreakoutSession: Breakout,
41
51
  },
42
52
 
43
53
  derived: {
44
54
  isInMainSession: {
55
+ cache: false,
45
56
  deps: ['sessionType'],
46
57
  /**
47
58
  * Returns true if the user is in the main session
@@ -51,6 +62,63 @@ const Breakouts = WebexPlugin.extend({
51
62
  return this.sessionType === BREAKOUTS.SESSION_TYPES.MAIN;
52
63
  },
53
64
  },
65
+ isActiveBreakout: {
66
+ cache: false, // fix issue: sometimes the derived will not change even if the deps changed
67
+ deps: ['sessionType', 'status'],
68
+ /**
69
+ * Returns true if the breakout status is active
70
+ * @returns {boolean}
71
+ */
72
+ fn() {
73
+ return (
74
+ this.sessionType === BREAKOUTS.SESSION_TYPES.BREAKOUT &&
75
+ (this.status === BREAKOUTS.STATUS.OPEN || this.status === BREAKOUTS.STATUS.CLOSING)
76
+ );
77
+ },
78
+ },
79
+ breakoutGroupId: {
80
+ cache: false,
81
+ deps: ['manageGroups'],
82
+ /**
83
+ * Returns the active group id
84
+ * @returns {boolean}
85
+ */
86
+ fn() {
87
+ if (this.manageGroups?.length) {
88
+ return this.manageGroups[0].status !== BREAKOUTS.STATUS.CLOSED
89
+ ? this.manageGroups[0].id
90
+ : '';
91
+ }
92
+
93
+ return '';
94
+ },
95
+ },
96
+ breakoutStatus: {
97
+ cache: true,
98
+ deps: ['isInMainSession', 'status', 'groups'],
99
+ /**
100
+ * Returns the breakout status
101
+ * @returns {boolean}
102
+ */
103
+ fn() {
104
+ return this.isInMainSession ? this.groups?.[0]?.status : this.status;
105
+ },
106
+ },
107
+ shouldQueryPreAssignments: {
108
+ cache: false,
109
+ deps: ['canManageBreakouts', 'enableBreakoutSession', 'hasBreakoutPreAssignments'],
110
+ /**
111
+ * Returns should query preAssignments or not
112
+ * @returns {boolean}
113
+ */
114
+ fn() {
115
+ return !!(
116
+ this.canManageBreakouts &&
117
+ this.enableBreakoutSession &&
118
+ this.hasBreakoutPreAssignments
119
+ );
120
+ },
121
+ },
54
122
  },
55
123
 
56
124
  /**
@@ -58,20 +126,31 @@ const Breakouts = WebexPlugin.extend({
58
126
  * @returns {void}
59
127
  */
60
128
  initialize() {
61
- this.listenTo(this, 'change:status', () => {
62
- if (this.status === BREAKOUTS.STATUS.CLOSING) {
129
+ this.listenTo(this, 'change:breakoutStatus', () => {
130
+ if (this.breakoutStatus === BREAKOUTS.STATUS.CLOSING) {
63
131
  this.trigger(BREAKOUTS.EVENTS.BREAKOUTS_CLOSING);
64
132
  }
65
133
  });
134
+ this.listenTo(this, 'change:shouldQueryPreAssignments', () => {
135
+ if (this.shouldQueryPreAssignments && !this.preAssignments) {
136
+ this.queryPreAssignments();
137
+ }
138
+ });
66
139
  this.debouncedQueryRosters = debounce(this.queryRosters, 10, {
67
140
  leading: true,
68
141
  trailing: false,
69
142
  });
70
- this.listenTo(this.breakouts, 'add', () => {
143
+ this.listenTo(this.breakouts, 'add', (breakout) => {
71
144
  this.debouncedQueryRosters();
145
+ this.triggerReturnToMainEvent(breakout);
146
+ });
147
+ this.listenTo(this.breakouts, 'change:requestedLastModifiedTime', (breakout) => {
148
+ this.triggerReturnToMainEvent(breakout);
72
149
  });
150
+ this.listenToCurrentSessionTypeChange();
73
151
  this.listenToBroadcastMessages();
74
152
  this.listenToBreakoutRosters();
153
+ this.listenToBreakoutHelp();
75
154
  // @ts-ignore
76
155
  this.breakoutRequest = new BreakoutRequest({webex: this.webex});
77
156
  },
@@ -91,10 +170,23 @@ const Breakouts = WebexPlugin.extend({
91
170
  */
92
171
  locusUrlUpdate(locusUrl) {
93
172
  this.set('locusUrl', locusUrl);
173
+ const {isInMainSession, mainLocusUrl} = this;
174
+ if (isInMainSession || !mainLocusUrl) {
175
+ this.set('mainLocusUrl', locusUrl);
176
+ }
177
+ },
178
+
179
+ /**
180
+ * Update whether self is moderator/cohost or not
181
+ * @param {boolean} canManageBreakouts
182
+ * @returns {void}
183
+ */
184
+ updateCanManageBreakouts(canManageBreakouts) {
185
+ this.set('canManageBreakouts', canManageBreakouts);
94
186
  },
95
187
 
96
188
  /**
97
- * Update the current breakout resouce url
189
+ * Update the current breakout resource url
98
190
  * @param {string} breakoutServiceUrl
99
191
  * @returns {void}
100
192
  */
@@ -115,7 +207,7 @@ const Breakouts = WebexPlugin.extend({
115
207
  body: {rosters},
116
208
  } = result;
117
209
 
118
- rosters.forEach(({locus}) => {
210
+ rosters?.forEach(({locus}) => {
119
211
  this.handleRosterUpdate(locus);
120
212
  });
121
213
 
@@ -142,6 +234,21 @@ const Breakouts = WebexPlugin.extend({
142
234
 
143
235
  session.parseRoster(locus);
144
236
  },
237
+ /**
238
+ *Sets up listener for currentBreakoutSession sessionType changed
239
+ * @returns {void}
240
+ */
241
+ listenToCurrentSessionTypeChange(): void {
242
+ this.listenTo(
243
+ this.currentBreakoutSession,
244
+ 'change:sessionType',
245
+ (currentBreakoutSession, sessionType) => {
246
+ if (isSessionTypeChangedFromSessionToMain(currentBreakoutSession, sessionType)) {
247
+ this.trigger(BREAKOUTS.EVENTS.LEAVE_BREAKOUT);
248
+ }
249
+ }
250
+ );
251
+ },
145
252
 
146
253
  /**
147
254
  * Sets up listener for broadcast messages sent to the breakout session
@@ -176,6 +283,36 @@ const Breakouts = WebexPlugin.extend({
176
283
  });
177
284
  },
178
285
 
286
+ /**
287
+ * Sets up a listener for ask help notify from mecury
288
+ * @returns {void}
289
+ */
290
+ listenToBreakoutHelp() {
291
+ this.listenTo(this.webex.internal.mercury, 'event:breakout.help', (event) => {
292
+ const {
293
+ data: {participant, sessionId},
294
+ } = event;
295
+ this.trigger(BREAKOUTS.EVENTS.ASK_FOR_HELP, {participant, sessionId});
296
+ });
297
+ },
298
+
299
+ /**
300
+ * get current breakout is in progress or not
301
+ * @returns {boolean}
302
+ */
303
+ isBreakoutInProgress() {
304
+ const currentStatus = this.groups?.[0]?.status || this.status;
305
+
306
+ return currentStatus === BREAKOUTS.STATUS.OPEN || currentStatus === BREAKOUTS.STATUS.CLOSING;
307
+ },
308
+
309
+ /**
310
+ * get current breakout is in closing or not
311
+ * @returns {boolean}
312
+ */
313
+ isBreakoutIClosing() {
314
+ return (this.groups?.[0]?.status || this.status) === BREAKOUTS.STATUS.CLOSING;
315
+ },
179
316
  /**
180
317
  * Updates the information about the current breakout
181
318
  * @param {Object} params
@@ -183,6 +320,10 @@ const Breakouts = WebexPlugin.extend({
183
320
  */
184
321
  updateBreakout(params) {
185
322
  this.set(params);
323
+ // These values are set manually so they are unset when they are not included in params
324
+ this.set('groups', params.groups);
325
+ this.set('startTime', params.startTime);
326
+ this.set('status', params.status);
186
327
 
187
328
  this.set('currentBreakoutSession', {
188
329
  sessionId: params.sessionId,
@@ -193,12 +334,31 @@ const Breakouts = WebexPlugin.extend({
193
334
  url: params.url,
194
335
  [BREAKOUTS.SESSION_STATES.ACTIVE]: false,
195
336
  [BREAKOUTS.SESSION_STATES.ALLOWED]: false,
196
- [BREAKOUTS.SESSION_STATES.ALLOWED]: false,
337
+ [BREAKOUTS.SESSION_STATES.ASSIGNED]: false,
197
338
  [BREAKOUTS.SESSION_STATES.ASSIGNED_CURRENT]: false,
198
339
  [BREAKOUTS.SESSION_STATES.REQUESTED]: false,
199
340
  });
200
341
 
201
- this.set('enableBreakoutSession', params.enableBreakoutSession);
342
+ if (!this.isBreakoutInProgress()) {
343
+ this.clearBreakouts();
344
+ }
345
+
346
+ if (
347
+ this.currentBreakoutSession.previous('sessionId') !== this.currentBreakoutSession.sessionId ||
348
+ this.currentBreakoutSession.previous('groupId') !== this.currentBreakoutSession.groupId
349
+ ) {
350
+ // should report joined session changed
351
+ const meeting = this.webex.meetings.getMeetingByType(_ID_, this.meetingId);
352
+ breakoutEvent.onBreakoutJoinResponse(
353
+ {
354
+ currentSession: this.currentBreakoutSession,
355
+ meeting,
356
+ breakoutMoveId: params.breakoutMoveId,
357
+ },
358
+ // @ts-ignore
359
+ this.webex.internal.newMetrics.submitClientEvent.bind(this.webex.internal.newMetrics)
360
+ );
361
+ }
202
362
  },
203
363
 
204
364
  /**
@@ -208,7 +368,12 @@ const Breakouts = WebexPlugin.extend({
208
368
  */
209
369
  updateBreakoutSessions(payload) {
210
370
  const breakouts = {};
211
-
371
+ if (this.isBreakoutIClosing()) {
372
+ // fix issue: don't clear/update breakouts collection when in closing since locus DTO will send undefined or
373
+ // only the MAIN session info here, if just update it, will miss the breakout roster info during
374
+ // count down to end breakouts
375
+ return;
376
+ }
212
377
  if (payload.breakoutSessions) {
213
378
  forEach(BREAKOUTS.SESSION_STATES, (state) => {
214
379
  forEach(payload.breakoutSessions[state], (breakout) => {
@@ -224,10 +389,13 @@ const Breakouts = WebexPlugin.extend({
224
389
  }
225
390
 
226
391
  breakouts[sessionId][state] = true;
392
+
393
+ if (state === BREAKOUTS.SESSION_STATES.REQUESTED) {
394
+ breakouts[sessionId].requestedLastModifiedTime = breakout.modifiedAt;
395
+ }
227
396
  });
228
397
  });
229
398
  }
230
-
231
399
  forEach(breakouts, (breakout: typeof Breakout) => {
232
400
  // eslint-disable-next-line no-param-reassign
233
401
  breakout.url = this.url;
@@ -235,6 +403,15 @@ const Breakouts = WebexPlugin.extend({
235
403
 
236
404
  this.breakouts.set(Object.values(breakouts));
237
405
  },
406
+ /**
407
+ * clear breakouts collection
408
+ * @returns {void}
409
+ */
410
+ clearBreakouts() {
411
+ if (this.breakouts.length > 0) {
412
+ this.breakouts.reset();
413
+ }
414
+ },
238
415
  /**
239
416
  * get main session
240
417
  * @returns {Breakout}
@@ -275,9 +452,7 @@ const Breakouts = WebexPlugin.extend({
275
452
  * @returns {Promise}
276
453
  */
277
454
  broadcast(message, options) {
278
- const breakoutGroupId = this.isInMainSession
279
- ? this.breakouts.filter((breakout) => !breakout.isMain)[0]?.groupId
280
- : this.groupId;
455
+ const {breakoutGroupId} = this;
281
456
  if (!breakoutGroupId) {
282
457
  throw new Error('Cannot broadcast, no breakout session found');
283
458
  }
@@ -316,16 +491,16 @@ const Breakouts = WebexPlugin.extend({
316
491
  },
317
492
 
318
493
  /**
319
- * Make the meeting enbale or disable breakout session
494
+ * Make the meeting enable or disable breakout session
320
495
  * @param {boolean} enable
321
496
  * @returns {Promise}
322
497
  */
323
498
  async toggleBreakout(enable) {
324
499
  if (this.enableBreakoutSession === undefined) {
325
500
  const info = await this.enableBreakouts();
501
+ // first time enable, set the initial data
502
+ this.updateBreakout(info?.body);
326
503
  if (!enable) {
327
- // if enable is false, updateBreakout set the param then set enableBreakoutSession as false
328
- this.updateBreakout(info.body);
329
504
  await this.doToggleBreakout(enable);
330
505
  }
331
506
  } else {
@@ -339,15 +514,412 @@ const Breakouts = WebexPlugin.extend({
339
514
  * @returns {Promise}
340
515
  */
341
516
  doToggleBreakout(enable) {
517
+ const body = {
518
+ ...(this.editLock && !!this.editLock.token ? {editlock: {token: this.editLock.token}} : {}),
519
+ ...{enableBreakoutSession: enable},
520
+ };
521
+
342
522
  // @ts-ignore
343
523
  return this.webex.request({
344
524
  method: HTTP_VERBS.PUT,
345
525
  uri: this.url,
346
- body: {
347
- enableBreakoutSession: enable,
526
+ body,
527
+ });
528
+ },
529
+
530
+ /**
531
+ * set groups to manageGroups prop
532
+ * @param {Object} breakoutInfo -- breakout groups
533
+ * @returns {void}
534
+ */
535
+ _setManageGroups(breakoutInfo) {
536
+ if (breakoutInfo?.body?.groups) {
537
+ this.set('manageGroups', breakoutInfo.body.groups);
538
+ }
539
+ },
540
+
541
+ /**
542
+ * Create new breakout sessions
543
+ * @param {object} params -- breakout session group
544
+ * @returns {Promise}
545
+ */
546
+ async create(params) {
547
+ const payload = {...params};
548
+ const body = {
549
+ ...(this.editLock && !!this.editLock.token ? {editlock: {token: this.editLock.token}} : {}),
550
+ ...{groups: [payload]},
551
+ };
552
+ // @ts-ignore
553
+ const breakoutInfo = await this.webex
554
+ .request({
555
+ method: HTTP_VERBS.PUT,
556
+ uri: this.url,
557
+ body,
558
+ })
559
+ .catch((error) => {
560
+ return Promise.reject(boServiceErrorHandler(error, 'Breakouts#create'));
561
+ });
562
+
563
+ this._setManageGroups(breakoutInfo);
564
+
565
+ // clear edit lock info after save breakout session info
566
+ this._clearEditLockInfo();
567
+
568
+ return breakoutInfo;
569
+ },
570
+
571
+ /**
572
+ * Delete all breakout sessions
573
+ * @returns {Promise}
574
+ */
575
+ async clearSessions() {
576
+ const body = {
577
+ ...(this.editLock && !!this.editLock.token ? {editlock: {token: this.editLock.token}} : {}),
578
+ ...{groups: [{action: BREAKOUTS.ACTION.DELETE}]},
579
+ };
580
+ // @ts-ignore
581
+ const breakoutInfo = await this.webex
582
+ .request({
583
+ method: HTTP_VERBS.PUT,
584
+ uri: this.url,
585
+ body,
586
+ })
587
+ .catch((error) => {
588
+ return Promise.reject(boServiceErrorHandler(error, 'Breakouts#clearSessions'));
589
+ });
590
+
591
+ this._setManageGroups(breakoutInfo);
592
+
593
+ return breakoutInfo;
594
+ },
595
+
596
+ /**
597
+ * Host or cohost starts breakout sessions
598
+ * @param {object} params
599
+ * @returns {Promise}
600
+ */
601
+ async start(params = {}) {
602
+ const action = BREAKOUTS.ACTION.START;
603
+ const payload = {
604
+ id: this.breakoutGroupId,
605
+ action,
606
+ allowBackToMain: false,
607
+ allowToJoinLater: false,
608
+ ...params,
609
+ };
610
+
611
+ const body = {
612
+ ...(this.editLock && !!this.editLock.token
613
+ ? {editlock: {token: this.editLock.token, refresh: true}}
614
+ : {}),
615
+ ...{groups: [payload]},
616
+ };
617
+
618
+ const breakoutInfo = await this.request({
619
+ method: HTTP_VERBS.PUT,
620
+ uri: this.url,
621
+ body,
622
+ }).catch((error) => {
623
+ return Promise.reject(boServiceErrorHandler(error, 'Breakouts#start'));
624
+ });
625
+
626
+ this._setManageGroups(breakoutInfo);
627
+
628
+ return breakoutInfo;
629
+ },
630
+
631
+ /**
632
+ * Host or cohost ends breakout sessions
633
+ * @param {object} params
634
+ * @returns {Promise}
635
+ */
636
+ async end(params = {}) {
637
+ const {delayCloseTime, breakoutGroupId: id} = this;
638
+ const action = BREAKOUTS.ACTION.CLOSE;
639
+ const payload = {
640
+ id,
641
+ action,
642
+ delayCloseTime,
643
+ ...params,
644
+ };
645
+
646
+ const body = {
647
+ ...(this.editLock && !!this.editLock.token
648
+ ? {editlock: {token: this.editLock.token, refresh: true}}
649
+ : {}),
650
+ ...{groups: [payload]},
651
+ };
652
+
653
+ const breakoutInfo = await this.request({
654
+ method: HTTP_VERBS.PUT,
655
+ uri: this.url,
656
+ body,
657
+ }).catch((error) => {
658
+ return Promise.reject(boServiceErrorHandler(error, 'Breakouts#end'));
659
+ });
660
+
661
+ this._setManageGroups(breakoutInfo);
662
+
663
+ return breakoutInfo;
664
+ },
665
+
666
+ /**
667
+ * Host or cohost update breakout sessions
668
+ * @param {Object} params
669
+ * @param {String} params.id
670
+ * @param {Boolean} unlockEdit
671
+ * @returns {Promise}
672
+ */
673
+ async update(params: {id: string}, unlockEdit?: boolean) {
674
+ if (!params.id) {
675
+ return Promise.reject(new Error('Missing breakout group id'));
676
+ }
677
+ const payload = {...params};
678
+
679
+ const body = {
680
+ ...(this.editLock?.token
681
+ ? {editlock: {token: this.editLock.token, refresh: !unlockEdit}}
682
+ : {}),
683
+ ...{groups: [payload]},
684
+ };
685
+
686
+ const breakoutInfo = await this.request({
687
+ method: HTTP_VERBS.PUT,
688
+ uri: this.url,
689
+ body,
690
+ }).catch((error) => {
691
+ return Promise.reject(boServiceErrorHandler(error, 'Breakouts#update'));
692
+ });
693
+
694
+ if (unlockEdit) {
695
+ this._clearEditLockInfo();
696
+ }
697
+
698
+ this._setManageGroups(breakoutInfo);
699
+
700
+ return breakoutInfo;
701
+ },
702
+
703
+ /**
704
+ * get existed breakout sessions
705
+ * @param {boolean} editlock -- lock operations of the breakout sessions
706
+ * @returns {Promise}
707
+ */
708
+ async getBreakout(editlock) {
709
+ const breakout = await this.request({
710
+ method: HTTP_VERBS.GET,
711
+ uri: this.url + (editlock ? `?editlock=${editlock}` : ''),
712
+ });
713
+
714
+ this._setManageGroups(breakout);
715
+ if (editlock && breakout.body?.editlock?.token) {
716
+ this.set('editLock', breakout.body.editlock);
717
+ this.keepEditLockAlive();
718
+ }
719
+
720
+ return breakout;
721
+ },
722
+
723
+ /**
724
+ * enable and edit lock breakout
725
+ * @returns {void}
726
+ */
727
+ async enableAndLockBreakout() {
728
+ if (this.enableBreakoutSession) {
729
+ this.lockBreakout();
730
+ } else {
731
+ const info = await this.enableBreakouts();
732
+
733
+ if (info.body) {
734
+ this.lockBreakout();
735
+ }
736
+ }
737
+ },
738
+
739
+ /**
740
+ * breakout edit locked by yourself or not
741
+ * @returns {boolean}
742
+ */
743
+ hasBreakoutLocked() {
744
+ return (
745
+ this.editLock &&
746
+ this.editLock.token &&
747
+ this.editLock.state === BREAKOUTS.EDIT_LOCK_STATUS.LOCKED
748
+ );
749
+ },
750
+
751
+ /**
752
+ * send breakout edit lock
753
+ * @returns {void}
754
+ */
755
+ async lockBreakout() {
756
+ if (this.editLock && !!this.editLock.token) {
757
+ if (this.editLock.state === BREAKOUTS.EDIT_LOCK_STATUS.LOCKED) {
758
+ throw new Error('Breakout already locked');
759
+ } else {
760
+ this.keepEditLockAlive();
761
+ }
762
+ } else {
763
+ const breakout = await this.getBreakout(true);
764
+ if (breakout.body?.editlock) {
765
+ this.keepEditLockAlive();
766
+ }
767
+ }
768
+ },
769
+
770
+ /**
771
+ * keep edit lock alive
772
+ * @returns {void}
773
+ */
774
+ keepEditLockAlive() {
775
+ if (this.editLock && !!this.editLock.token) {
776
+ const ttl = this.editLock.ttl < 30 ? BREAKOUTS.DEFAULT_TTL : this.editLock.ttl;
777
+ if (this.intervalID) {
778
+ window.clearInterval(this.intervalID);
779
+ }
780
+
781
+ this.intervalID = window.setInterval(() => {
782
+ this.request({
783
+ method: HTTP_VERBS.PUT,
784
+ uri: `${this.url}/editlock/${this.editLock.token}`,
785
+ }).catch((error) => {
786
+ this._clearEditLockInfo();
787
+
788
+ return Promise.reject(boServiceErrorHandler(error, 'Breakouts#keepEditLockAlive'));
789
+ });
790
+ }, (ttl / 2) * 1000);
791
+ }
792
+ },
793
+
794
+ /**
795
+ * unlock edit breakout
796
+ * @returns {void}
797
+ */
798
+ unLockEditBreakout() {
799
+ if (this.editLock && !!this.editLock.token) {
800
+ this.request({
801
+ method: HTTP_VERBS.DELETE,
802
+ uri: `${this.url}/editlock/${this.editLock.token}`,
803
+ })
804
+ .then(() => {
805
+ this._clearEditLockInfo();
806
+ })
807
+ .catch((error) => {
808
+ return Promise.reject(boServiceErrorHandler(error, 'Breakouts#unLockEditBreakout'));
809
+ });
810
+ }
811
+ },
812
+
813
+ /**
814
+ * clear interval and edit lock info
815
+ * @private
816
+ * @returns {void}
817
+ */
818
+ _clearEditLockInfo() {
819
+ if (this.intervalID) {
820
+ clearInterval(this.intervalID);
821
+ }
822
+ this.set('editLock', {});
823
+ },
824
+
825
+ /**
826
+ * assign participants to breakout session
827
+ * @param {Array} sessions
828
+ * @returns {void}
829
+ */
830
+ assign(sessions: any[]) {
831
+ const internalSessions = sessions.map((item) => {
832
+ return {
833
+ id: item.id,
834
+ assigned: item.memberIds,
835
+ assignedEmails: item.emails,
836
+ anyoneCanJoin: !!item.anyone,
837
+ };
838
+ });
839
+
840
+ const body = {
841
+ ...(this.editLock && !!this.editLock.token
842
+ ? {editlock: {token: this.editLock.token, refresh: true}}
843
+ : {}),
844
+ ...{
845
+ groups: [
846
+ {
847
+ id: this.breakoutGroupId,
848
+ sessions: internalSessions,
849
+ },
850
+ ],
348
851
  },
852
+ };
853
+
854
+ return this.request({
855
+ method: HTTP_VERBS.PUT,
856
+ uri: this.url,
857
+ body,
349
858
  });
350
859
  },
860
+
861
+ /**
862
+ * query preAssignments
863
+ * @returns {void}
864
+ */
865
+ queryPreAssignments() {
866
+ this.webex
867
+ .request({uri: `${this.url}/preassignments`, qs: {locusUrl: btoa(this.locusUrl)}})
868
+ .then((result) => {
869
+ if (result.body?.groups) {
870
+ this.set('preAssignments', result.body.groups);
871
+ this.trigger(BREAKOUTS.EVENTS.PRE_ASSIGNMENTS_UPDATE);
872
+ }
873
+ })
874
+ .catch((error) => {
875
+ LoggerProxy.logger.error('Meeting:breakouts#queryPreAssignments failed', error);
876
+ });
877
+ },
878
+ /**
879
+ * assign participants dynamically after breakout sessions started,
880
+ * but currently it only used for admitting participants from lobby into breakout directly
881
+ * @param {Array} sessions
882
+ * @returns {void}
883
+ */
884
+ dynamicAssign(sessions: any[]) {
885
+ const updatedSessions = sessions.map((item) => {
886
+ return {
887
+ id: item.id,
888
+ participants: item.participants,
889
+ targetState: item.targetState,
890
+ };
891
+ });
892
+
893
+ const body = {
894
+ groups: [
895
+ {
896
+ id: this.breakoutGroupId,
897
+ sessions: updatedSessions,
898
+ },
899
+ ],
900
+ editlock: null,
901
+ };
902
+
903
+ if (this.editLock && this.editLock.token) {
904
+ body.editlock = this.editLock;
905
+ }
906
+
907
+ return this.request({
908
+ method: HTTP_VERBS.PUT,
909
+ uri: `${this.url}/dynamicAssign`,
910
+ body,
911
+ });
912
+ },
913
+ /**
914
+ * trigger ASK_RETURN_TO_MAIN event when main session requested
915
+ * @param {Object} breakout
916
+ * @returns {void}
917
+ */
918
+ triggerReturnToMainEvent(breakout) {
919
+ if (breakout.isMain && breakout.requested) {
920
+ this.trigger(BREAKOUTS.EVENTS.ASK_RETURN_TO_MAIN);
921
+ }
922
+ },
351
923
  });
352
924
 
353
925
  export default Breakouts;