@webex/plugin-meetings 3.0.0-beta.4 → 3.0.0-beta.40
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.
- package/UPGRADING.md +9 -9
- package/browsers.js +19 -24
- package/dist/breakouts/breakout.js +137 -0
- package/dist/breakouts/breakout.js.map +1 -0
- package/dist/breakouts/collection.js +23 -0
- package/dist/breakouts/collection.js.map +1 -0
- package/dist/breakouts/edit-lock-error.js +52 -0
- package/dist/breakouts/edit-lock-error.js.map +1 -0
- package/dist/breakouts/index.js +546 -0
- package/dist/breakouts/index.js.map +1 -0
- package/dist/breakouts/request.js +78 -0
- package/dist/breakouts/request.js.map +1 -0
- package/dist/breakouts/utils.js +48 -0
- package/dist/breakouts/utils.js.map +1 -0
- package/dist/common/browser-detection.js +1 -20
- package/dist/common/browser-detection.js.map +1 -1
- package/dist/common/collection.js +5 -20
- package/dist/common/collection.js.map +1 -1
- package/dist/common/config.js +0 -7
- package/dist/common/config.js.map +1 -1
- package/dist/common/errors/captcha-error.js +10 -24
- package/dist/common/errors/captcha-error.js.map +1 -1
- package/dist/common/errors/intent-to-join.js +11 -24
- package/dist/common/errors/intent-to-join.js.map +1 -1
- package/dist/common/errors/join-meeting.js +12 -25
- package/dist/common/errors/join-meeting.js.map +1 -1
- package/dist/common/errors/media.js +10 -24
- package/dist/common/errors/media.js.map +1 -1
- package/dist/common/errors/parameter.js +5 -33
- package/dist/common/errors/parameter.js.map +1 -1
- package/dist/common/errors/password-error.js +10 -24
- package/dist/common/errors/password-error.js.map +1 -1
- package/dist/common/errors/permission.js +9 -23
- package/dist/common/errors/permission.js.map +1 -1
- package/dist/common/errors/reconnection-in-progress.js +0 -17
- package/dist/common/errors/reconnection-in-progress.js.map +1 -1
- package/dist/common/errors/reconnection.js +10 -24
- package/dist/common/errors/reconnection.js.map +1 -1
- package/dist/common/errors/stats.js +10 -24
- package/dist/common/errors/stats.js.map +1 -1
- package/dist/common/errors/webex-errors.js +6 -41
- package/dist/common/errors/webex-errors.js.map +1 -1
- package/dist/common/errors/webex-meetings-error.js +5 -25
- package/dist/common/errors/webex-meetings-error.js.map +1 -1
- package/dist/common/events/events-scope.js +0 -22
- package/dist/common/events/events-scope.js.map +1 -1
- package/dist/common/events/events.js +0 -23
- package/dist/common/events/events.js.map +1 -1
- package/dist/common/events/trigger-proxy.js +0 -12
- package/dist/common/events/trigger-proxy.js.map +1 -1
- package/dist/common/events/util.js +0 -15
- package/dist/common/events/util.js.map +1 -1
- package/dist/common/logs/logger-config.js +0 -4
- package/dist/common/logs/logger-config.js.map +1 -1
- package/dist/common/logs/logger-proxy.js +1 -8
- package/dist/common/logs/logger-proxy.js.map +1 -1
- package/dist/common/logs/request.js +37 -60
- package/dist/common/logs/request.js.map +1 -1
- package/dist/common/queue.js +4 -14
- package/dist/common/queue.js.map +1 -1
- package/dist/config.js +6 -6
- package/dist/config.js.map +1 -1
- package/dist/constants.js +109 -49
- package/dist/constants.js.map +1 -1
- package/dist/controls-options-manager/constants.js +14 -0
- package/dist/controls-options-manager/constants.js.map +1 -0
- package/dist/controls-options-manager/enums.js +15 -0
- package/dist/controls-options-manager/enums.js.map +1 -0
- package/dist/controls-options-manager/index.js +203 -0
- package/dist/controls-options-manager/index.js.map +1 -0
- package/dist/controls-options-manager/util.js +28 -0
- package/dist/controls-options-manager/util.js.map +1 -0
- package/dist/index.js +11 -18
- package/dist/index.js.map +1 -1
- package/dist/locus-info/controlsUtils.js +12 -29
- package/dist/locus-info/controlsUtils.js.map +1 -1
- package/dist/locus-info/embeddedAppsUtils.js +3 -26
- package/dist/locus-info/embeddedAppsUtils.js.map +1 -1
- package/dist/locus-info/fullState.js +0 -15
- package/dist/locus-info/fullState.js.map +1 -1
- package/dist/locus-info/hostUtils.js +4 -12
- package/dist/locus-info/hostUtils.js.map +1 -1
- package/dist/locus-info/index.js +186 -192
- package/dist/locus-info/index.js.map +1 -1
- package/dist/locus-info/infoUtils.js +3 -37
- package/dist/locus-info/infoUtils.js.map +1 -1
- package/dist/locus-info/mediaSharesUtils.js +12 -38
- package/dist/locus-info/mediaSharesUtils.js.map +1 -1
- package/dist/locus-info/parser.js +92 -118
- package/dist/locus-info/parser.js.map +1 -1
- package/dist/locus-info/selfUtils.js +34 -91
- package/dist/locus-info/selfUtils.js.map +1 -1
- package/dist/media/index.js +66 -153
- package/dist/media/index.js.map +1 -1
- package/dist/media/properties.js +83 -117
- package/dist/media/properties.js.map +1 -1
- package/dist/media/util.js +2 -9
- package/dist/media/util.js.map +1 -1
- package/dist/mediaQualityMetrics/config.js +505 -495
- package/dist/mediaQualityMetrics/config.js.map +1 -1
- package/dist/meeting/in-meeting-actions.js +13 -14
- package/dist/meeting/in-meeting-actions.js.map +1 -1
- package/dist/meeting/index.js +2141 -2210
- package/dist/meeting/index.js.map +1 -1
- package/dist/meeting/muteState.js +59 -82
- package/dist/meeting/muteState.js.map +1 -1
- package/dist/meeting/request.js +308 -264
- package/dist/meeting/request.js.map +1 -1
- package/dist/meeting/request.type.js +7 -0
- package/dist/meeting/request.type.js.map +1 -0
- package/dist/meeting/state.js +21 -31
- package/dist/meeting/state.js.map +1 -1
- package/dist/meeting/util.js +45 -217
- package/dist/meeting/util.js.map +1 -1
- package/dist/meeting-info/collection.js +6 -25
- package/dist/meeting-info/collection.js.map +1 -1
- package/dist/meeting-info/index.js +14 -32
- package/dist/meeting-info/index.js.map +1 -1
- package/dist/meeting-info/meeting-info-v2.js +193 -268
- package/dist/meeting-info/meeting-info-v2.js.map +1 -1
- package/dist/meeting-info/request.js +3 -15
- package/dist/meeting-info/request.js.map +1 -1
- package/dist/meeting-info/util.js +98 -183
- package/dist/meeting-info/util.js.map +1 -1
- package/dist/meeting-info/utilv2.js +137 -228
- package/dist/meeting-info/utilv2.js.map +1 -1
- package/dist/meetings/collection.js +5 -20
- package/dist/meetings/collection.js.map +1 -1
- package/dist/meetings/index.js +490 -560
- package/dist/meetings/index.js.map +1 -1
- package/dist/meetings/request.js +24 -41
- package/dist/meetings/request.js.map +1 -1
- package/dist/meetings/util.js +116 -155
- package/dist/meetings/util.js.map +1 -1
- package/dist/member/index.js +78 -86
- package/dist/member/index.js.map +1 -1
- package/dist/member/util.js +31 -68
- package/dist/member/util.js.map +1 -1
- package/dist/members/collection.js +3 -12
- package/dist/members/collection.js.map +1 -1
- package/dist/members/index.js +95 -200
- package/dist/members/index.js.map +1 -1
- package/dist/members/request.js +16 -39
- package/dist/members/request.js.map +1 -1
- package/dist/members/util.js +9 -38
- package/dist/members/util.js.map +1 -1
- package/dist/metrics/config.js +1 -13
- package/dist/metrics/config.js.map +1 -1
- package/dist/metrics/constants.js +1 -6
- package/dist/metrics/constants.js.map +1 -1
- package/dist/metrics/index.js +54 -156
- package/dist/metrics/index.js.map +1 -1
- package/dist/multistream/mediaRequestManager.js +74 -52
- package/dist/multistream/mediaRequestManager.js.map +1 -1
- package/dist/multistream/receiveSlot.js +48 -65
- package/dist/multistream/receiveSlot.js.map +1 -1
- package/dist/multistream/receiveSlotManager.js +60 -82
- package/dist/multistream/receiveSlotManager.js.map +1 -1
- package/dist/multistream/remoteMedia.js +60 -76
- package/dist/multistream/remoteMedia.js.map +1 -1
- package/dist/multistream/remoteMediaGroup.js +6 -40
- package/dist/multistream/remoteMediaGroup.js.map +1 -1
- package/dist/multistream/remoteMediaManager.js +360 -413
- package/dist/multistream/remoteMediaManager.js.map +1 -1
- package/dist/networkQualityMonitor/index.js +40 -59
- package/dist/networkQualityMonitor/index.js.map +1 -1
- package/dist/personal-meeting-room/index.js +21 -45
- package/dist/personal-meeting-room/index.js.map +1 -1
- package/dist/personal-meeting-room/request.js +1 -31
- package/dist/personal-meeting-room/request.js.map +1 -1
- package/dist/personal-meeting-room/util.js +0 -13
- package/dist/personal-meeting-room/util.js.map +1 -1
- package/dist/reachability/index.js +147 -183
- package/dist/reachability/index.js.map +1 -1
- package/dist/reachability/request.js +15 -23
- package/dist/reachability/request.js.map +1 -1
- package/dist/reactions/constants.js +13 -0
- package/dist/reactions/constants.js.map +1 -0
- package/dist/reactions/reactions.js +109 -0
- package/dist/reactions/reactions.js.map +1 -0
- package/dist/reactions/reactions.type.js +36 -0
- package/dist/reactions/reactions.type.js.map +1 -0
- package/dist/reconnection-manager/index.js +322 -456
- package/dist/reconnection-manager/index.js.map +1 -1
- package/dist/recording-controller/enums.js +17 -0
- package/dist/recording-controller/enums.js.map +1 -0
- package/dist/recording-controller/index.js +343 -0
- package/dist/recording-controller/index.js.map +1 -0
- package/dist/recording-controller/util.js +63 -0
- package/dist/recording-controller/util.js.map +1 -0
- package/dist/roap/index.js +48 -70
- package/dist/roap/index.js.map +1 -1
- package/dist/roap/request.js +143 -131
- package/dist/roap/request.js.map +1 -1
- package/dist/roap/turnDiscovery.js +91 -98
- package/dist/roap/turnDiscovery.js.map +1 -1
- package/dist/statsAnalyzer/global.js +1 -95
- package/dist/statsAnalyzer/global.js.map +1 -1
- package/dist/statsAnalyzer/index.js +361 -449
- package/dist/statsAnalyzer/index.js.map +1 -1
- package/dist/statsAnalyzer/mqaUtil.js +137 -81
- package/dist/statsAnalyzer/mqaUtil.js.map +1 -1
- package/dist/transcription/index.js +22 -47
- package/dist/transcription/index.js.map +1 -1
- package/dist/types/breakouts/breakout.d.ts +8 -0
- package/dist/types/breakouts/collection.d.ts +5 -0
- package/dist/types/breakouts/edit-lock-error.d.ts +15 -0
- package/dist/types/breakouts/index.d.ts +5 -0
- package/dist/types/breakouts/request.d.ts +22 -0
- package/dist/types/breakouts/utils.d.ts +8 -0
- package/dist/types/common/browser-detection.d.ts +9 -0
- package/dist/types/common/collection.d.ts +48 -0
- package/dist/types/common/config.d.ts +2 -0
- package/dist/types/common/errors/captcha-error.d.ts +15 -0
- package/dist/types/common/errors/intent-to-join.d.ts +16 -0
- package/dist/types/common/errors/join-meeting.d.ts +17 -0
- package/dist/types/common/errors/media.d.ts +15 -0
- package/dist/types/common/errors/parameter.d.ts +15 -0
- package/dist/types/common/errors/password-error.d.ts +15 -0
- package/dist/types/common/errors/permission.d.ts +14 -0
- package/dist/types/common/errors/reconnection-in-progress.d.ts +9 -0
- package/dist/types/common/errors/reconnection.d.ts +15 -0
- package/dist/types/common/errors/stats.d.ts +15 -0
- package/dist/types/common/errors/webex-errors.d.ts +69 -0
- package/dist/types/common/errors/webex-meetings-error.d.ts +20 -0
- package/dist/types/common/events/events-scope.d.ts +17 -0
- package/dist/types/common/events/events.d.ts +12 -0
- package/dist/types/common/events/trigger-proxy.d.ts +2 -0
- package/dist/types/common/events/util.d.ts +2 -0
- package/dist/types/common/logs/logger-config.d.ts +2 -0
- package/dist/types/common/logs/logger-proxy.d.ts +2 -0
- package/dist/types/common/logs/request.d.ts +34 -0
- package/dist/types/common/queue.d.ts +32 -0
- package/dist/types/config.d.ts +77 -0
- package/dist/types/constants.d.ts +916 -0
- package/dist/types/controls-options-manager/constants.d.ts +4 -0
- package/dist/types/controls-options-manager/enums.d.ts +5 -0
- package/dist/types/controls-options-manager/index.d.ts +120 -0
- package/dist/types/controls-options-manager/util.d.ts +7 -0
- package/dist/types/index.d.ts +6 -0
- package/dist/types/locus-info/controlsUtils.d.ts +2 -0
- package/dist/types/locus-info/embeddedAppsUtils.d.ts +2 -0
- package/dist/types/locus-info/fullState.d.ts +2 -0
- package/dist/types/locus-info/hostUtils.d.ts +2 -0
- package/dist/types/locus-info/index.d.ts +269 -0
- package/dist/types/locus-info/infoUtils.d.ts +2 -0
- package/dist/types/locus-info/mediaSharesUtils.d.ts +2 -0
- package/dist/types/locus-info/parser.d.ts +212 -0
- package/dist/types/locus-info/selfUtils.d.ts +2 -0
- package/dist/types/media/index.d.ts +32 -0
- package/dist/types/media/properties.d.ts +108 -0
- package/dist/types/media/util.d.ts +2 -0
- package/dist/types/mediaQualityMetrics/config.d.ts +365 -0
- package/dist/types/meeting/in-meeting-actions.d.ts +83 -0
- package/dist/types/meeting/index.d.ts +1699 -0
- package/dist/types/meeting/muteState.d.ts +116 -0
- package/dist/types/meeting/request.d.ts +271 -0
- package/dist/types/meeting/request.type.d.ts +11 -0
- package/dist/types/meeting/state.d.ts +9 -0
- package/dist/types/meeting/util.d.ts +2 -0
- package/dist/types/meeting-info/collection.d.ts +20 -0
- package/dist/types/meeting-info/index.d.ts +57 -0
- package/dist/types/meeting-info/meeting-info-v2.d.ts +93 -0
- package/dist/types/meeting-info/request.d.ts +22 -0
- package/dist/types/meeting-info/util.d.ts +2 -0
- package/dist/types/meeting-info/utilv2.d.ts +2 -0
- package/dist/types/meetings/collection.d.ts +23 -0
- package/dist/types/meetings/index.d.ts +297 -0
- package/dist/types/meetings/request.d.ts +27 -0
- package/dist/types/meetings/util.d.ts +18 -0
- package/dist/types/member/index.d.ts +146 -0
- package/dist/types/member/util.d.ts +2 -0
- package/dist/types/members/collection.d.ts +24 -0
- package/dist/types/members/index.d.ts +320 -0
- package/dist/types/members/request.d.ts +50 -0
- package/dist/types/members/util.d.ts +2 -0
- package/dist/types/metrics/config.d.ts +169 -0
- package/dist/types/metrics/constants.d.ts +53 -0
- package/dist/types/metrics/index.d.ts +152 -0
- package/dist/types/multistream/mediaRequestManager.d.ts +51 -0
- package/dist/types/multistream/receiveSlot.d.ts +64 -0
- package/dist/types/multistream/receiveSlotManager.d.ts +46 -0
- package/dist/types/multistream/remoteMedia.d.ts +100 -0
- package/dist/types/multistream/remoteMediaGroup.d.ts +56 -0
- package/dist/types/multistream/remoteMediaManager.d.ts +241 -0
- package/dist/types/networkQualityMonitor/index.d.ts +70 -0
- package/dist/types/personal-meeting-room/index.d.ts +47 -0
- package/dist/types/personal-meeting-room/request.d.ts +14 -0
- package/dist/types/personal-meeting-room/util.d.ts +2 -0
- package/dist/types/reachability/index.d.ts +140 -0
- package/dist/types/reachability/request.d.ts +37 -0
- package/dist/types/reactions/constants.d.ts +3 -0
- package/dist/types/reactions/reactions.d.ts +4 -0
- package/dist/types/reactions/reactions.type.d.ts +52 -0
- package/dist/types/reconnection-manager/index.d.ts +117 -0
- package/dist/types/recording-controller/enums.d.ts +7 -0
- package/dist/types/recording-controller/index.d.ts +193 -0
- package/dist/types/recording-controller/util.d.ts +13 -0
- package/dist/types/roap/index.d.ts +77 -0
- package/dist/types/roap/request.d.ts +38 -0
- package/dist/types/roap/turnDiscovery.d.ts +74 -0
- package/dist/types/statsAnalyzer/global.d.ts +36 -0
- package/dist/types/statsAnalyzer/index.d.ts +195 -0
- package/dist/types/statsAnalyzer/mqaUtil.d.ts +24 -0
- package/dist/types/transcription/index.d.ts +64 -0
- package/internal-README.md +7 -6
- package/package.json +27 -21
- package/src/breakouts/README.md +199 -0
- package/src/breakouts/breakout.ts +130 -0
- package/src/breakouts/collection.ts +19 -0
- package/src/breakouts/edit-lock-error.ts +25 -0
- package/src/breakouts/index.ts +504 -0
- package/src/breakouts/request.ts +55 -0
- package/src/breakouts/utils.ts +39 -0
- package/src/common/{browser-detection.js → browser-detection.ts} +9 -6
- package/src/common/collection.ts +9 -7
- package/src/common/{config.js → config.ts} +1 -1
- package/src/common/errors/{captcha-error.js → captcha-error.ts} +11 -7
- package/src/common/errors/{intent-to-join.js → intent-to-join.ts} +12 -7
- package/src/common/errors/{join-meeting.js → join-meeting.ts} +17 -8
- package/src/common/errors/{media.js → media.ts} +11 -7
- package/src/common/errors/parameter.ts +11 -7
- package/src/common/errors/{password-error.js → password-error.ts} +11 -7
- package/src/common/errors/{permission.js → permission.ts} +10 -6
- package/src/common/errors/{reconnection.js → reconnection.ts} +11 -7
- package/src/common/errors/{stats.js → stats.ts} +11 -7
- package/src/common/errors/{webex-errors.js → webex-errors.ts} +8 -7
- package/src/common/errors/{webex-meetings-error.js → webex-meetings-error.ts} +4 -2
- package/src/common/events/{events-scope.js → events-scope.ts} +6 -2
- package/src/common/events/{events.js → events.ts} +5 -1
- package/src/common/events/{trigger-proxy.js → trigger-proxy.ts} +9 -5
- package/src/common/events/{util.js → util.ts} +2 -3
- package/src/common/logs/{logger-config.js → logger-config.ts} +1 -2
- package/src/common/logs/logger-proxy.ts +44 -0
- package/src/common/logs/{request.js → request.ts} +22 -9
- package/src/common/queue.ts +1 -2
- package/src/{config.js → config.ts} +17 -12
- package/src/constants.ts +62 -5
- package/src/controls-options-manager/constants.ts +5 -0
- package/src/controls-options-manager/enums.ts +6 -0
- package/src/controls-options-manager/index.ts +183 -0
- package/src/controls-options-manager/util.ts +20 -0
- package/src/index.js +4 -1
- package/src/locus-info/controlsUtils.ts +114 -0
- package/src/locus-info/{embeddedAppsUtils.js → embeddedAppsUtils.ts} +5 -6
- package/src/locus-info/{fullState.js → fullState.ts} +16 -12
- package/src/locus-info/{hostUtils.js → hostUtils.ts} +9 -8
- package/src/locus-info/{index.js → index.ts} +150 -66
- package/src/locus-info/{infoUtils.js → infoUtils.ts} +19 -8
- package/src/locus-info/{mediaSharesUtils.js → mediaSharesUtils.ts} +17 -17
- package/src/locus-info/{parser.js → parser.ts} +67 -79
- package/src/locus-info/{selfUtils.js → selfUtils.ts} +123 -68
- package/src/media/{index.js → index.ts} +182 -173
- package/src/media/{properties.js → properties.ts} +60 -37
- package/src/media/{util.js → util.ts} +2 -2
- package/src/mediaQualityMetrics/config.ts +384 -0
- package/src/meeting/in-meeting-actions.ts +31 -3
- package/src/meeting/{index.js → index.ts} +2512 -1579
- package/src/meeting/{muteState.js → muteState.ts} +95 -49
- package/src/meeting/{request.js → request.ts} +326 -142
- package/src/meeting/request.type.ts +13 -0
- package/src/meeting/{state.js → state.ts} +50 -35
- package/src/meeting/{util.js → util.ts} +117 -119
- package/src/meeting-info/{collection.js → collection.ts} +6 -2
- package/src/meeting-info/{index.js → index.ts} +42 -36
- package/src/meeting-info/meeting-info-v2.ts +273 -0
- package/src/meeting-info/{request.js → request.ts} +14 -4
- package/src/meeting-info/{util.js → util.ts} +60 -51
- package/src/meeting-info/{utilv2.js → utilv2.ts} +65 -58
- package/src/meetings/{collection.js → collection.ts} +6 -3
- package/src/meetings/index.ts +1159 -0
- package/src/meetings/{request.js → request.ts} +32 -25
- package/src/meetings/{util.js → util.ts} +58 -32
- package/src/member/{index.js → index.ts} +102 -56
- package/src/member/{util.js → util.ts} +52 -25
- package/src/members/{collection.js → collection.ts} +2 -2
- package/src/members/{index.js → index.ts} +221 -142
- package/src/members/{request.js → request.ts} +60 -16
- package/src/members/{util.js → util.ts} +50 -48
- package/src/metrics/{config.js → config.ts} +253 -92
- package/src/metrics/{constants.js → constants.ts} +0 -6
- package/src/metrics/{index.js → index.ts} +105 -94
- package/src/multistream/mediaRequestManager.ts +101 -39
- package/src/multistream/receiveSlot.ts +62 -26
- package/src/multistream/receiveSlotManager.ts +35 -21
- package/src/multistream/remoteMedia.ts +38 -5
- package/src/multistream/remoteMediaGroup.ts +4 -3
- package/src/multistream/remoteMediaManager.ts +152 -36
- package/src/networkQualityMonitor/{index.js → index.ts} +41 -29
- package/src/personal-meeting-room/{index.js → index.ts} +28 -19
- package/src/personal-meeting-room/{request.js → request.ts} +13 -4
- package/src/personal-meeting-room/{util.js → util.ts} +4 -4
- package/src/reachability/{index.js → index.ts} +109 -85
- package/src/reachability/request.ts +46 -35
- package/src/reactions/constants.ts +4 -0
- package/src/reactions/reactions.ts +104 -0
- package/src/reactions/reactions.type.ts +62 -0
- package/src/reconnection-manager/{index.js → index.ts} +196 -103
- package/src/recording-controller/enums.ts +8 -0
- package/src/recording-controller/index.ts +315 -0
- package/src/recording-controller/util.ts +58 -0
- package/src/roap/{index.js → index.ts} +77 -60
- package/src/roap/request.ts +172 -0
- package/src/roap/turnDiscovery.ts +81 -41
- package/src/statsAnalyzer/global.ts +37 -0
- package/src/statsAnalyzer/index.ts +1234 -0
- package/src/statsAnalyzer/mqaUtil.ts +293 -0
- package/src/transcription/{index.js → index.ts} +46 -39
- package/test/integration/spec/converged-space-meetings.js +176 -0
- package/test/integration/spec/journey.js +665 -464
- package/test/integration/spec/space-meeting.js +320 -206
- package/test/integration/spec/transcription.js +7 -8
- package/test/unit/spec/breakouts/breakout.ts +147 -0
- package/test/unit/spec/breakouts/collection.ts +15 -0
- package/test/unit/spec/breakouts/edit-lock-error.ts +30 -0
- package/test/unit/spec/breakouts/index.ts +707 -0
- package/test/unit/spec/breakouts/request.ts +104 -0
- package/test/unit/spec/breakouts/utils.js +47 -0
- package/test/unit/spec/common/browser-detection.js +9 -28
- package/test/unit/spec/controls-options-manager/index.js +124 -0
- package/test/unit/spec/controls-options-manager/util.js +66 -0
- package/test/unit/spec/fixture/locus.js +92 -90
- package/test/unit/spec/locus-info/controlsUtils.js +25 -5
- package/test/unit/spec/locus-info/embeddedAppsUtils.js +8 -6
- package/test/unit/spec/locus-info/index.js +104 -2
- package/test/unit/spec/locus-info/infoUtils.js +41 -32
- package/test/unit/spec/locus-info/lib/BasicSeqCmp.json +88 -430
- package/test/unit/spec/locus-info/lib/SeqCmp.json +513 -685
- package/test/unit/spec/locus-info/parser.js +3 -9
- package/test/unit/spec/locus-info/selfConstant.js +97 -103
- package/test/unit/spec/locus-info/selfUtils.js +105 -12
- package/test/unit/spec/media/index.ts +39 -53
- package/test/unit/spec/media/properties.ts +9 -9
- package/test/unit/spec/meeting/in-meeting-actions.ts +13 -2
- package/test/unit/spec/meeting/index.js +2253 -811
- package/test/unit/spec/meeting/muteState.js +74 -55
- package/test/unit/spec/meeting/request.js +141 -43
- package/test/unit/spec/meeting/utils.js +106 -171
- package/test/unit/spec/meeting-info/meetinginfov2.js +100 -73
- package/test/unit/spec/meeting-info/request.js +7 -9
- package/test/unit/spec/meeting-info/util.js +11 -12
- package/test/unit/spec/meeting-info/utilv2.js +110 -74
- package/test/unit/spec/meetings/collection.js +1 -1
- package/test/unit/spec/meetings/index.js +439 -257
- package/test/unit/spec/meetings/utils.js +14 -12
- package/test/unit/spec/member/index.js +0 -1
- package/test/unit/spec/member/util.js +31 -7
- package/test/unit/spec/members/index.js +104 -54
- package/test/unit/spec/members/request.js +29 -20
- package/test/unit/spec/members/utils.js +8 -5
- package/test/unit/spec/metrics/index.js +16 -21
- package/test/unit/spec/multistream/mediaRequestManager.ts +318 -64
- package/test/unit/spec/multistream/receiveSlot.ts +68 -17
- package/test/unit/spec/multistream/receiveSlotManager.ts +41 -13
- package/test/unit/spec/multistream/remoteMedia.ts +38 -2
- package/test/unit/spec/multistream/remoteMediaGroup.ts +5 -5
- package/test/unit/spec/multistream/remoteMediaManager.ts +412 -65
- package/test/unit/spec/networkQualityMonitor/index.js +24 -18
- package/test/unit/spec/personal-meeting-room/personal-meeting-room.js +2 -7
- package/test/unit/spec/reachability/index.ts +70 -27
- package/test/unit/spec/reachability/request.js +66 -0
- package/test/unit/spec/reconnection-manager/index.js +58 -30
- package/test/unit/spec/recording-controller/index.js +231 -0
- package/test/unit/spec/recording-controller/util.js +102 -0
- package/test/unit/spec/roap/index.ts +12 -8
- package/test/unit/spec/roap/request.ts +217 -0
- package/test/unit/spec/roap/turnDiscovery.ts +72 -49
- package/test/unit/spec/stats-analyzer/index.js +86 -57
- package/test/utils/cmr.js +44 -42
- package/test/utils/constants.js +9 -0
- package/test/utils/testUtils.js +98 -77
- package/test/utils/webex-config.js +22 -18
- package/test/utils/webex-test-users.js +57 -50
- package/tsconfig.json +6 -0
- package/dist/media/internal-media-core-wrapper.js +0 -22
- package/dist/media/internal-media-core-wrapper.js.map +0 -1
- package/dist/meeting/effectsState.js +0 -327
- package/dist/meeting/effectsState.js.map +0 -1
- package/dist/multistream/multistreamMedia.js +0 -116
- package/dist/multistream/multistreamMedia.js.map +0 -1
- package/dist/peer-connection-manager/util.js +0 -124
- package/dist/peer-connection-manager/util.js.map +0 -1
- package/src/common/logs/logger-proxy.js +0 -33
- package/src/locus-info/controlsUtils.js +0 -102
- package/src/media/internal-media-core-wrapper.ts +0 -9
- package/src/mediaQualityMetrics/config.js +0 -382
- package/src/meeting/effectsState.js +0 -205
- package/src/meeting-info/meeting-info-v2.js +0 -255
- package/src/meetings/index.js +0 -1015
- package/src/multistream/multistreamMedia.ts +0 -92
- package/src/peer-connection-manager/util.ts +0 -117
- package/src/roap/request.js +0 -127
- package/src/statsAnalyzer/global.js +0 -133
- package/src/statsAnalyzer/index.js +0 -1006
- package/src/statsAnalyzer/mqaUtil.js +0 -173
- package/test/unit/spec/meeting/effectsState.js +0 -291
- package/test/unit/spec/peerconnection-manager/utils.test-fixtures.ts +0 -389
- /package/src/common/errors/{reconnection-in-progress.js → reconnection-in-progress.ts} +0 -0
|
@@ -1,13 +1,20 @@
|
|
|
1
|
-
|
|
1
|
+
/* eslint-disable valid-jsdoc */
|
|
2
|
+
import {
|
|
3
|
+
MediaType,
|
|
4
|
+
ReceiveSlot as WcmeReceiveSlot,
|
|
5
|
+
ReceiveSlotEvents as WcmeReceiveSlotEvents,
|
|
6
|
+
SourceState,
|
|
7
|
+
} from '@webex/internal-media-core';
|
|
2
8
|
|
|
3
9
|
import LoggerProxy from '../common/logs/logger-proxy';
|
|
4
10
|
import EventsScope from '../common/events/events-scope';
|
|
5
11
|
|
|
6
12
|
export const ReceiveSlotEvents = {
|
|
7
13
|
SourceUpdate: 'sourceUpdate',
|
|
14
|
+
MaxFsUpdate: 'maxFsUpdate',
|
|
8
15
|
};
|
|
9
16
|
|
|
10
|
-
export type SourceState
|
|
17
|
+
export type {SourceState} from '@webex/internal-media-core';
|
|
11
18
|
export type CSI = number;
|
|
12
19
|
export type MemberId = string;
|
|
13
20
|
export type ReceiveSlotId = string;
|
|
@@ -21,31 +28,31 @@ export type FindMemberIdCallback = (csi: CSI) => MemberId | undefined;
|
|
|
21
28
|
* for example some participant's main video or audio
|
|
22
29
|
*/
|
|
23
30
|
export class ReceiveSlot extends EventsScope {
|
|
24
|
-
private readonly mcReceiveSlot:
|
|
31
|
+
private readonly mcReceiveSlot: WcmeReceiveSlot;
|
|
25
32
|
|
|
26
33
|
private readonly findMemberIdCallback: FindMemberIdCallback;
|
|
27
34
|
|
|
28
35
|
public readonly id: ReceiveSlotId;
|
|
29
36
|
|
|
30
|
-
public readonly mediaType:
|
|
37
|
+
public readonly mediaType: MediaType;
|
|
31
38
|
|
|
32
39
|
#memberId?: MemberId;
|
|
33
40
|
|
|
34
41
|
#csi?: CSI;
|
|
35
42
|
|
|
36
|
-
#sourceState:
|
|
43
|
+
#sourceState: SourceState;
|
|
37
44
|
|
|
38
45
|
/**
|
|
39
46
|
* constructor - don't use it directly, you should always use meeting.receiveSlotManager.allocateSlot()
|
|
40
47
|
* to create any receive slots
|
|
41
48
|
*
|
|
42
|
-
* @param {
|
|
43
|
-
* @param {
|
|
49
|
+
* @param {MediaType} mediaType
|
|
50
|
+
* @param {ReceiveSlot} mcReceiveSlot
|
|
44
51
|
* @param {FindMemberIdCallback} findMemberIdCallback callback for finding memberId for given CSI
|
|
45
52
|
*/
|
|
46
53
|
constructor(
|
|
47
|
-
mediaType:
|
|
48
|
-
mcReceiveSlot:
|
|
54
|
+
mediaType: MediaType,
|
|
55
|
+
mcReceiveSlot: WcmeReceiveSlot,
|
|
49
56
|
findMemberIdCallback: FindMemberIdCallback
|
|
50
57
|
) {
|
|
51
58
|
super();
|
|
@@ -75,6 +82,25 @@ export class ReceiveSlot extends EventsScope {
|
|
|
75
82
|
return this.#csi;
|
|
76
83
|
}
|
|
77
84
|
|
|
85
|
+
/**
|
|
86
|
+
* Set the max frame size for this slot
|
|
87
|
+
* @param newFs frame size
|
|
88
|
+
*/
|
|
89
|
+
public setMaxFs(newFs) {
|
|
90
|
+
// emit event for media request manager to listen to
|
|
91
|
+
|
|
92
|
+
this.emit(
|
|
93
|
+
{
|
|
94
|
+
file: 'meeting/receiveSlot',
|
|
95
|
+
function: 'findMemberId',
|
|
96
|
+
},
|
|
97
|
+
ReceiveSlotEvents.MaxFsUpdate,
|
|
98
|
+
{
|
|
99
|
+
maxFs: newFs,
|
|
100
|
+
}
|
|
101
|
+
);
|
|
102
|
+
}
|
|
103
|
+
|
|
78
104
|
/**
|
|
79
105
|
* Getter for sourceState
|
|
80
106
|
*/
|
|
@@ -85,15 +111,15 @@ export class ReceiveSlot extends EventsScope {
|
|
|
85
111
|
/**
|
|
86
112
|
* registers event handlers with the underlying ReceiveSlot
|
|
87
113
|
*/
|
|
88
|
-
setupEventListeners() {
|
|
114
|
+
private setupEventListeners() {
|
|
89
115
|
const scope = {
|
|
90
116
|
file: 'meeting/receiveSlot',
|
|
91
117
|
function: 'setupEventListeners',
|
|
92
118
|
};
|
|
93
119
|
|
|
94
120
|
this.mcReceiveSlot.on(
|
|
95
|
-
|
|
96
|
-
(state:
|
|
121
|
+
WcmeReceiveSlotEvents.SourceUpdate,
|
|
122
|
+
(state: SourceState, csi?: number) => {
|
|
97
123
|
LoggerProxy.logger.log(
|
|
98
124
|
`ReceiveSlot#setupEventListeners --> got source update on receive slot ${this.id}, mediaType=${this.mediaType}, csi=${csi}, state=${state}`
|
|
99
125
|
);
|
|
@@ -110,6 +136,29 @@ export class ReceiveSlot extends EventsScope {
|
|
|
110
136
|
);
|
|
111
137
|
}
|
|
112
138
|
|
|
139
|
+
/** Tries to find the member id for this receive slot if it hasn't got one */
|
|
140
|
+
public findMemberId() {
|
|
141
|
+
if (this.#memberId === undefined && this.#csi) {
|
|
142
|
+
this.#memberId = this.findMemberIdCallback(this.#csi);
|
|
143
|
+
|
|
144
|
+
if (this.#memberId) {
|
|
145
|
+
// if we found the memberId, simulate source update so that the client app knows that something's changed
|
|
146
|
+
this.emit(
|
|
147
|
+
{
|
|
148
|
+
file: 'meeting/receiveSlot',
|
|
149
|
+
function: 'findMemberId',
|
|
150
|
+
},
|
|
151
|
+
ReceiveSlotEvents.SourceUpdate,
|
|
152
|
+
{
|
|
153
|
+
state: this.#sourceState,
|
|
154
|
+
csi: this.#csi,
|
|
155
|
+
memberId: this.#memberId,
|
|
156
|
+
}
|
|
157
|
+
);
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
|
|
113
162
|
/**
|
|
114
163
|
* The MediaStream object associated with this slot.
|
|
115
164
|
*
|
|
@@ -122,20 +171,7 @@ export class ReceiveSlot extends EventsScope {
|
|
|
122
171
|
/**
|
|
123
172
|
* The underlying WCME receive slot
|
|
124
173
|
*/
|
|
125
|
-
get wcmeReceiveSlot():
|
|
174
|
+
get wcmeReceiveSlot(): WcmeReceiveSlot {
|
|
126
175
|
return this.mcReceiveSlot;
|
|
127
176
|
}
|
|
128
|
-
|
|
129
|
-
/**
|
|
130
|
-
* Resets the source state to the default 'no source' value.
|
|
131
|
-
* This function should be called on receive slots that are
|
|
132
|
-
* no longer part of a media request. It's needed because WCME
|
|
133
|
-
* does not send any more events on such slots, so the sourceState
|
|
134
|
-
* value would not represent the truth anymore.
|
|
135
|
-
*/
|
|
136
|
-
public resetSourceState() {
|
|
137
|
-
this.#sourceState = 'no source';
|
|
138
|
-
this.#csi = undefined;
|
|
139
|
-
this.#memberId = undefined;
|
|
140
|
-
}
|
|
141
177
|
}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
|
+
/* eslint-disable valid-jsdoc */
|
|
1
2
|
/* eslint-disable import/prefer-default-export */
|
|
2
|
-
import {
|
|
3
|
+
import {MediaType} from '@webex/internal-media-core';
|
|
3
4
|
|
|
4
5
|
import LoggerProxy from '../common/logs/logger-proxy';
|
|
5
6
|
import Meeting from '../meeting';
|
|
@@ -11,9 +12,9 @@ import {CSI, ReceiveSlot} from './receiveSlot';
|
|
|
11
12
|
* so this manager has a pool in order to re-use the slots that were released earlier.
|
|
12
13
|
*/
|
|
13
14
|
export class ReceiveSlotManager {
|
|
14
|
-
private allocatedSlots: {[key in
|
|
15
|
+
private allocatedSlots: {[key in MediaType]: ReceiveSlot[]};
|
|
15
16
|
|
|
16
|
-
private freeSlots: {[key in
|
|
17
|
+
private freeSlots: {[key in MediaType]: ReceiveSlot[]};
|
|
17
18
|
|
|
18
19
|
private meeting: Meeting;
|
|
19
20
|
|
|
@@ -23,16 +24,16 @@ export class ReceiveSlotManager {
|
|
|
23
24
|
*/
|
|
24
25
|
constructor(meeting) {
|
|
25
26
|
this.allocatedSlots = {
|
|
26
|
-
[
|
|
27
|
-
[
|
|
28
|
-
[
|
|
29
|
-
[
|
|
27
|
+
[MediaType.AudioMain]: [],
|
|
28
|
+
[MediaType.VideoMain]: [],
|
|
29
|
+
[MediaType.AudioSlides]: [],
|
|
30
|
+
[MediaType.VideoSlides]: [],
|
|
30
31
|
};
|
|
31
32
|
this.freeSlots = {
|
|
32
|
-
[
|
|
33
|
-
[
|
|
34
|
-
[
|
|
35
|
-
[
|
|
33
|
+
[MediaType.AudioMain]: [],
|
|
34
|
+
[MediaType.VideoMain]: [],
|
|
35
|
+
[MediaType.AudioSlides]: [],
|
|
36
|
+
[MediaType.VideoSlides]: [],
|
|
36
37
|
};
|
|
37
38
|
this.meeting = meeting;
|
|
38
39
|
}
|
|
@@ -40,10 +41,10 @@ export class ReceiveSlotManager {
|
|
|
40
41
|
/**
|
|
41
42
|
* Creates a new receive slot or returns one from the existing pool of free slots
|
|
42
43
|
*
|
|
43
|
-
* @param {
|
|
44
|
+
* @param {MediaType} mediaType
|
|
44
45
|
* @returns {Promise<ReceiveSlot>}
|
|
45
46
|
*/
|
|
46
|
-
async allocateSlot(mediaType:
|
|
47
|
+
async allocateSlot(mediaType: MediaType): Promise<ReceiveSlot> {
|
|
47
48
|
if (!this.meeting?.mediaProperties?.webrtcMediaConnection) {
|
|
48
49
|
return Promise.reject(new Error('Webrtc media connection is missing'));
|
|
49
50
|
}
|
|
@@ -66,6 +67,7 @@ export class ReceiveSlotManager {
|
|
|
66
67
|
const receiveSlot = new ReceiveSlot(
|
|
67
68
|
mediaType,
|
|
68
69
|
wcmeReceiveSlot,
|
|
70
|
+
// @ts-ignore
|
|
69
71
|
(csi: CSI) => this.meeting.members.findMemberByCsi(csi)?.id
|
|
70
72
|
);
|
|
71
73
|
|
|
@@ -100,16 +102,16 @@ export class ReceiveSlotManager {
|
|
|
100
102
|
*/
|
|
101
103
|
reset() {
|
|
102
104
|
this.allocatedSlots = {
|
|
103
|
-
[
|
|
104
|
-
[
|
|
105
|
-
[
|
|
106
|
-
[
|
|
105
|
+
[MediaType.AudioMain]: [],
|
|
106
|
+
[MediaType.VideoMain]: [],
|
|
107
|
+
[MediaType.AudioSlides]: [],
|
|
108
|
+
[MediaType.VideoSlides]: [],
|
|
107
109
|
};
|
|
108
110
|
this.freeSlots = {
|
|
109
|
-
[
|
|
110
|
-
[
|
|
111
|
-
[
|
|
112
|
-
[
|
|
111
|
+
[MediaType.AudioMain]: [],
|
|
112
|
+
[MediaType.VideoMain]: [],
|
|
113
|
+
[MediaType.AudioSlides]: [],
|
|
114
|
+
[MediaType.VideoSlides]: [],
|
|
113
115
|
};
|
|
114
116
|
}
|
|
115
117
|
|
|
@@ -139,4 +141,16 @@ export class ReceiveSlotManager {
|
|
|
139
141
|
numFreeSlots,
|
|
140
142
|
};
|
|
141
143
|
}
|
|
144
|
+
|
|
145
|
+
/**
|
|
146
|
+
* Tries to find the member id on all allocated receive slots
|
|
147
|
+
* This function should be called when new members are added to the meeting.
|
|
148
|
+
*/
|
|
149
|
+
updateMemberIds() {
|
|
150
|
+
Object.keys(this.allocatedSlots).forEach((key) => {
|
|
151
|
+
this.allocatedSlots[key].forEach((slot: ReceiveSlot) => {
|
|
152
|
+
slot.findMemberId();
|
|
153
|
+
});
|
|
154
|
+
});
|
|
155
|
+
}
|
|
142
156
|
}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
/* eslint-disable valid-jsdoc */
|
|
2
|
+
import {MediaType, SourceState} from '@webex/internal-media-core';
|
|
2
3
|
import LoggerProxy from '../common/logs/logger-proxy';
|
|
3
4
|
import EventsScope from '../common/events/events-scope';
|
|
4
5
|
|
|
@@ -7,6 +8,7 @@ import {CSI, ReceiveSlot, ReceiveSlotEvents} from './receiveSlot';
|
|
|
7
8
|
|
|
8
9
|
export const RemoteMediaEvents = {
|
|
9
10
|
SourceUpdate: ReceiveSlotEvents.SourceUpdate,
|
|
11
|
+
Stopped: 'stopped',
|
|
10
12
|
};
|
|
11
13
|
|
|
12
14
|
export type RemoteVideoResolution =
|
|
@@ -55,7 +57,7 @@ export function getMaxFs(paneSize: RemoteVideoResolution): number {
|
|
|
55
57
|
}
|
|
56
58
|
|
|
57
59
|
type Options = {
|
|
58
|
-
resolution?: RemoteVideoResolution; // applies only to groups of type
|
|
60
|
+
resolution?: RemoteVideoResolution; // applies only to groups of type MediaType.VideoMain and MediaType.VideoSlides
|
|
59
61
|
};
|
|
60
62
|
|
|
61
63
|
export type RemoteMediaId = string;
|
|
@@ -100,6 +102,29 @@ export class RemoteMedia extends EventsScope {
|
|
|
100
102
|
this.id = `RM${remoteMediaCounter}-${this.receiveSlot.id}`;
|
|
101
103
|
}
|
|
102
104
|
|
|
105
|
+
/**
|
|
106
|
+
* Supply the width and height of the video element
|
|
107
|
+
* to restrict the requested resolution to this size
|
|
108
|
+
* @param width width of the video element
|
|
109
|
+
* @param height height of the video element
|
|
110
|
+
*/
|
|
111
|
+
public setSizeHint(width, height) {
|
|
112
|
+
// only base on height for now
|
|
113
|
+
let fs: number;
|
|
114
|
+
|
|
115
|
+
if (height < 135) {
|
|
116
|
+
fs = 60;
|
|
117
|
+
} else if (height < 270) {
|
|
118
|
+
fs = 240;
|
|
119
|
+
} else if (height < 540) {
|
|
120
|
+
fs = 920;
|
|
121
|
+
} else {
|
|
122
|
+
fs = 3600;
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
this.receiveSlot?.setMaxFs(fs);
|
|
126
|
+
}
|
|
127
|
+
|
|
103
128
|
/**
|
|
104
129
|
* Invalidates the remote media by clearing the reference to a receive slot and
|
|
105
130
|
* cancelling the media request.
|
|
@@ -108,10 +133,18 @@ export class RemoteMedia extends EventsScope {
|
|
|
108
133
|
* @param {boolean} commit - whether to commit the cancellation of the media request
|
|
109
134
|
* @internal
|
|
110
135
|
*/
|
|
111
|
-
public stop(commit
|
|
136
|
+
public stop(commit = true) {
|
|
112
137
|
this.cancelMediaRequest(commit);
|
|
113
138
|
this.receiveSlot?.removeAllListeners();
|
|
114
139
|
this.receiveSlot = undefined;
|
|
140
|
+
this.emit(
|
|
141
|
+
{
|
|
142
|
+
file: 'multistream/remoteMedia',
|
|
143
|
+
function: 'stop',
|
|
144
|
+
},
|
|
145
|
+
RemoteMediaEvents.Stopped,
|
|
146
|
+
{}
|
|
147
|
+
);
|
|
115
148
|
}
|
|
116
149
|
|
|
117
150
|
/**
|
|
@@ -164,7 +197,7 @@ export class RemoteMedia extends EventsScope {
|
|
|
164
197
|
private setupEventListeners() {
|
|
165
198
|
if (this.receiveSlot) {
|
|
166
199
|
const scope = {
|
|
167
|
-
file: '
|
|
200
|
+
file: 'multistream/remoteMedia',
|
|
168
201
|
function: 'setupEventListeners',
|
|
169
202
|
};
|
|
170
203
|
|
|
@@ -177,7 +210,7 @@ export class RemoteMedia extends EventsScope {
|
|
|
177
210
|
/**
|
|
178
211
|
* Getter for mediaType
|
|
179
212
|
*/
|
|
180
|
-
public get mediaType() {
|
|
213
|
+
public get mediaType(): MediaType {
|
|
181
214
|
return this.receiveSlot?.mediaType;
|
|
182
215
|
}
|
|
183
216
|
|
|
@@ -198,7 +231,7 @@ export class RemoteMedia extends EventsScope {
|
|
|
198
231
|
/**
|
|
199
232
|
* Getter for source state
|
|
200
233
|
*/
|
|
201
|
-
public get sourceState() {
|
|
234
|
+
public get sourceState(): SourceState {
|
|
202
235
|
return this.receiveSlot?.sourceState;
|
|
203
236
|
}
|
|
204
237
|
|
|
@@ -8,8 +8,8 @@ import {MediaRequestId, MediaRequestManager} from './mediaRequestManager';
|
|
|
8
8
|
import {CSI, ReceiveSlot} from './receiveSlot';
|
|
9
9
|
|
|
10
10
|
type Options = {
|
|
11
|
-
resolution?: RemoteVideoResolution; // applies only to groups of type
|
|
12
|
-
preferLiveVideo?: boolean; // applies only to groups of type
|
|
11
|
+
resolution?: RemoteVideoResolution; // applies only to groups of type MediaType.VideoMain and MediaType.VideoSlides
|
|
12
|
+
preferLiveVideo?: boolean; // applies only to groups of type MediaType.VideoMain and MediaType.VideoSlides
|
|
13
13
|
};
|
|
14
14
|
|
|
15
15
|
export class RemoteMediaGroup {
|
|
@@ -62,6 +62,7 @@ export class RemoteMediaGroup {
|
|
|
62
62
|
// return a shallow copy so that the client cannot modify this.pinnedRemoteMedia array
|
|
63
63
|
return [...this.pinnedRemoteMedia];
|
|
64
64
|
}
|
|
65
|
+
|
|
65
66
|
return [...this.unpinnedRemoteMedia, ...this.pinnedRemoteMedia];
|
|
66
67
|
}
|
|
67
68
|
|
|
@@ -189,7 +190,7 @@ export class RemoteMediaGroup {
|
|
|
189
190
|
* @param{boolean} commit whether to commit the cancellation of media requests
|
|
190
191
|
* @internal
|
|
191
192
|
*/
|
|
192
|
-
public stop(commit
|
|
193
|
+
public stop(commit = true) {
|
|
193
194
|
this.unpinnedRemoteMedia.forEach((remoteMedia) => remoteMedia.stop(false));
|
|
194
195
|
this.pinnedRemoteMedia.forEach((remoteMedia) => remoteMedia.stop(false));
|
|
195
196
|
this.cancelActiveSpeakerMediaRequest(false);
|