@webex/plugin-meetings 3.0.0-beta.16 → 3.0.0-beta.161

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 (424) hide show
  1. package/README.md +45 -1
  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 +359 -0
  7. package/dist/annotation/index.js.map +1 -0
  8. package/dist/breakouts/breakout.js +212 -0
  9. package/dist/breakouts/breakout.js.map +1 -0
  10. package/dist/breakouts/collection.js +23 -0
  11. package/dist/breakouts/collection.js.map +1 -0
  12. package/dist/breakouts/edit-lock-error.js +52 -0
  13. package/dist/breakouts/edit-lock-error.js.map +1 -0
  14. package/dist/breakouts/events.js +43 -0
  15. package/dist/breakouts/events.js.map +1 -0
  16. package/dist/breakouts/index.js +1046 -0
  17. package/dist/breakouts/index.js.map +1 -0
  18. package/dist/breakouts/request.js +78 -0
  19. package/dist/breakouts/request.js.map +1 -0
  20. package/dist/breakouts/utils.js +67 -0
  21. package/dist/breakouts/utils.js.map +1 -0
  22. package/dist/common/errors/webex-errors.js +3 -2
  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/config.js +6 -8
  27. package/dist/config.js.map +1 -1
  28. package/dist/constants.js +175 -26
  29. package/dist/constants.js.map +1 -1
  30. package/dist/controls-options-manager/constants.js +14 -0
  31. package/dist/controls-options-manager/constants.js.map +1 -0
  32. package/dist/controls-options-manager/enums.js +27 -0
  33. package/dist/controls-options-manager/enums.js.map +1 -0
  34. package/dist/controls-options-manager/index.js +297 -0
  35. package/dist/controls-options-manager/index.js.map +1 -0
  36. package/dist/controls-options-manager/types.js +7 -0
  37. package/dist/controls-options-manager/types.js.map +1 -0
  38. package/dist/controls-options-manager/util.js +300 -0
  39. package/dist/controls-options-manager/util.js.map +1 -0
  40. package/dist/index.js +77 -0
  41. package/dist/index.js.map +1 -1
  42. package/dist/interpretation/collection.js +23 -0
  43. package/dist/interpretation/collection.js.map +1 -0
  44. package/dist/interpretation/index.js +214 -0
  45. package/dist/interpretation/index.js.map +1 -0
  46. package/dist/interpretation/siLanguage.js +25 -0
  47. package/dist/interpretation/siLanguage.js.map +1 -0
  48. package/dist/locus-info/controlsUtils.js +92 -2
  49. package/dist/locus-info/controlsUtils.js.map +1 -1
  50. package/dist/locus-info/index.js +317 -24
  51. package/dist/locus-info/index.js.map +1 -1
  52. package/dist/locus-info/mediaSharesUtils.js +43 -1
  53. package/dist/locus-info/mediaSharesUtils.js.map +1 -1
  54. package/dist/locus-info/parser.js +2 -1
  55. package/dist/locus-info/parser.js.map +1 -1
  56. package/dist/locus-info/selfUtils.js +97 -14
  57. package/dist/locus-info/selfUtils.js.map +1 -1
  58. package/dist/media/index.js +39 -134
  59. package/dist/media/index.js.map +1 -1
  60. package/dist/media/properties.js +19 -97
  61. package/dist/media/properties.js.map +1 -1
  62. package/dist/mediaQualityMetrics/config.js +505 -493
  63. package/dist/mediaQualityMetrics/config.js.map +1 -1
  64. package/dist/meeting/in-meeting-actions.js +79 -1
  65. package/dist/meeting/in-meeting-actions.js.map +1 -1
  66. package/dist/meeting/index.js +2349 -2178
  67. package/dist/meeting/index.js.map +1 -1
  68. package/dist/meeting/locusMediaRequest.js +291 -0
  69. package/dist/meeting/locusMediaRequest.js.map +1 -0
  70. package/dist/meeting/muteState.js +229 -124
  71. package/dist/meeting/muteState.js.map +1 -1
  72. package/dist/meeting/request.js +191 -167
  73. package/dist/meeting/request.js.map +1 -1
  74. package/dist/meeting/request.type.js.map +1 -1
  75. package/dist/meeting/util.js +444 -443
  76. package/dist/meeting/util.js.map +1 -1
  77. package/dist/meeting-info/meeting-info-v2.js +157 -49
  78. package/dist/meeting-info/meeting-info-v2.js.map +1 -1
  79. package/dist/meeting-info/utilv2.js +20 -5
  80. package/dist/meeting-info/utilv2.js.map +1 -1
  81. package/dist/meetings/collection.js +22 -0
  82. package/dist/meetings/collection.js.map +1 -1
  83. package/dist/meetings/index.js +365 -73
  84. package/dist/meetings/index.js.map +1 -1
  85. package/dist/meetings/meetings.types.js +7 -0
  86. package/dist/meetings/meetings.types.js.map +1 -0
  87. package/dist/meetings/request.js +16 -12
  88. package/dist/meetings/request.js.map +1 -1
  89. package/dist/meetings/util.js +88 -1
  90. package/dist/meetings/util.js.map +1 -1
  91. package/dist/member/index.js +43 -0
  92. package/dist/member/index.js.map +1 -1
  93. package/dist/member/types.js +15 -0
  94. package/dist/member/types.js.map +1 -0
  95. package/dist/member/util.js +97 -3
  96. package/dist/member/util.js.map +1 -1
  97. package/dist/members/collection.js +10 -0
  98. package/dist/members/collection.js.map +1 -1
  99. package/dist/members/index.js +94 -11
  100. package/dist/members/index.js.map +1 -1
  101. package/dist/members/request.js +109 -39
  102. package/dist/members/request.js.map +1 -1
  103. package/dist/members/types.js +15 -0
  104. package/dist/members/types.js.map +1 -0
  105. package/dist/members/util.js +316 -233
  106. package/dist/members/util.js.map +1 -1
  107. package/dist/metrics/config.js +50 -14
  108. package/dist/metrics/config.js.map +1 -1
  109. package/dist/metrics/constants.js +3 -5
  110. package/dist/metrics/constants.js.map +1 -1
  111. package/dist/metrics/index.js +48 -29
  112. package/dist/metrics/index.js.map +1 -1
  113. package/dist/multistream/mediaRequestManager.js +265 -36
  114. package/dist/multistream/mediaRequestManager.js.map +1 -1
  115. package/dist/multistream/receiveSlot.js +52 -19
  116. package/dist/multistream/receiveSlot.js.map +1 -1
  117. package/dist/multistream/receiveSlotManager.js +53 -33
  118. package/dist/multistream/receiveSlotManager.js.map +1 -1
  119. package/dist/multistream/remoteMedia.js +44 -18
  120. package/dist/multistream/remoteMedia.js.map +1 -1
  121. package/dist/multistream/remoteMediaGroup.js +60 -3
  122. package/dist/multistream/remoteMediaGroup.js.map +1 -1
  123. package/dist/multistream/remoteMediaManager.js +322 -103
  124. package/dist/multistream/remoteMediaManager.js.map +1 -1
  125. package/dist/networkQualityMonitor/index.js +4 -2
  126. package/dist/networkQualityMonitor/index.js.map +1 -1
  127. package/dist/reachability/index.js +117 -60
  128. package/dist/reachability/index.js.map +1 -1
  129. package/dist/reachability/request.js +12 -5
  130. package/dist/reachability/request.js.map +1 -1
  131. package/dist/reactions/constants.js +13 -0
  132. package/dist/reactions/constants.js.map +1 -0
  133. package/dist/reactions/reactions.js +2 -2
  134. package/dist/reactions/reactions.js.map +1 -1
  135. package/dist/reactions/reactions.type.js +18 -18
  136. package/dist/reactions/reactions.type.js.map +1 -1
  137. package/dist/reconnection-manager/index.js +190 -145
  138. package/dist/reconnection-manager/index.js.map +1 -1
  139. package/dist/recording-controller/enums.js +17 -0
  140. package/dist/recording-controller/enums.js.map +1 -0
  141. package/dist/recording-controller/index.js +343 -0
  142. package/dist/recording-controller/index.js.map +1 -0
  143. package/dist/recording-controller/util.js +63 -0
  144. package/dist/recording-controller/util.js.map +1 -0
  145. package/dist/roap/index.js +21 -29
  146. package/dist/roap/index.js.map +1 -1
  147. package/dist/roap/request.js +127 -92
  148. package/dist/roap/request.js.map +1 -1
  149. package/dist/roap/turnDiscovery.js +135 -53
  150. package/dist/roap/turnDiscovery.js.map +1 -1
  151. package/dist/statsAnalyzer/global.js +1 -93
  152. package/dist/statsAnalyzer/global.js.map +1 -1
  153. package/dist/statsAnalyzer/index.js +329 -314
  154. package/dist/statsAnalyzer/index.js.map +1 -1
  155. package/dist/statsAnalyzer/mqaUtil.js +103 -54
  156. package/dist/statsAnalyzer/mqaUtil.js.map +1 -1
  157. package/dist/types/annotation/annotation.types.d.ts +43 -0
  158. package/dist/types/annotation/constants.d.ts +31 -0
  159. package/dist/types/annotation/index.d.ts +124 -0
  160. package/dist/types/breakouts/breakout.d.ts +8 -0
  161. package/dist/types/breakouts/collection.d.ts +5 -0
  162. package/dist/types/breakouts/edit-lock-error.d.ts +15 -0
  163. package/dist/types/breakouts/events.d.ts +2 -0
  164. package/dist/types/breakouts/index.d.ts +5 -0
  165. package/dist/types/breakouts/request.d.ts +22 -0
  166. package/dist/types/breakouts/utils.d.ts +15 -0
  167. package/dist/types/common/browser-detection.d.ts +9 -0
  168. package/dist/types/common/collection.d.ts +48 -0
  169. package/dist/types/common/config.d.ts +2 -0
  170. package/dist/types/common/errors/captcha-error.d.ts +15 -0
  171. package/dist/types/common/errors/intent-to-join.d.ts +16 -0
  172. package/dist/types/common/errors/join-meeting.d.ts +17 -0
  173. package/dist/types/common/errors/media.d.ts +15 -0
  174. package/dist/types/common/errors/parameter.d.ts +15 -0
  175. package/dist/types/common/errors/password-error.d.ts +15 -0
  176. package/dist/types/common/errors/permission.d.ts +14 -0
  177. package/dist/types/common/errors/reconnection-in-progress.d.ts +9 -0
  178. package/dist/types/common/errors/reconnection.d.ts +15 -0
  179. package/dist/types/common/errors/stats.d.ts +15 -0
  180. package/dist/types/common/errors/webex-errors.d.ts +69 -0
  181. package/dist/types/common/errors/webex-meetings-error.d.ts +20 -0
  182. package/dist/types/common/events/events-scope.d.ts +17 -0
  183. package/dist/types/common/events/events.d.ts +12 -0
  184. package/dist/types/common/events/trigger-proxy.d.ts +2 -0
  185. package/dist/types/common/events/util.d.ts +2 -0
  186. package/dist/types/common/logs/logger-config.d.ts +2 -0
  187. package/dist/types/common/logs/logger-proxy.d.ts +2 -0
  188. package/dist/types/common/logs/request.d.ts +34 -0
  189. package/dist/types/common/queue.d.ts +32 -0
  190. package/dist/types/config.d.ts +72 -0
  191. package/dist/types/constants.d.ts +987 -0
  192. package/dist/types/controls-options-manager/constants.d.ts +4 -0
  193. package/dist/types/controls-options-manager/enums.d.ts +15 -0
  194. package/dist/types/controls-options-manager/index.d.ts +136 -0
  195. package/dist/types/controls-options-manager/types.d.ts +43 -0
  196. package/dist/types/controls-options-manager/util.d.ts +1 -0
  197. package/dist/types/index.d.ts +7 -0
  198. package/dist/types/interpretation/collection.d.ts +5 -0
  199. package/dist/types/interpretation/index.d.ts +5 -0
  200. package/dist/types/interpretation/siLanguage.d.ts +5 -0
  201. package/dist/types/locus-info/controlsUtils.d.ts +2 -0
  202. package/dist/types/locus-info/embeddedAppsUtils.d.ts +2 -0
  203. package/dist/types/locus-info/fullState.d.ts +2 -0
  204. package/dist/types/locus-info/hostUtils.d.ts +2 -0
  205. package/dist/types/locus-info/index.d.ts +315 -0
  206. package/dist/types/locus-info/infoUtils.d.ts +2 -0
  207. package/dist/types/locus-info/mediaSharesUtils.d.ts +2 -0
  208. package/dist/types/locus-info/parser.d.ts +212 -0
  209. package/dist/types/locus-info/selfUtils.d.ts +2 -0
  210. package/dist/types/media/index.d.ts +34 -0
  211. package/dist/types/media/properties.d.ts +86 -0
  212. package/dist/types/media/util.d.ts +2 -0
  213. package/dist/types/mediaQualityMetrics/config.d.ts +365 -0
  214. package/dist/types/meeting/in-meeting-actions.d.ts +149 -0
  215. package/dist/types/meeting/index.d.ts +1524 -0
  216. package/dist/types/meeting/locusMediaRequest.d.ts +70 -0
  217. package/dist/types/meeting/muteState.d.ts +184 -0
  218. package/dist/types/meeting/request.d.ts +270 -0
  219. package/dist/types/meeting/request.type.d.ts +11 -0
  220. package/dist/types/meeting/state.d.ts +9 -0
  221. package/dist/types/meeting/util.d.ts +75 -0
  222. package/dist/types/meeting-info/collection.d.ts +20 -0
  223. package/dist/types/meeting-info/index.d.ts +57 -0
  224. package/dist/types/meeting-info/meeting-info-v2.d.ts +122 -0
  225. package/dist/types/meeting-info/request.d.ts +22 -0
  226. package/dist/types/meeting-info/util.d.ts +2 -0
  227. package/dist/types/meeting-info/utilv2.d.ts +2 -0
  228. package/dist/types/meetings/collection.d.ts +31 -0
  229. package/dist/types/meetings/index.d.ts +364 -0
  230. package/dist/types/meetings/meetings.types.d.ts +4 -0
  231. package/dist/types/meetings/request.d.ts +27 -0
  232. package/dist/types/meetings/util.d.ts +18 -0
  233. package/dist/types/member/index.d.ts +158 -0
  234. package/dist/types/member/types.d.ts +21 -0
  235. package/dist/types/member/util.d.ts +2 -0
  236. package/dist/types/members/collection.d.ts +29 -0
  237. package/dist/types/members/index.d.ts +353 -0
  238. package/dist/types/members/request.d.ts +114 -0
  239. package/dist/types/members/types.d.ts +24 -0
  240. package/dist/types/members/util.d.ts +210 -0
  241. package/dist/types/metrics/config.d.ts +195 -0
  242. package/dist/types/metrics/constants.d.ts +55 -0
  243. package/dist/types/metrics/index.d.ts +169 -0
  244. package/dist/types/multistream/mediaRequestManager.d.ts +118 -0
  245. package/dist/types/multistream/receiveSlot.d.ts +68 -0
  246. package/dist/types/multistream/receiveSlotManager.d.ts +56 -0
  247. package/dist/types/multistream/remoteMedia.d.ts +72 -0
  248. package/dist/types/multistream/remoteMediaGroup.d.ts +47 -0
  249. package/dist/types/multistream/remoteMediaManager.d.ts +277 -0
  250. package/dist/types/networkQualityMonitor/index.d.ts +70 -0
  251. package/dist/types/personal-meeting-room/index.d.ts +47 -0
  252. package/dist/types/personal-meeting-room/request.d.ts +14 -0
  253. package/dist/types/personal-meeting-room/util.d.ts +2 -0
  254. package/dist/types/reachability/index.d.ts +152 -0
  255. package/dist/types/reachability/request.d.ts +37 -0
  256. package/dist/types/reactions/constants.d.ts +3 -0
  257. package/dist/types/reactions/reactions.d.ts +4 -0
  258. package/dist/types/reactions/reactions.type.d.ts +52 -0
  259. package/dist/types/reconnection-manager/index.d.ts +126 -0
  260. package/dist/types/recording-controller/enums.d.ts +7 -0
  261. package/dist/types/recording-controller/index.d.ts +193 -0
  262. package/dist/types/recording-controller/util.d.ts +13 -0
  263. package/dist/types/roap/index.d.ts +77 -0
  264. package/dist/types/roap/request.d.ts +36 -0
  265. package/dist/types/roap/turnDiscovery.d.ts +91 -0
  266. package/dist/types/statsAnalyzer/global.d.ts +36 -0
  267. package/dist/types/statsAnalyzer/index.d.ts +200 -0
  268. package/dist/types/statsAnalyzer/mqaUtil.d.ts +24 -0
  269. package/dist/types/transcription/index.d.ts +64 -0
  270. package/package.json +28 -21
  271. package/src/annotation/annotation.types.ts +52 -0
  272. package/src/annotation/constants.ts +36 -0
  273. package/src/annotation/index.ts +343 -0
  274. package/src/breakouts/README.md +220 -0
  275. package/src/breakouts/breakout.ts +180 -0
  276. package/src/breakouts/collection.ts +19 -0
  277. package/src/breakouts/edit-lock-error.ts +25 -0
  278. package/src/breakouts/events.ts +37 -0
  279. package/src/breakouts/index.ts +921 -0
  280. package/src/breakouts/request.ts +55 -0
  281. package/src/breakouts/utils.ts +57 -0
  282. package/src/common/errors/webex-errors.ts +6 -2
  283. package/src/common/logs/logger-proxy.ts +1 -1
  284. package/src/config.ts +5 -7
  285. package/src/constants.ts +165 -20
  286. package/src/controls-options-manager/constants.ts +5 -0
  287. package/src/controls-options-manager/enums.ts +18 -0
  288. package/src/controls-options-manager/index.ts +278 -0
  289. package/src/controls-options-manager/types.ts +59 -0
  290. package/src/controls-options-manager/util.ts +286 -0
  291. package/src/index.ts +34 -0
  292. package/src/interpretation/README.md +51 -0
  293. package/src/interpretation/collection.ts +19 -0
  294. package/src/interpretation/index.ts +182 -0
  295. package/src/interpretation/siLanguage.ts +18 -0
  296. package/src/locus-info/controlsUtils.ts +110 -0
  297. package/src/locus-info/index.ts +339 -21
  298. package/src/locus-info/mediaSharesUtils.ts +48 -0
  299. package/src/locus-info/parser.ts +2 -1
  300. package/src/locus-info/selfUtils.ts +86 -2
  301. package/src/media/index.ts +70 -142
  302. package/src/media/properties.ts +41 -104
  303. package/src/mediaQualityMetrics/config.ts +379 -377
  304. package/src/meeting/in-meeting-actions.ts +156 -0
  305. package/src/meeting/index.ts +1779 -1741
  306. package/src/meeting/locusMediaRequest.ts +309 -0
  307. package/src/meeting/muteState.ts +228 -132
  308. package/src/meeting/request.ts +100 -91
  309. package/src/meeting/request.type.ts +2 -0
  310. package/src/meeting/util.ts +422 -421
  311. package/src/meeting-info/meeting-info-v2.ts +134 -13
  312. package/src/meeting-info/utilv2.ts +13 -3
  313. package/src/meetings/collection.ts +20 -0
  314. package/src/meetings/index.ts +385 -83
  315. package/src/meetings/meetings.types.ts +12 -0
  316. package/src/meetings/request.ts +3 -1
  317. package/src/meetings/util.ts +103 -4
  318. package/src/member/index.ts +42 -0
  319. package/src/member/types.ts +24 -0
  320. package/src/member/util.ts +95 -1
  321. package/src/members/collection.ts +8 -0
  322. package/src/members/index.ts +108 -6
  323. package/src/members/request.ts +98 -17
  324. package/src/members/types.ts +28 -0
  325. package/src/members/util.ts +319 -240
  326. package/src/metrics/config.ts +49 -10
  327. package/src/metrics/constants.ts +2 -4
  328. package/src/metrics/index.ts +43 -27
  329. package/src/multistream/mediaRequestManager.ts +337 -63
  330. package/src/multistream/receiveSlot.ts +68 -26
  331. package/src/multistream/receiveSlotManager.ts +61 -38
  332. package/src/multistream/remoteMedia.ts +29 -3
  333. package/src/multistream/remoteMediaGroup.ts +61 -2
  334. package/src/multistream/remoteMediaManager.ts +260 -66
  335. package/src/networkQualityMonitor/index.ts +6 -6
  336. package/src/reachability/index.ts +75 -25
  337. package/src/reachability/request.ts +10 -5
  338. package/src/reactions/constants.ts +4 -0
  339. package/src/reactions/reactions.ts +4 -4
  340. package/src/reactions/reactions.type.ts +28 -3
  341. package/src/reconnection-manager/index.ts +53 -32
  342. package/src/recording-controller/enums.ts +8 -0
  343. package/src/recording-controller/index.ts +315 -0
  344. package/src/recording-controller/util.ts +58 -0
  345. package/src/roap/index.ts +21 -30
  346. package/src/roap/request.ts +51 -52
  347. package/src/roap/turnDiscovery.ts +51 -27
  348. package/src/statsAnalyzer/global.ts +1 -94
  349. package/src/statsAnalyzer/index.ts +380 -390
  350. package/src/statsAnalyzer/mqaUtil.ts +106 -99
  351. package/test/integration/spec/converged-space-meetings.js +233 -0
  352. package/test/integration/spec/journey.js +331 -254
  353. package/test/integration/spec/space-meeting.js +77 -4
  354. package/test/unit/spec/annotation/index.ts +436 -0
  355. package/test/unit/spec/breakouts/breakout.ts +233 -0
  356. package/test/unit/spec/breakouts/collection.ts +15 -0
  357. package/test/unit/spec/breakouts/edit-lock-error.ts +30 -0
  358. package/test/unit/spec/breakouts/events.ts +77 -0
  359. package/test/unit/spec/breakouts/index.ts +1790 -0
  360. package/test/unit/spec/breakouts/request.ts +104 -0
  361. package/test/unit/spec/breakouts/utils.js +72 -0
  362. package/test/unit/spec/controls-options-manager/index.js +287 -0
  363. package/test/unit/spec/controls-options-manager/util.js +518 -0
  364. package/test/unit/spec/fixture/locus.js +1 -0
  365. package/test/unit/spec/interpretation/collection.ts +15 -0
  366. package/test/unit/spec/interpretation/index.ts +329 -0
  367. package/test/unit/spec/interpretation/siLanguage.ts +26 -0
  368. package/test/unit/spec/locus-info/controlsUtils.js +323 -30
  369. package/test/unit/spec/locus-info/index.js +680 -4
  370. package/test/unit/spec/locus-info/mediaSharesUtils.ts +22 -0
  371. package/test/unit/spec/locus-info/selfConstant.js +48 -0
  372. package/test/unit/spec/locus-info/selfUtils.js +275 -0
  373. package/test/unit/spec/media/index.ts +118 -22
  374. package/test/unit/spec/media/properties.ts +9 -9
  375. package/test/unit/spec/meeting/in-meeting-actions.ts +76 -0
  376. package/test/unit/spec/meeting/index.js +2695 -1513
  377. package/test/unit/spec/meeting/locusMediaRequest.ts +436 -0
  378. package/test/unit/spec/meeting/muteState.js +370 -208
  379. package/test/unit/spec/meeting/request.js +354 -42
  380. package/test/unit/spec/meeting/utils.js +270 -156
  381. package/test/unit/spec/meeting-info/meetinginfov2.js +383 -5
  382. package/test/unit/spec/meeting-info/utilv2.js +21 -0
  383. package/test/unit/spec/meetings/collection.js +14 -0
  384. package/test/unit/spec/meetings/index.js +866 -120
  385. package/test/unit/spec/meetings/utils.js +206 -2
  386. package/test/unit/spec/member/index.js +31 -0
  387. package/test/unit/spec/member/util.js +408 -32
  388. package/test/unit/spec/members/index.js +320 -1
  389. package/test/unit/spec/members/request.js +206 -27
  390. package/test/unit/spec/members/utils.js +184 -0
  391. package/test/unit/spec/metrics/index.js +98 -0
  392. package/test/unit/spec/multistream/mediaRequestManager.ts +1012 -109
  393. package/test/unit/spec/multistream/receiveSlot.ts +77 -18
  394. package/test/unit/spec/multistream/receiveSlotManager.ts +69 -39
  395. package/test/unit/spec/multistream/remoteMedia.ts +32 -2
  396. package/test/unit/spec/multistream/remoteMediaGroup.ts +271 -5
  397. package/test/unit/spec/multistream/remoteMediaManager.ts +672 -65
  398. package/test/unit/spec/networkQualityMonitor/index.js +4 -4
  399. package/test/unit/spec/reachability/index.ts +176 -25
  400. package/test/unit/spec/reachability/request.js +66 -0
  401. package/test/unit/spec/reconnection-manager/index.js +46 -13
  402. package/test/unit/spec/recording-controller/index.js +231 -0
  403. package/test/unit/spec/recording-controller/util.js +102 -0
  404. package/test/unit/spec/roap/index.ts +21 -51
  405. package/test/unit/spec/roap/request.ts +187 -0
  406. package/test/unit/spec/roap/turnDiscovery.ts +73 -34
  407. package/test/unit/spec/stats-analyzer/index.js +94 -43
  408. package/test/utils/constants.js +9 -0
  409. package/test/utils/integrationTestUtils.js +46 -0
  410. package/test/utils/testUtils.js +0 -45
  411. package/test/utils/webex-config.js +4 -0
  412. package/test/utils/webex-test-users.js +7 -3
  413. package/tsconfig.json +6 -0
  414. package/dist/media/internal-media-core-wrapper.js +0 -18
  415. package/dist/media/internal-media-core-wrapper.js.map +0 -1
  416. package/dist/meeting/effectsState.js +0 -262
  417. package/dist/meeting/effectsState.js.map +0 -1
  418. package/dist/multistream/multistreamMedia.js +0 -106
  419. package/dist/multistream/multistreamMedia.js.map +0 -1
  420. package/src/index.js +0 -15
  421. package/src/media/internal-media-core-wrapper.ts +0 -9
  422. package/src/meeting/effectsState.ts +0 -211
  423. package/src/multistream/multistreamMedia.ts +0 -93
  424. package/test/unit/spec/meeting/effectsState.js +0 -281
@@ -0,0 +1,118 @@
1
+ import { StreamRequest } from '@webex/internal-media-core';
2
+ import { ReceiveSlot } from './receiveSlot';
3
+ export interface ActiveSpeakerPolicyInfo {
4
+ policy: 'active-speaker';
5
+ priority: number;
6
+ crossPriorityDuplication: boolean;
7
+ crossPolicyDuplication: boolean;
8
+ preferLiveVideo: boolean;
9
+ }
10
+ export interface ReceiverSelectedPolicyInfo {
11
+ policy: 'receiver-selected';
12
+ csi: number;
13
+ }
14
+ export type PolicyInfo = ActiveSpeakerPolicyInfo | ReceiverSelectedPolicyInfo;
15
+ export interface H264CodecInfo {
16
+ codec: 'h264';
17
+ maxFs?: number;
18
+ maxFps?: number;
19
+ maxMbps?: number;
20
+ maxWidth?: number;
21
+ maxHeight?: number;
22
+ }
23
+ export type CodecInfo = H264CodecInfo;
24
+ export interface MediaRequest {
25
+ policyInfo: PolicyInfo;
26
+ receiveSlots: Array<ReceiveSlot>;
27
+ codecInfo?: CodecInfo;
28
+ preferredMaxFs?: number;
29
+ handleMaxFs?: ({ maxFs }: {
30
+ maxFs: number;
31
+ }) => void;
32
+ }
33
+ export type MediaRequestId = string;
34
+ type DegradationPreferences = {
35
+ maxMacroblocksLimit: number;
36
+ };
37
+ type SendMediaRequestsCallback = (streamRequests: StreamRequest[]) => void;
38
+ type Kind = 'audio' | 'video';
39
+ type Options = {
40
+ degradationPreferences: DegradationPreferences;
41
+ kind: Kind;
42
+ trimRequestsToNumOfSources: boolean;
43
+ };
44
+ export declare class MediaRequestManager {
45
+ private sendMediaRequestsCallback;
46
+ private kind;
47
+ private counter;
48
+ private clientRequests;
49
+ private degradationPreferences;
50
+ private sourceUpdateListener;
51
+ private debouncedSourceUpdateListener;
52
+ private previousStreamRequests;
53
+ private trimRequestsToNumOfSources;
54
+ private numTotalSources;
55
+ private numLiveSources;
56
+ constructor(sendMediaRequestsCallback: SendMediaRequestsCallback, options: Options);
57
+ setDegradationPreferences(degradationPreferences: DegradationPreferences): void;
58
+ private getDegradedClientRequests;
59
+ /**
60
+ * Returns true if two stream requests are the same, false otherwise.
61
+ *
62
+ * @param {StreamRequest} streamRequestA - Stream request A for comparison.
63
+ * @param {StreamRequest} streamRequestB - Stream request B for comparison.
64
+ * @returns {boolean} - Whether they are equal.
65
+ */
66
+ isEqual(streamRequestA: StreamRequest, streamRequestB: StreamRequest): boolean;
67
+ /**
68
+ * Compares new stream requests to previous ones and determines
69
+ * if they are the same.
70
+ *
71
+ * @param {StreamRequest[]} newRequests - Array with new requests.
72
+ * @returns {boolean} - True if they are equal, false otherwise.
73
+ */
74
+ private checkIsNewRequestsEqualToPrev;
75
+ /**
76
+ * Returns the maxPayloadBitsPerSecond per Stream
77
+ *
78
+ * If MediaRequestManager kind is "audio", a constant bitrate will be returned.
79
+ * If MediaRequestManager kind is "video", the bitrate will be calculated based
80
+ * on maxFs (default h264 maxFs as fallback if maxFs is not defined)
81
+ *
82
+ * @param {MediaRequest} mediaRequest - mediaRequest to take data from
83
+ * @returns {number} maxPayloadBitsPerSecond
84
+ */
85
+ private getMaxPayloadBitsPerSecond;
86
+ /**
87
+ * Returns the max Macro Blocks per second (maxMbps) per H264 Stream
88
+ *
89
+ * The maxMbps will be calculated based on maxFs and maxFps
90
+ * (default h264 maxFps as fallback if maxFps is not defined)
91
+ *
92
+ * @param {MediaRequest} mediaRequest - mediaRequest to take data from
93
+ * @returns {number} maxMbps
94
+ */
95
+ private getH264MaxMbps;
96
+ /**
97
+ * Clears the previous stream requests.
98
+ *
99
+ * @returns {void}
100
+ */
101
+ clearPreviousRequests(): void;
102
+ /** Modifies the passed in clientRequests and makes sure that in total they don't ask
103
+ * for more streams than there are available.
104
+ *
105
+ * @param {Object} clientRequests
106
+ * @returns {void}
107
+ */
108
+ private trimRequests;
109
+ private getPreferLiveVideo;
110
+ private cloneClientRequests;
111
+ private sendRequests;
112
+ addRequest(mediaRequest: MediaRequest, commit?: boolean): MediaRequestId;
113
+ cancelRequest(requestId: MediaRequestId, commit?: boolean): void;
114
+ commit(): void;
115
+ reset(): void;
116
+ setNumCurrentSources(numTotalSources: number, numLiveSources: number): void;
117
+ }
118
+ export {};
@@ -0,0 +1,68 @@
1
+ import { MediaType, ReceiveSlot as WcmeReceiveSlot, StreamState } from '@webex/internal-media-core';
2
+ import EventsScope from '../common/events/events-scope';
3
+ export declare const ReceiveSlotEvents: {
4
+ SourceUpdate: string;
5
+ MaxFsUpdate: string;
6
+ };
7
+ export type { StreamState } from '@webex/internal-media-core';
8
+ export type CSI = number;
9
+ export type MemberId = string;
10
+ export type ReceiveSlotId = string;
11
+ export type FindMemberIdCallback = (csi: CSI) => MemberId | undefined;
12
+ /**
13
+ * Class representing a receive slot. A single receive slot is able to receive a single track
14
+ * for example some participant's main video or audio
15
+ */
16
+ export declare class ReceiveSlot extends EventsScope {
17
+ #private;
18
+ private readonly mcReceiveSlot;
19
+ private readonly findMemberIdCallback;
20
+ readonly id: ReceiveSlotId;
21
+ readonly mediaType: MediaType;
22
+ /**
23
+ * constructor - don't use it directly, you should always use meeting.receiveSlotManager.allocateSlot()
24
+ * to create any receive slots
25
+ *
26
+ * @param {MediaType} mediaType
27
+ * @param {ReceiveSlot} mcReceiveSlot
28
+ * @param {FindMemberIdCallback} findMemberIdCallback callback for finding memberId for given CSI
29
+ */
30
+ constructor(mediaType: MediaType, mcReceiveSlot: WcmeReceiveSlot, findMemberIdCallback: FindMemberIdCallback);
31
+ /**
32
+ * Getter for memberId
33
+ */
34
+ get memberId(): string;
35
+ /**
36
+ * Getter for csi
37
+ */
38
+ get csi(): number;
39
+ /**
40
+ * Set the max frame size for this slot
41
+ * @param newFs frame size
42
+ */
43
+ setMaxFs(newFs: any): void;
44
+ /**
45
+ * Getter for sourceState
46
+ */
47
+ get sourceState(): StreamState;
48
+ /**
49
+ * registers event handlers with the underlying ReceiveSlot
50
+ */
51
+ private setupEventListeners;
52
+ /** Tries to find the member id for this receive slot if it hasn't got one */
53
+ findMemberId(): void;
54
+ /**
55
+ * @returns {string} a log message used to identify the receive slot
56
+ */
57
+ get logString(): string;
58
+ /**
59
+ * The MediaStream object associated with this slot.
60
+ *
61
+ * @returns {MediaStream} The MediaStreamTrack.
62
+ */
63
+ get stream(): MediaStream;
64
+ /**
65
+ * The underlying WCME receive slot
66
+ */
67
+ get wcmeReceiveSlot(): WcmeReceiveSlot;
68
+ }
@@ -0,0 +1,56 @@
1
+ import { MediaType, ReceiveSlot as WcmeReceiveSlot } from '@webex/internal-media-core';
2
+ import { FindMemberIdCallback, ReceiveSlot } from './receiveSlot';
3
+ export type CreateSlotCallback = (mediaType: MediaType) => Promise<WcmeReceiveSlot>;
4
+ export type { CSI, FindMemberIdCallback } from './receiveSlot';
5
+ /**
6
+ * Manages all receive slots used by a meeting. WMCE receive slots cannot be ever deleted,
7
+ * so this manager has a pool in order to re-use the slots that were released earlier.
8
+ */
9
+ export declare class ReceiveSlotManager {
10
+ private allocatedSlots;
11
+ private freeSlots;
12
+ private createSlotCallback;
13
+ private findMemberIdByCsiCallback;
14
+ /**
15
+ * Constructor
16
+ * @param {Meeting} meeting
17
+ */
18
+ constructor(createSlotCallback: CreateSlotCallback, findMemberIdByCsiCallback: FindMemberIdCallback);
19
+ /**
20
+ * Creates a new receive slot or returns one from the existing pool of free slots
21
+ *
22
+ * @param {MediaType} mediaType
23
+ * @returns {Promise<ReceiveSlot>}
24
+ */
25
+ allocateSlot(mediaType: MediaType): Promise<ReceiveSlot>;
26
+ /**
27
+ * Releases the slot back to the pool so it can be re-used by others in the future
28
+ * @param {ReceiveSlot} slot
29
+ */
30
+ releaseSlot(slot: ReceiveSlot): void;
31
+ /**
32
+ * Resets the slot manager - this method should be called when the media connection is torn down
33
+ */
34
+ reset(): void;
35
+ /**
36
+ * Returns statistics about the managed slots
37
+ *
38
+ * @returns {Object}
39
+ */
40
+ getStats(): {
41
+ numAllocatedSlots: {};
42
+ numFreeSlots: {};
43
+ };
44
+ /**
45
+ * Tries to find the member id on all allocated receive slots
46
+ * This function should be called when new members are added to the meeting.
47
+ */
48
+ updateMemberIds(): void;
49
+ /**
50
+ * Find a receive slot by a ssrc.
51
+ *
52
+ * @param ssrc - The ssrc of the receive slot to find.
53
+ * @returns - The receive slot with this ssrc, undefined if not found.
54
+ */
55
+ findReceiveSlotBySsrc(ssrc: number): ReceiveSlot | undefined;
56
+ }
@@ -0,0 +1,72 @@
1
+ import { MediaType, StreamState } from '@webex/internal-media-core';
2
+ import EventsScope from '../common/events/events-scope';
3
+ import { MediaRequestManager } from './mediaRequestManager';
4
+ import { ReceiveSlot } from './receiveSlot';
5
+ export declare const RemoteMediaEvents: {
6
+ SourceUpdate: string;
7
+ Stopped: string;
8
+ };
9
+ export type RemoteVideoResolution = 'thumbnail' | 'very small' | 'small' | 'medium' | 'large' | 'best';
10
+ /**
11
+ * Converts pane size into h264 maxFs
12
+ * @param {PaneSize} paneSize
13
+ * @returns {number}
14
+ */
15
+ export declare function getMaxFs(paneSize: RemoteVideoResolution): number;
16
+ type Options = {
17
+ resolution?: RemoteVideoResolution;
18
+ };
19
+ export type RemoteMediaId = string;
20
+ /**
21
+ * Class representing a remote audio/video stream.
22
+ *
23
+ * Internally it is associated with a specific receive slot
24
+ * and a media request for it.
25
+ */
26
+ export declare class RemoteMedia extends EventsScope {
27
+ private receiveSlot?;
28
+ private readonly mediaRequestManager;
29
+ private readonly options;
30
+ private mediaRequestId?;
31
+ readonly id: RemoteMediaId;
32
+ /**
33
+ * Constructs RemoteMedia instance
34
+ *
35
+ * @param receiveSlot
36
+ * @param mediaRequestManager
37
+ * @param options
38
+ */
39
+ constructor(receiveSlot: ReceiveSlot, mediaRequestManager: MediaRequestManager, options?: Options);
40
+ /**
41
+ * Supply the width and height of the video element
42
+ * to restrict the requested resolution to this size
43
+ * @param width width of the video element
44
+ * @param height height of the video element
45
+ */
46
+ setSizeHint(width: any, height: any): void;
47
+ /**
48
+ * registers event listeners on the receive slot and forwards all the events
49
+ */
50
+ private setupEventListeners;
51
+ /**
52
+ * Getter for mediaType
53
+ */
54
+ get mediaType(): MediaType;
55
+ /**
56
+ * Getter for memberId
57
+ */
58
+ get memberId(): string;
59
+ /**
60
+ * Getter for csi
61
+ */
62
+ get csi(): number;
63
+ /**
64
+ * Getter for source state
65
+ */
66
+ get sourceState(): StreamState;
67
+ /**
68
+ * Getter for remote media stream
69
+ */
70
+ get stream(): MediaStream;
71
+ }
72
+ export {};
@@ -0,0 +1,47 @@
1
+ import { RemoteMedia, RemoteVideoResolution } from './remoteMedia';
2
+ import { MediaRequestManager } from './mediaRequestManager';
3
+ import { CSI, ReceiveSlot } from './receiveSlot';
4
+ type Options = {
5
+ resolution?: RemoteVideoResolution;
6
+ preferLiveVideo?: boolean;
7
+ };
8
+ export declare class RemoteMediaGroup {
9
+ private mediaRequestManager;
10
+ private priority;
11
+ private options;
12
+ private unpinnedRemoteMedia;
13
+ private mediaRequestId?;
14
+ private pinnedRemoteMedia;
15
+ constructor(mediaRequestManager: MediaRequestManager, receiveSlots: ReceiveSlot[], priority: number, commitMediaRequest: boolean, options?: Options);
16
+ /**
17
+ * Gets the array of remote media elements from the group
18
+ *
19
+ * @param {string} filter - 'all' (default) returns both pinned and unpinned
20
+ * @returns {Array<RemoteMedia>}
21
+ */
22
+ getRemoteMedia(filter?: 'all' | 'pinned' | 'unpinned'): RemoteMedia[];
23
+ /**
24
+ * Pins a specific remote media instance to a specfic CSI, so the media will
25
+ * no longer come from active speaker, but from that CSI.
26
+ * If no CSI is given, the current CSI value is used.
27
+ *
28
+ */
29
+ pin(remoteMedia: RemoteMedia, csi?: CSI): void;
30
+ /**
31
+ * Unpins a remote media instance, so that it will again provide media from active speakers
32
+ *
33
+ */
34
+ unpin(remoteMedia: RemoteMedia): void;
35
+ isPinned(remoteMedia: RemoteMedia): boolean;
36
+ private sendActiveSpeakerMediaRequest;
37
+ private cancelActiveSpeakerMediaRequest;
38
+ /**
39
+ * Checks if a given RemoteMedia instance belongs to this group.
40
+ *
41
+ * @param remoteMedia RemoteMedia instance to check
42
+ * @param filter controls which remote media from the group to check
43
+ * @returns true if remote media is found
44
+ */
45
+ includes(remoteMedia: RemoteMedia, filter?: 'all' | 'pinned' | 'unpinned'): boolean;
46
+ }
47
+ export {};
@@ -0,0 +1,277 @@
1
+ import { EventMap } from 'typed-emitter';
2
+ import EventsScope from '../common/events/events-scope';
3
+ import { RemoteMedia, RemoteVideoResolution } from './remoteMedia';
4
+ import { CSI } from './receiveSlot';
5
+ import { ReceiveSlotManager } from './receiveSlotManager';
6
+ import { RemoteMediaGroup } from './remoteMediaGroup';
7
+ import { MediaRequestManager } from './mediaRequestManager';
8
+ export type PaneSize = RemoteVideoResolution;
9
+ export type LayoutId = string;
10
+ export type PaneId = string;
11
+ export type PaneGroupId = string;
12
+ export interface ActiveSpeakerVideoPaneGroup {
13
+ id: PaneGroupId;
14
+ numPanes: number;
15
+ size: PaneSize;
16
+ priority: number;
17
+ }
18
+ export interface MemberVideoPane {
19
+ id: PaneId;
20
+ size: PaneSize;
21
+ csi?: CSI;
22
+ }
23
+ export interface VideoLayout {
24
+ screenShareVideo?: {
25
+ size: PaneSize;
26
+ };
27
+ activeSpeakerVideoPaneGroups?: ActiveSpeakerVideoPaneGroup[];
28
+ memberVideoPanes?: MemberVideoPane[];
29
+ }
30
+ export interface Configuration {
31
+ audio: {
32
+ numOfActiveSpeakerStreams: number;
33
+ numOfScreenShareStreams: number;
34
+ };
35
+ video: {
36
+ preferLiveVideo: boolean;
37
+ initialLayoutId: LayoutId;
38
+ layouts: {
39
+ [key: LayoutId]: VideoLayout;
40
+ };
41
+ };
42
+ }
43
+ /**
44
+ * Default configuration:
45
+ * - uses 3 audio streams
46
+ * - prefers active speakers with live video (e.g. are not audio only or video muted) over active speakers without live video
47
+ * - has a few layouts defined, including 1 that contains remote screen share (ScreenShareView)
48
+ */
49
+ export declare const DefaultConfiguration: Configuration;
50
+ export declare enum Event {
51
+ AudioCreated = "AudioCreated",
52
+ ScreenShareAudioCreated = "ScreenShareAudioCreated",
53
+ VideoLayoutChanged = "VideoLayoutChanged"
54
+ }
55
+ export interface VideoLayoutChangedEventData {
56
+ layoutId: LayoutId;
57
+ activeSpeakerVideoPanes: {
58
+ [key: PaneGroupId]: RemoteMediaGroup;
59
+ };
60
+ memberVideoPanes: {
61
+ [key: PaneId]: RemoteMedia;
62
+ };
63
+ screenShareVideo?: RemoteMedia;
64
+ }
65
+ export interface Events extends EventMap {
66
+ [Event.AudioCreated]: (audio: RemoteMediaGroup) => void;
67
+ [Event.ScreenShareAudioCreated]: (screenShareAudio: RemoteMediaGroup) => void;
68
+ [Event.VideoLayoutChanged]: (data: VideoLayoutChangedEventData) => void;
69
+ }
70
+ /**
71
+ * A helper class that manages all remote audio/video streams in order to achieve a predefined set of layouts.
72
+ * It also creates a fixed number of audio streams and these don't change during the meeting.
73
+ *
74
+ * Things that RemoteMediaManager does:
75
+ * - owns the receive slots (creates them when needed, and re-uses them when switching layouts)
76
+ * - constructs appropriate RemoteMedia and RemoteMediaGroup objects and sends appropriate mediaRequests
77
+ */
78
+ export declare class RemoteMediaManager extends EventsScope {
79
+ private config;
80
+ private started;
81
+ private receiveSlotManager;
82
+ private mediaRequestManagers;
83
+ private currentLayout?;
84
+ private slots;
85
+ private media;
86
+ private receiveSlotAllocations;
87
+ private currentLayoutId?;
88
+ /**
89
+ * Constructor
90
+ *
91
+ * @param {ReceiveSlotManager} receiveSlotManager
92
+ * @param {{audio: MediaRequestManager, video: mediaRequestManagers}} mediaRequestManagers
93
+ * @param {Configuration} config Configuration describing what video layouts to use during the meeting
94
+ */
95
+ constructor(receiveSlotManager: ReceiveSlotManager, mediaRequestManagers: {
96
+ audio: MediaRequestManager;
97
+ video: MediaRequestManager;
98
+ screenShareAudio: MediaRequestManager;
99
+ screenShareVideo: MediaRequestManager;
100
+ }, config?: Configuration);
101
+ /**
102
+ * Checks if configuration is valid, throws an error if it's not
103
+ */
104
+ private checkConfigValidity;
105
+ /**
106
+ * Starts the RemoteMediaManager.
107
+ *
108
+ * @returns {Promise}
109
+ */
110
+ start(): Promise<void>;
111
+ /**
112
+ * Releases all the used resources (like allocated receive slots). This function needs
113
+ * to be called when we leave the meeting, etc.
114
+ */
115
+ stop(): void;
116
+ /**
117
+ * Returns the total number of main video panes required for a given layout
118
+ *
119
+ * @param {VideoLayout} layout
120
+ * @returns {number}
121
+ */
122
+ private getRequiredNumVideoSlotsForLayout;
123
+ /**
124
+ * Allocates the maximum number of panes that any of the configured layouts will require.
125
+ * We do this at the beginning, because it's more efficient (much faster) then allocating receive slots
126
+ * later, after the SDP exchange was done.
127
+ */
128
+ private preallocateVideoReceiveSlots;
129
+ /**
130
+ * Changes the layout (triggers Event.VideoLayoutChanged)
131
+ *
132
+ * @param {LayoutId} layoutId new layout id
133
+ * @returns {Promise}
134
+ */
135
+ setLayout(layoutId: LayoutId): Promise<void>;
136
+ /**
137
+ * Returns the currently selected layout id
138
+ *
139
+ * @returns {LayoutId}
140
+ */
141
+ getLayoutId(): LayoutId | undefined;
142
+ /**
143
+ * sets the preferLiveVideo
144
+ */
145
+ setPreferLiveVideo(preferLiveVideo: boolean): void;
146
+ /**
147
+ * Sets CSIs for multiple RemoteMedia instances belonging to RemoteMediaGroup.
148
+ * For each entry in the remoteMediaCsis array:
149
+ * - if csi is specified, the RemoteMedia instance is pinned to that CSI
150
+ * - if csi is undefined, the RemoteMedia instance is unpinned
151
+ */
152
+ setActiveSpeakerCsis(remoteMediaCsis: {
153
+ remoteMedia: RemoteMedia;
154
+ csi?: number;
155
+ }[]): void;
156
+ /**
157
+ * Creates the audio slots
158
+ */
159
+ private createAudioMedia;
160
+ /**
161
+ * Creates receive slots required for receiving screen share audio and video
162
+ */
163
+ private createScreenShareReceiveSlots;
164
+ /**
165
+ * Creates RemoteMedia objects for screen share
166
+ */
167
+ private createScreenShareAudioMedia;
168
+ /**
169
+ * Goes over all receiver-selected slots and keeps only the ones that are required by a given layout,
170
+ * the rest are all moved to the "unused" list
171
+ */
172
+ private trimReceiverSelectedSlots;
173
+ /**
174
+ * Releases all the "unused" video slots.
175
+ */
176
+ private releaseUnusedVideoSlots;
177
+ /**
178
+ * Allocates receive slots to all active speaker video panes
179
+ * in the current selected layout.
180
+ *
181
+ * Allocation tries to keep the same order of the slots between the previous
182
+ * layout and the new one. Sorting helps making sure that highest priority slots
183
+ * go in the same order in the new layout.
184
+ */
185
+ private allocateSlotsToActiveSpeakerPaneGroups;
186
+ /**
187
+ * Allocates receive slots to all receiver selected video panes
188
+ * in the current selected layout
189
+ */
190
+ private allocateSlotsToReceiverSelectedVideoPaneGroups;
191
+ /**
192
+ * Ensures that we have enough slots for the current layout.
193
+ */
194
+ private refillRequiredSlotsIfNeeded;
195
+ /**
196
+ * Move all active speaker slots to "unused"
197
+ */
198
+ private trimActiveSpeakerSlots;
199
+ /**
200
+ * Logs the state of the receive slots
201
+ */
202
+ private logReceieveSlots;
203
+ /**
204
+ * Makes sure we have the right number of receive slots created for the current layout
205
+ * and allocates them to the right video panes / pane groups
206
+ *
207
+ * @returns {Promise}
208
+ */
209
+ private updateVideoReceiveSlots;
210
+ /**
211
+ * Creates new RemoteMedia and RemoteMediaGroup objects for the current layout
212
+ * and sends the media requests for all of them.
213
+ */
214
+ private updateVideoRemoteMediaObjects;
215
+ /**
216
+ * Checks if current layout requires a screen share.
217
+ * If it does, it creates new RemoteMediaGroup object for screen share
218
+ * and sends the media requests for it.
219
+ * If it doesn't, it makes sure we clean up any RemoteMediaGroup objects
220
+ * created earlier for screen share (for previous layout).
221
+ */
222
+ private updateScreenShareVideoRemoteMediaObject;
223
+ /**
224
+ * Invalidates all remote media objects belonging to currently selected layout
225
+ */
226
+ private invalidateCurrentRemoteMedia;
227
+ /** emits Event.VideoLayoutChanged */
228
+ private emitVideoLayoutChangedEvent;
229
+ /**
230
+ * Sets a new CSI on a given remote media object
231
+ *
232
+ * @param {RemoteMedia} remoteMedia remote Media object to modify
233
+ * @param {CSI} csi new CSI value, can be null if we want to stop receiving media
234
+ */
235
+ setRemoteVideoCsi(remoteMedia: RemoteMedia, csi: CSI | null): void;
236
+ /**
237
+ * Adds a new member video pane to the currently selected layout.
238
+ *
239
+ * Changes to the layout are lost after a layout change.
240
+ *
241
+ * @param {MemberVideoPane} newPane
242
+ * @returns {Promise<RemoteMedia>}
243
+ */
244
+ addMemberVideoPane(newPane: MemberVideoPane): Promise<RemoteMedia>;
245
+ /**
246
+ * Removes a member video pane from the currently selected layout.
247
+ *
248
+ * Changes to the layout are lost after a layout change.
249
+ *
250
+ * @param {PaneId} paneId pane id of the pane to remove
251
+ * @returns {Promise<void>}
252
+ */
253
+ removeMemberVideoPane(paneId: PaneId): Promise<void>;
254
+ /**
255
+ * Pins an active speaker remote media object to the given CSI value. From that moment
256
+ * onwards the remote media will only play audio/video from that specific CSI until
257
+ * unpinActiveSpeakerVideoPane() is called or current layout is changed.
258
+ *
259
+ * @param {RemoteMedia} remoteMedia remote media object reference
260
+ * @param {CSI} csi CSI value to pin to, if undefined, then current CSI value is used
261
+ */
262
+ pinActiveSpeakerVideoPane(remoteMedia: RemoteMedia, csi?: CSI): void;
263
+ /**
264
+ * Unpins a remote media object from the fixed CSI value it was pinned to.
265
+ *
266
+ * @param {RemoteMedia} remoteMedia remote media object reference
267
+ */
268
+ unpinActiveSpeakerVideoPane(remoteMedia: RemoteMedia): void;
269
+ /**
270
+ * Returns true if a given remote media object belongs to an active speaker group and has been pinned.
271
+ * Throws an error if the remote media object doesn't belong to any active speaker remote media group.
272
+ *
273
+ * @param {RemoteMedia} remoteMedia remote media object
274
+ * @returns {boolean}
275
+ */
276
+ isPinned(remoteMedia: RemoteMedia): boolean;
277
+ }