@webex/plugin-meetings 3.0.0-beta.2 → 3.0.0-beta.21
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 +116 -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/index.js +226 -0
- package/dist/breakouts/index.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 +88 -46
- package/dist/constants.js.map +1 -1
- package/dist/index.js +4 -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 +184 -190
- 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 +67 -111
- package/dist/media/index.js.map +1 -1
- package/dist/media/properties.js +80 -114
- 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 +10 -12
- package/dist/mediaQualityMetrics/config.js.map +1 -1
- package/dist/meeting/effectsState.js +125 -190
- package/dist/meeting/effectsState.js.map +1 -1
- package/dist/meeting/in-meeting-actions.js +5 -14
- package/dist/meeting/in-meeting-actions.js.map +1 -1
- package/dist/meeting/index.js +1692 -1925
- package/dist/meeting/index.js.map +1 -1
- package/dist/meeting/muteState.js +36 -77
- package/dist/meeting/muteState.js.map +1 -1
- package/dist/meeting/request.js +224 -230
- 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 +43 -215
- 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 +99 -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 +93 -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 +0 -2
- package/dist/metrics/config.js.map +1 -1
- package/dist/metrics/constants.js +1 -2
- package/dist/metrics/constants.js.map +1 -1
- package/dist/metrics/index.js +55 -135
- package/dist/metrics/index.js.map +1 -1
- package/dist/multistream/mediaRequestManager.js +57 -32
- package/dist/multistream/mediaRequestManager.js.map +1 -1
- package/dist/multistream/multistreamMedia.js +15 -21
- package/dist/multistream/multistreamMedia.js.map +1 -1
- package/dist/multistream/receiveSlot.js +10 -50
- package/dist/multistream/receiveSlot.js.map +1 -1
- package/dist/multistream/receiveSlotManager.js +45 -82
- package/dist/multistream/receiveSlotManager.js.map +1 -1
- package/dist/multistream/remoteMedia.js +18 -58
- 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 +362 -416
- package/dist/multistream/remoteMediaManager.js.map +1 -1
- package/dist/networkQualityMonitor/index.js +36 -57
- 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 +138 -182
- package/dist/reachability/index.js.map +1 -1
- package/dist/reachability/request.js +3 -18
- 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 -455
- 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 +39 -64
- package/dist/roap/index.js.map +1 -1
- package/dist/roap/request.js +94 -113
- package/dist/roap/request.js.map +1 -1
- package/dist/roap/turnDiscovery.js +85 -94
- package/dist/roap/turnDiscovery.js.map +1 -1
- package/dist/statsAnalyzer/global.js +0 -2
- package/dist/statsAnalyzer/global.js.map +1 -1
- package/dist/statsAnalyzer/index.js +85 -175
- package/dist/statsAnalyzer/index.js.map +1 -1
- package/dist/statsAnalyzer/mqaUtil.js +72 -53
- package/dist/statsAnalyzer/mqaUtil.js.map +1 -1
- package/dist/transcription/index.js +22 -47
- package/dist/transcription/index.js.map +1 -1
- package/internal-README.md +7 -6
- package/package.json +25 -20
- package/src/breakouts/README.md +190 -0
- package/src/breakouts/breakout.ts +110 -0
- package/src/breakouts/collection.ts +19 -0
- package/src/breakouts/index.ts +225 -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-in-progress.js → reconnection-in-progress.ts} +0 -0
- 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 +40 -1
- package/src/index.js +2 -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} +148 -64
- 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} +181 -131
- package/src/media/{properties.js → properties.ts} +47 -28
- package/src/media/{util.js → util.ts} +2 -2
- package/src/mediaQualityMetrics/{config.js → config.ts} +46 -46
- package/src/meeting/{effectsState.js → effectsState.ts} +47 -41
- package/src/meeting/in-meeting-actions.ts +15 -3
- package/src/meeting/{index.js → index.ts} +2263 -1427
- package/src/meeting/{muteState.js → muteState.ts} +78 -42
- package/src/meeting/{request.js → request.ts} +292 -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} +112 -115
- 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} +34 -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} +219 -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} +254 -83
- package/src/metrics/{constants.js → constants.ts} +0 -2
- package/src/metrics/{index.js → index.ts} +106 -74
- package/src/multistream/mediaRequestManager.ts +81 -15
- package/src/multistream/multistreamMedia.ts +5 -0
- package/src/multistream/receiveSlot.ts +18 -12
- package/src/multistream/receiveSlotManager.ts +23 -21
- package/src/multistream/remoteMedia.ts +15 -5
- package/src/multistream/remoteMediaGroup.ts +4 -3
- package/src/multistream/remoteMediaManager.ts +153 -37
- package/src/networkQualityMonitor/{index.js → index.ts} +37 -25
- 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} +99 -83
- package/src/reachability/request.ts +39 -33
- 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} +195 -102
- 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} +73 -56
- package/src/roap/request.ts +157 -0
- package/src/roap/turnDiscovery.ts +77 -37
- package/src/statsAnalyzer/{global.js → global.ts} +30 -33
- package/src/statsAnalyzer/{index.js → index.ts} +468 -192
- package/src/statsAnalyzer/mqaUtil.ts +290 -0
- package/src/transcription/{index.js → index.ts} +46 -39
- package/test/integration/spec/journey.js +664 -463
- package/test/integration/spec/space-meeting.js +320 -206
- package/test/integration/spec/transcription.js +7 -8
- package/test/unit/spec/breakouts/breakout.ts +119 -0
- package/test/unit/spec/breakouts/collection.ts +15 -0
- package/test/unit/spec/breakouts/index.ts +293 -0
- package/test/unit/spec/common/browser-detection.js +9 -28
- 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 +31 -47
- package/test/unit/spec/media/properties.ts +9 -9
- package/test/unit/spec/meeting/effectsState.js +39 -45
- package/test/unit/spec/meeting/in-meeting-actions.ts +5 -2
- package/test/unit/spec/meeting/index.js +2017 -742
- package/test/unit/spec/meeting/muteState.js +42 -33
- package/test/unit/spec/meeting/request.js +115 -44
- package/test/unit/spec/meeting/utils.js +104 -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 +316 -50
- package/test/unit/spec/multistream/receiveSlot.ts +6 -6
- package/test/unit/spec/multistream/receiveSlotManager.ts +13 -13
- package/test/unit/spec/multistream/remoteMedia.ts +10 -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 +21 -15
- package/test/unit/spec/personal-meeting-room/personal-meeting-room.js +2 -7
- package/test/unit/spec/reachability/index.ts +58 -26
- package/test/unit/spec/reconnection-manager/index.js +102 -9
- 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 +2 -1
- package/test/unit/spec/roap/request.ts +114 -0
- package/test/unit/spec/roap/turnDiscovery.ts +64 -45
- package/test/unit/spec/stats-analyzer/index.js +27 -22
- package/test/utils/cmr.js +44 -42
- package/test/utils/testUtils.js +83 -74
- package/test/utils/webex-config.js +18 -18
- package/test/utils/webex-test-users.js +54 -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/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/meeting-info/meeting-info-v2.js +0 -255
- package/src/meetings/index.js +0 -1015
- package/src/peer-connection-manager/util.ts +0 -117
- package/src/roap/request.js +0 -127
- package/src/statsAnalyzer/mqaUtil.js +0 -173
- package/test/unit/spec/peerconnection-manager/utils.test-fixtures.ts +0 -389
|
@@ -1,47 +1,30 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _Reflect$construct = require("@babel/runtime-corejs2/core-js/reflect/construct");
|
|
4
|
-
|
|
5
4
|
var _Object$defineProperty = require("@babel/runtime-corejs2/core-js/object/define-property");
|
|
6
|
-
|
|
7
5
|
var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequireDefault");
|
|
8
|
-
|
|
9
6
|
_Object$defineProperty(exports, "__esModule", {
|
|
10
7
|
value: true
|
|
11
8
|
});
|
|
12
|
-
|
|
13
9
|
exports.RemoteMediaEvents = exports.RemoteMedia = void 0;
|
|
14
10
|
exports.getMaxFs = getMaxFs;
|
|
15
|
-
|
|
16
11
|
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/classCallCheck"));
|
|
17
|
-
|
|
18
12
|
var _createClass2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/createClass"));
|
|
19
|
-
|
|
20
13
|
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/assertThisInitialized"));
|
|
21
|
-
|
|
22
14
|
var _inherits2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/inherits"));
|
|
23
|
-
|
|
24
15
|
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/possibleConstructorReturn"));
|
|
25
|
-
|
|
26
16
|
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/getPrototypeOf"));
|
|
27
|
-
|
|
28
17
|
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/defineProperty"));
|
|
29
|
-
|
|
30
18
|
var _loggerProxy = _interopRequireDefault(require("../common/logs/logger-proxy"));
|
|
31
|
-
|
|
32
19
|
var _eventsScope = _interopRequireDefault(require("../common/events/events-scope"));
|
|
33
|
-
|
|
34
20
|
var _receiveSlot = require("./receiveSlot");
|
|
35
|
-
|
|
36
21
|
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2.default)(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2.default)(this).constructor; result = _Reflect$construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2.default)(this, result); }; }
|
|
37
|
-
|
|
38
22
|
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !_Reflect$construct) return false; if (_Reflect$construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(_Reflect$construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
|
|
39
|
-
|
|
40
23
|
var RemoteMediaEvents = {
|
|
41
|
-
SourceUpdate: _receiveSlot.ReceiveSlotEvents.SourceUpdate
|
|
24
|
+
SourceUpdate: _receiveSlot.ReceiveSlotEvents.SourceUpdate,
|
|
25
|
+
Stopped: 'stopped'
|
|
42
26
|
};
|
|
43
27
|
exports.RemoteMediaEvents = RemoteMediaEvents;
|
|
44
|
-
|
|
45
28
|
// highest possible resolution
|
|
46
29
|
|
|
47
30
|
/**
|
|
@@ -51,55 +34,42 @@ exports.RemoteMediaEvents = RemoteMediaEvents;
|
|
|
51
34
|
*/
|
|
52
35
|
function getMaxFs(paneSize) {
|
|
53
36
|
var maxFs;
|
|
54
|
-
|
|
55
37
|
switch (paneSize) {
|
|
56
38
|
case 'thumbnail':
|
|
57
39
|
maxFs = 60;
|
|
58
40
|
break;
|
|
59
|
-
|
|
60
41
|
case 'very small':
|
|
61
42
|
maxFs = 240;
|
|
62
43
|
break;
|
|
63
|
-
|
|
64
44
|
case 'small':
|
|
65
45
|
maxFs = 920;
|
|
66
46
|
break;
|
|
67
|
-
|
|
68
47
|
case 'medium':
|
|
69
48
|
maxFs = 3600;
|
|
70
49
|
break;
|
|
71
|
-
|
|
72
50
|
case 'large':
|
|
73
51
|
maxFs = 8192;
|
|
74
52
|
break;
|
|
75
|
-
|
|
76
53
|
case 'best':
|
|
77
54
|
maxFs = 8192; // for now 'best' is 1080p, so same as 'large'
|
|
78
|
-
|
|
79
55
|
break;
|
|
80
|
-
|
|
81
56
|
default:
|
|
82
57
|
_loggerProxy.default.logger.warn("RemoteMedia#getMaxFs --> unsupported paneSize: ".concat(paneSize, ", using \"medium\" instead"));
|
|
83
|
-
|
|
84
58
|
maxFs = 3600;
|
|
85
59
|
}
|
|
86
|
-
|
|
87
60
|
return maxFs;
|
|
88
61
|
}
|
|
89
|
-
|
|
90
62
|
var remoteMediaCounter = 0;
|
|
63
|
+
|
|
91
64
|
/**
|
|
92
65
|
* Class representing a remote audio/video stream.
|
|
93
66
|
*
|
|
94
67
|
* Internally it is associated with a specific receive slot
|
|
95
68
|
* and a media request for it.
|
|
96
69
|
*/
|
|
97
|
-
|
|
98
70
|
var RemoteMedia = /*#__PURE__*/function (_EventsScope) {
|
|
99
71
|
(0, _inherits2.default)(RemoteMedia, _EventsScope);
|
|
100
|
-
|
|
101
72
|
var _super = _createSuper(RemoteMedia);
|
|
102
|
-
|
|
103
73
|
/**
|
|
104
74
|
* Constructs RemoteMedia instance
|
|
105
75
|
*
|
|
@@ -109,7 +79,6 @@ var RemoteMedia = /*#__PURE__*/function (_EventsScope) {
|
|
|
109
79
|
*/
|
|
110
80
|
function RemoteMedia(receiveSlot, mediaRequestManager, options) {
|
|
111
81
|
var _this;
|
|
112
|
-
|
|
113
82
|
(0, _classCallCheck2.default)(this, RemoteMedia);
|
|
114
83
|
_this = _super.call(this);
|
|
115
84
|
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "receiveSlot", void 0);
|
|
@@ -121,12 +90,11 @@ var RemoteMedia = /*#__PURE__*/function (_EventsScope) {
|
|
|
121
90
|
_this.receiveSlot = receiveSlot;
|
|
122
91
|
_this.mediaRequestManager = mediaRequestManager;
|
|
123
92
|
_this.options = options || {};
|
|
124
|
-
|
|
125
93
|
_this.setupEventListeners();
|
|
126
|
-
|
|
127
94
|
_this.id = "RM".concat(remoteMediaCounter, "-").concat(_this.receiveSlot.id);
|
|
128
95
|
return _this;
|
|
129
96
|
}
|
|
97
|
+
|
|
130
98
|
/**
|
|
131
99
|
* Invalidates the remote media by clearing the reference to a receive slot and
|
|
132
100
|
* cancelling the media request.
|
|
@@ -135,18 +103,20 @@ var RemoteMedia = /*#__PURE__*/function (_EventsScope) {
|
|
|
135
103
|
* @param {boolean} commit - whether to commit the cancellation of the media request
|
|
136
104
|
* @internal
|
|
137
105
|
*/
|
|
138
|
-
|
|
139
|
-
|
|
140
106
|
(0, _createClass2.default)(RemoteMedia, [{
|
|
141
107
|
key: "stop",
|
|
142
108
|
value: function stop() {
|
|
143
109
|
var _this$receiveSlot;
|
|
144
|
-
|
|
145
110
|
var commit = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true;
|
|
146
111
|
this.cancelMediaRequest(commit);
|
|
147
112
|
(_this$receiveSlot = this.receiveSlot) === null || _this$receiveSlot === void 0 ? void 0 : _this$receiveSlot.removeAllListeners();
|
|
148
113
|
this.receiveSlot = undefined;
|
|
114
|
+
this.emit({
|
|
115
|
+
file: 'multistream/remoteMedia',
|
|
116
|
+
function: 'stop'
|
|
117
|
+
}, RemoteMediaEvents.Stopped, {});
|
|
149
118
|
}
|
|
119
|
+
|
|
150
120
|
/**
|
|
151
121
|
* Sends a new media request. This method can only be used for receiver-selected policy,
|
|
152
122
|
* because only in that policy we have a 1-1 relationship between RemoteMedia and MediaRequest
|
|
@@ -156,18 +126,15 @@ var RemoteMedia = /*#__PURE__*/function (_EventsScope) {
|
|
|
156
126
|
*
|
|
157
127
|
* @internal
|
|
158
128
|
*/
|
|
159
|
-
|
|
160
129
|
}, {
|
|
161
130
|
key: "sendMediaRequest",
|
|
162
131
|
value: function sendMediaRequest(csi, commit) {
|
|
163
132
|
if (this.mediaRequestId) {
|
|
164
133
|
this.cancelMediaRequest(false);
|
|
165
134
|
}
|
|
166
|
-
|
|
167
135
|
if (!this.receiveSlot) {
|
|
168
136
|
throw new Error('sendMediaRequest() called on an invalidated RemoteMedia instance');
|
|
169
137
|
}
|
|
170
|
-
|
|
171
138
|
this.mediaRequestId = this.mediaRequestManager.addRequest({
|
|
172
139
|
policyInfo: {
|
|
173
140
|
policy: 'receiver-selected',
|
|
@@ -180,10 +147,10 @@ var RemoteMedia = /*#__PURE__*/function (_EventsScope) {
|
|
|
180
147
|
}
|
|
181
148
|
}, commit);
|
|
182
149
|
}
|
|
150
|
+
|
|
183
151
|
/**
|
|
184
152
|
* @internal
|
|
185
153
|
*/
|
|
186
|
-
|
|
187
154
|
}, {
|
|
188
155
|
key: "cancelMediaRequest",
|
|
189
156
|
value: function cancelMediaRequest(commit) {
|
|
@@ -192,18 +159,17 @@ var RemoteMedia = /*#__PURE__*/function (_EventsScope) {
|
|
|
192
159
|
this.mediaRequestId = undefined;
|
|
193
160
|
}
|
|
194
161
|
}
|
|
162
|
+
|
|
195
163
|
/**
|
|
196
164
|
* registers event listeners on the receive slot and forwards all the events
|
|
197
165
|
*/
|
|
198
|
-
|
|
199
166
|
}, {
|
|
200
167
|
key: "setupEventListeners",
|
|
201
168
|
value: function setupEventListeners() {
|
|
202
169
|
var _this2 = this;
|
|
203
|
-
|
|
204
170
|
if (this.receiveSlot) {
|
|
205
171
|
var scope = {
|
|
206
|
-
file: '
|
|
172
|
+
file: 'multistream/remoteMedia',
|
|
207
173
|
function: 'setupEventListeners'
|
|
208
174
|
};
|
|
209
175
|
this.receiveSlot.on(_receiveSlot.ReceiveSlotEvents.SourceUpdate, function (data) {
|
|
@@ -211,66 +177,61 @@ var RemoteMedia = /*#__PURE__*/function (_EventsScope) {
|
|
|
211
177
|
});
|
|
212
178
|
}
|
|
213
179
|
}
|
|
180
|
+
|
|
214
181
|
/**
|
|
215
182
|
* Getter for mediaType
|
|
216
183
|
*/
|
|
217
|
-
|
|
218
184
|
}, {
|
|
219
185
|
key: "mediaType",
|
|
220
186
|
get: function get() {
|
|
221
187
|
var _this$receiveSlot2;
|
|
222
|
-
|
|
223
188
|
return (_this$receiveSlot2 = this.receiveSlot) === null || _this$receiveSlot2 === void 0 ? void 0 : _this$receiveSlot2.mediaType;
|
|
224
189
|
}
|
|
190
|
+
|
|
225
191
|
/**
|
|
226
192
|
* Getter for memberId
|
|
227
193
|
*/
|
|
228
|
-
|
|
229
194
|
}, {
|
|
230
195
|
key: "memberId",
|
|
231
196
|
get: function get() {
|
|
232
197
|
var _this$receiveSlot3;
|
|
233
|
-
|
|
234
198
|
return (_this$receiveSlot3 = this.receiveSlot) === null || _this$receiveSlot3 === void 0 ? void 0 : _this$receiveSlot3.memberId;
|
|
235
199
|
}
|
|
200
|
+
|
|
236
201
|
/**
|
|
237
202
|
* Getter for csi
|
|
238
203
|
*/
|
|
239
|
-
|
|
240
204
|
}, {
|
|
241
205
|
key: "csi",
|
|
242
206
|
get: function get() {
|
|
243
207
|
var _this$receiveSlot4;
|
|
244
|
-
|
|
245
208
|
return (_this$receiveSlot4 = this.receiveSlot) === null || _this$receiveSlot4 === void 0 ? void 0 : _this$receiveSlot4.csi;
|
|
246
209
|
}
|
|
210
|
+
|
|
247
211
|
/**
|
|
248
212
|
* Getter for source state
|
|
249
213
|
*/
|
|
250
|
-
|
|
251
214
|
}, {
|
|
252
215
|
key: "sourceState",
|
|
253
216
|
get: function get() {
|
|
254
217
|
var _this$receiveSlot5;
|
|
255
|
-
|
|
256
218
|
return (_this$receiveSlot5 = this.receiveSlot) === null || _this$receiveSlot5 === void 0 ? void 0 : _this$receiveSlot5.sourceState;
|
|
257
219
|
}
|
|
220
|
+
|
|
258
221
|
/**
|
|
259
222
|
* Getter for remote media stream
|
|
260
223
|
*/
|
|
261
|
-
|
|
262
224
|
}, {
|
|
263
225
|
key: "stream",
|
|
264
226
|
get: function get() {
|
|
265
227
|
var _this$receiveSlot6;
|
|
266
|
-
|
|
267
228
|
return (_this$receiveSlot6 = this.receiveSlot) === null || _this$receiveSlot6 === void 0 ? void 0 : _this$receiveSlot6.stream;
|
|
268
229
|
}
|
|
230
|
+
|
|
269
231
|
/**
|
|
270
232
|
* @internal
|
|
271
233
|
* @returns {ReceiveSlot}
|
|
272
234
|
*/
|
|
273
|
-
|
|
274
235
|
}, {
|
|
275
236
|
key: "getUnderlyingReceiveSlot",
|
|
276
237
|
value: function getUnderlyingReceiveSlot() {
|
|
@@ -279,6 +240,5 @@ var RemoteMedia = /*#__PURE__*/function (_EventsScope) {
|
|
|
279
240
|
}]);
|
|
280
241
|
return RemoteMedia;
|
|
281
242
|
}(_eventsScope.default);
|
|
282
|
-
|
|
283
243
|
exports.RemoteMedia = RemoteMedia;
|
|
284
244
|
//# sourceMappingURL=remoteMedia.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["RemoteMediaEvents","SourceUpdate","ReceiveSlotEvents","getMaxFs","paneSize","maxFs","LoggerProxy","logger","warn","remoteMediaCounter","RemoteMedia","receiveSlot","mediaRequestManager","options","setupEventListeners","id","commit","cancelMediaRequest","removeAllListeners","undefined","csi","mediaRequestId","Error","addRequest","policyInfo","policy","receiveSlots","codecInfo","resolution","codec","cancelRequest","scope","
|
|
1
|
+
{"version":3,"names":["RemoteMediaEvents","SourceUpdate","ReceiveSlotEvents","Stopped","getMaxFs","paneSize","maxFs","LoggerProxy","logger","warn","remoteMediaCounter","RemoteMedia","receiveSlot","mediaRequestManager","options","setupEventListeners","id","commit","cancelMediaRequest","removeAllListeners","undefined","emit","file","function","csi","mediaRequestId","Error","addRequest","policyInfo","policy","receiveSlots","codecInfo","resolution","codec","cancelRequest","scope","on","data","mediaType","memberId","sourceState","stream","EventsScope"],"sources":["remoteMedia.ts"],"sourcesContent":["/* eslint-disable valid-jsdoc */\nimport {MediaType, SourceState} from '@webex/internal-media-core';\nimport LoggerProxy from '../common/logs/logger-proxy';\nimport EventsScope from '../common/events/events-scope';\n\nimport {MediaRequestId, MediaRequestManager} from './mediaRequestManager';\nimport {CSI, ReceiveSlot, ReceiveSlotEvents} from './receiveSlot';\n\nexport const RemoteMediaEvents = {\n SourceUpdate: ReceiveSlotEvents.SourceUpdate,\n Stopped: 'stopped',\n};\n\nexport type RemoteVideoResolution =\n | 'thumbnail' // the smallest possible resolution, 90p or less\n | 'very small' // 180p or less\n | 'small' // 360p or less\n | 'medium' // 720p or less\n | 'large' // 1080p or less\n | 'best'; // highest possible resolution\n\n/**\n * Converts pane size into h264 maxFs\n * @param {PaneSize} paneSize\n * @returns {number}\n */\nexport function getMaxFs(paneSize: RemoteVideoResolution): number {\n let maxFs;\n\n switch (paneSize) {\n case 'thumbnail':\n maxFs = 60;\n break;\n case 'very small':\n maxFs = 240;\n break;\n case 'small':\n maxFs = 920;\n break;\n case 'medium':\n maxFs = 3600;\n break;\n case 'large':\n maxFs = 8192;\n break;\n case 'best':\n maxFs = 8192; // for now 'best' is 1080p, so same as 'large'\n break;\n default:\n LoggerProxy.logger.warn(\n `RemoteMedia#getMaxFs --> unsupported paneSize: ${paneSize}, using \"medium\" instead`\n );\n maxFs = 3600;\n }\n\n return maxFs;\n}\n\ntype Options = {\n resolution?: RemoteVideoResolution; // applies only to groups of type MediaType.VideoMain and MediaType.VideoSlides\n};\n\nexport type RemoteMediaId = string;\n\nlet remoteMediaCounter = 0;\n\n/**\n * Class representing a remote audio/video stream.\n *\n * Internally it is associated with a specific receive slot\n * and a media request for it.\n */\nexport class RemoteMedia extends EventsScope {\n private receiveSlot?: ReceiveSlot;\n\n private readonly mediaRequestManager: MediaRequestManager;\n\n private readonly options: Options;\n\n private mediaRequestId?: MediaRequestId;\n\n public readonly id: RemoteMediaId;\n\n /**\n * Constructs RemoteMedia instance\n *\n * @param receiveSlot\n * @param mediaRequestManager\n * @param options\n */\n constructor(\n receiveSlot: ReceiveSlot,\n mediaRequestManager: MediaRequestManager,\n options?: Options\n ) {\n super();\n remoteMediaCounter += 1;\n this.receiveSlot = receiveSlot;\n this.mediaRequestManager = mediaRequestManager;\n this.options = options || {};\n this.setupEventListeners();\n this.id = `RM${remoteMediaCounter}-${this.receiveSlot.id}`;\n }\n\n /**\n * Invalidates the remote media by clearing the reference to a receive slot and\n * cancelling the media request.\n * After this call the remote media is unusable.\n *\n * @param {boolean} commit - whether to commit the cancellation of the media request\n * @internal\n */\n public stop(commit = true) {\n this.cancelMediaRequest(commit);\n this.receiveSlot?.removeAllListeners();\n this.receiveSlot = undefined;\n this.emit(\n {\n file: 'multistream/remoteMedia',\n function: 'stop',\n },\n RemoteMediaEvents.Stopped,\n {}\n );\n }\n\n /**\n * Sends a new media request. This method can only be used for receiver-selected policy,\n * because only in that policy we have a 1-1 relationship between RemoteMedia and MediaRequest\n * and the request id is then stored in this RemoteMedia instance.\n * For active-speaker policy, the same request is shared among many RemoteMedia instances,\n * so it's managed through RemoteMediaGroup\n *\n * @internal\n */\n public sendMediaRequest(csi: CSI, commit: boolean) {\n if (this.mediaRequestId) {\n this.cancelMediaRequest(false);\n }\n\n if (!this.receiveSlot) {\n throw new Error('sendMediaRequest() called on an invalidated RemoteMedia instance');\n }\n\n this.mediaRequestId = this.mediaRequestManager.addRequest(\n {\n policyInfo: {\n policy: 'receiver-selected',\n csi,\n },\n receiveSlots: [this.receiveSlot],\n codecInfo: this.options.resolution && {\n codec: 'h264',\n maxFs: getMaxFs(this.options.resolution),\n },\n },\n commit\n );\n }\n\n /**\n * @internal\n */\n public cancelMediaRequest(commit: boolean) {\n if (this.mediaRequestId) {\n this.mediaRequestManager.cancelRequest(this.mediaRequestId, commit);\n this.mediaRequestId = undefined;\n }\n }\n\n /**\n * registers event listeners on the receive slot and forwards all the events\n */\n private setupEventListeners() {\n if (this.receiveSlot) {\n const scope = {\n file: 'multistream/remoteMedia',\n function: 'setupEventListeners',\n };\n\n this.receiveSlot.on(ReceiveSlotEvents.SourceUpdate, (data) => {\n this.emit(scope, RemoteMediaEvents.SourceUpdate, data);\n });\n }\n }\n\n /**\n * Getter for mediaType\n */\n public get mediaType(): MediaType {\n return this.receiveSlot?.mediaType;\n }\n\n /**\n * Getter for memberId\n */\n public get memberId() {\n return this.receiveSlot?.memberId;\n }\n\n /**\n * Getter for csi\n */\n public get csi() {\n return this.receiveSlot?.csi;\n }\n\n /**\n * Getter for source state\n */\n public get sourceState(): SourceState {\n return this.receiveSlot?.sourceState;\n }\n\n /**\n * Getter for remote media stream\n */\n public get stream() {\n return this.receiveSlot?.stream;\n }\n\n /**\n * @internal\n * @returns {ReceiveSlot}\n */\n public getUnderlyingReceiveSlot() {\n return this.receiveSlot;\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;AAEA;AACA;AAGA;AAAkE;AAAA;AAE3D,IAAMA,iBAAiB,GAAG;EAC/BC,YAAY,EAAEC,8BAAiB,CAACD,YAAY;EAC5CE,OAAO,EAAE;AACX,CAAC;AAAC;AAQU;;AAEZ;AACA;AACA;AACA;AACA;AACO,SAASC,QAAQ,CAACC,QAA+B,EAAU;EAChE,IAAIC,KAAK;EAET,QAAQD,QAAQ;IACd,KAAK,WAAW;MACdC,KAAK,GAAG,EAAE;MACV;IACF,KAAK,YAAY;MACfA,KAAK,GAAG,GAAG;MACX;IACF,KAAK,OAAO;MACVA,KAAK,GAAG,GAAG;MACX;IACF,KAAK,QAAQ;MACXA,KAAK,GAAG,IAAI;MACZ;IACF,KAAK,OAAO;MACVA,KAAK,GAAG,IAAI;MACZ;IACF,KAAK,MAAM;MACTA,KAAK,GAAG,IAAI,CAAC,CAAC;MACd;IACF;MACEC,oBAAW,CAACC,MAAM,CAACC,IAAI,0DAC6BJ,QAAQ,gCAC3D;MACDC,KAAK,GAAG,IAAI;EAAC;EAGjB,OAAOA,KAAK;AACd;AAQA,IAAII,kBAAkB,GAAG,CAAC;;AAE1B;AACA;AACA;AACA;AACA;AACA;AALA,IAMaC,WAAW;EAAA;EAAA;EAWtB;AACF;AACA;AACA;AACA;AACA;AACA;EACE,qBACEC,WAAwB,EACxBC,mBAAwC,EACxCC,OAAiB,EACjB;IAAA;IAAA;IACA;IAAQ;IAAA;IAAA;IAAA;IAAA;IACRJ,kBAAkB,IAAI,CAAC;IACvB,MAAKE,WAAW,GAAGA,WAAW;IAC9B,MAAKC,mBAAmB,GAAGA,mBAAmB;IAC9C,MAAKC,OAAO,GAAGA,OAAO,IAAI,CAAC,CAAC;IAC5B,MAAKC,mBAAmB,EAAE;IAC1B,MAAKC,EAAE,eAAQN,kBAAkB,cAAI,MAAKE,WAAW,CAACI,EAAE,CAAE;IAAC;EAC7D;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EAPE;IAAA;IAAA,OAQA,gBAA2B;MAAA;MAAA,IAAfC,MAAM,uEAAG,IAAI;MACvB,IAAI,CAACC,kBAAkB,CAACD,MAAM,CAAC;MAC/B,yBAAI,CAACL,WAAW,sDAAhB,kBAAkBO,kBAAkB,EAAE;MACtC,IAAI,CAACP,WAAW,GAAGQ,SAAS;MAC5B,IAAI,CAACC,IAAI,CACP;QACEC,IAAI,EAAE,yBAAyB;QAC/BC,QAAQ,EAAE;MACZ,CAAC,EACDvB,iBAAiB,CAACG,OAAO,EACzB,CAAC,CAAC,CACH;IACH;;IAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EARE;IAAA;IAAA,OASA,0BAAwBqB,GAAQ,EAAEP,MAAe,EAAE;MACjD,IAAI,IAAI,CAACQ,cAAc,EAAE;QACvB,IAAI,CAACP,kBAAkB,CAAC,KAAK,CAAC;MAChC;MAEA,IAAI,CAAC,IAAI,CAACN,WAAW,EAAE;QACrB,MAAM,IAAIc,KAAK,CAAC,kEAAkE,CAAC;MACrF;MAEA,IAAI,CAACD,cAAc,GAAG,IAAI,CAACZ,mBAAmB,CAACc,UAAU,CACvD;QACEC,UAAU,EAAE;UACVC,MAAM,EAAE,mBAAmB;UAC3BL,GAAG,EAAHA;QACF,CAAC;QACDM,YAAY,EAAE,CAAC,IAAI,CAAClB,WAAW,CAAC;QAChCmB,SAAS,EAAE,IAAI,CAACjB,OAAO,CAACkB,UAAU,IAAI;UACpCC,KAAK,EAAE,MAAM;UACb3B,KAAK,EAAEF,QAAQ,CAAC,IAAI,CAACU,OAAO,CAACkB,UAAU;QACzC;MACF,CAAC,EACDf,MAAM,CACP;IACH;;IAEA;AACF;AACA;EAFE;IAAA;IAAA,OAGA,4BAA0BA,MAAe,EAAE;MACzC,IAAI,IAAI,CAACQ,cAAc,EAAE;QACvB,IAAI,CAACZ,mBAAmB,CAACqB,aAAa,CAAC,IAAI,CAACT,cAAc,EAAER,MAAM,CAAC;QACnE,IAAI,CAACQ,cAAc,GAAGL,SAAS;MACjC;IACF;;IAEA;AACF;AACA;EAFE;IAAA;IAAA,OAGA,+BAA8B;MAAA;MAC5B,IAAI,IAAI,CAACR,WAAW,EAAE;QACpB,IAAMuB,KAAK,GAAG;UACZb,IAAI,EAAE,yBAAyB;UAC/BC,QAAQ,EAAE;QACZ,CAAC;QAED,IAAI,CAACX,WAAW,CAACwB,EAAE,CAAClC,8BAAiB,CAACD,YAAY,EAAE,UAACoC,IAAI,EAAK;UAC5D,MAAI,CAAChB,IAAI,CAACc,KAAK,EAAEnC,iBAAiB,CAACC,YAAY,EAAEoC,IAAI,CAAC;QACxD,CAAC,CAAC;MACJ;IACF;;IAEA;AACF;AACA;EAFE;IAAA;IAAA,KAGA,eAAkC;MAAA;MAChC,6BAAO,IAAI,CAACzB,WAAW,uDAAhB,mBAAkB0B,SAAS;IACpC;;IAEA;AACF;AACA;EAFE;IAAA;IAAA,KAGA,eAAsB;MAAA;MACpB,6BAAO,IAAI,CAAC1B,WAAW,uDAAhB,mBAAkB2B,QAAQ;IACnC;;IAEA;AACF;AACA;EAFE;IAAA;IAAA,KAGA,eAAiB;MAAA;MACf,6BAAO,IAAI,CAAC3B,WAAW,uDAAhB,mBAAkBY,GAAG;IAC9B;;IAEA;AACF;AACA;EAFE;IAAA;IAAA,KAGA,eAAsC;MAAA;MACpC,6BAAO,IAAI,CAACZ,WAAW,uDAAhB,mBAAkB4B,WAAW;IACtC;;IAEA;AACF;AACA;EAFE;IAAA;IAAA,KAGA,eAAoB;MAAA;MAClB,6BAAO,IAAI,CAAC5B,WAAW,uDAAhB,mBAAkB6B,MAAM;IACjC;;IAEA;AACF;AACA;AACA;EAHE;IAAA;IAAA,OAIA,oCAAkC;MAChC,OAAO,IAAI,CAAC7B,WAAW;IACzB;EAAC;EAAA;AAAA,EA3J8B8B,oBAAW;AAAA"}
|
|
@@ -1,37 +1,25 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _Object$defineProperty = require("@babel/runtime-corejs2/core-js/object/define-property");
|
|
4
|
-
|
|
5
4
|
var _interopRequireDefault = require("@babel/runtime-corejs2/helpers/interopRequireDefault");
|
|
6
|
-
|
|
7
5
|
_Object$defineProperty(exports, "__esModule", {
|
|
8
6
|
value: true
|
|
9
7
|
});
|
|
10
|
-
|
|
11
8
|
exports.RemoteMediaGroup = void 0;
|
|
12
|
-
|
|
13
9
|
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/toConsumableArray"));
|
|
14
|
-
|
|
15
10
|
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/classCallCheck"));
|
|
16
|
-
|
|
17
11
|
var _createClass2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/createClass"));
|
|
18
|
-
|
|
19
12
|
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/defineProperty"));
|
|
20
|
-
|
|
21
13
|
var _loggerProxy = _interopRequireDefault(require("../common/logs/logger-proxy"));
|
|
22
|
-
|
|
23
14
|
var _remoteMedia = require("./remoteMedia");
|
|
24
|
-
|
|
25
15
|
/* eslint-disable valid-jsdoc */
|
|
26
|
-
|
|
27
16
|
/* eslint-disable require-jsdoc */
|
|
28
|
-
|
|
29
17
|
/* eslint-disable import/prefer-default-export */
|
|
30
18
|
var RemoteMediaGroup = /*#__PURE__*/function () {
|
|
31
19
|
// id of the "active-speaker" media request id
|
|
20
|
+
|
|
32
21
|
function RemoteMediaGroup(mediaRequestManager, receiveSlots, priority, commitMediaRequest) {
|
|
33
22
|
var _this = this;
|
|
34
|
-
|
|
35
23
|
var options = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : {};
|
|
36
24
|
(0, _classCallCheck2.default)(this, RemoteMediaGroup);
|
|
37
25
|
(0, _defineProperty2.default)(this, "mediaRequestManager", void 0);
|
|
@@ -51,91 +39,77 @@ var RemoteMediaGroup = /*#__PURE__*/function () {
|
|
|
51
39
|
this.pinnedRemoteMedia = [];
|
|
52
40
|
this.sendActiveSpeakerMediaRequest(commitMediaRequest);
|
|
53
41
|
}
|
|
42
|
+
|
|
54
43
|
/**
|
|
55
44
|
* Gets the array of remote media elements from the group
|
|
56
45
|
*
|
|
57
46
|
* @param {string} filter - 'all' (default) returns both pinned and unpinned
|
|
58
47
|
* @returns {Array<RemoteMedia>}
|
|
59
48
|
*/
|
|
60
|
-
|
|
61
|
-
|
|
62
49
|
(0, _createClass2.default)(RemoteMediaGroup, [{
|
|
63
50
|
key: "getRemoteMedia",
|
|
64
51
|
value: function getRemoteMedia() {
|
|
65
52
|
var filter = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'all';
|
|
66
|
-
|
|
67
53
|
if (filter === 'unpinned') {
|
|
68
54
|
// return a shallow copy so that the client cannot modify this.unpinnedRemoteMedia array
|
|
69
55
|
return (0, _toConsumableArray2.default)(this.unpinnedRemoteMedia);
|
|
70
56
|
}
|
|
71
|
-
|
|
72
57
|
if (filter === 'pinned') {
|
|
73
58
|
// return a shallow copy so that the client cannot modify this.pinnedRemoteMedia array
|
|
74
59
|
return (0, _toConsumableArray2.default)(this.pinnedRemoteMedia);
|
|
75
60
|
}
|
|
76
|
-
|
|
77
61
|
return [].concat((0, _toConsumableArray2.default)(this.unpinnedRemoteMedia), (0, _toConsumableArray2.default)(this.pinnedRemoteMedia));
|
|
78
62
|
}
|
|
63
|
+
|
|
79
64
|
/**
|
|
80
65
|
* Pins a specific remote media instance to a specfic CSI, so the media will
|
|
81
66
|
* no longer come from active speaker, but from that CSI.
|
|
82
67
|
* If no CSI is given, the current CSI value is used.
|
|
83
68
|
*
|
|
84
69
|
*/
|
|
85
|
-
|
|
86
70
|
}, {
|
|
87
71
|
key: "pin",
|
|
88
72
|
value: function pin(remoteMedia, csi) {
|
|
89
73
|
// if csi is not specified, use the current one
|
|
90
74
|
var targetCsi = csi || remoteMedia.csi;
|
|
91
|
-
|
|
92
75
|
if (!targetCsi) {
|
|
93
76
|
throw new Error("failed to pin a remote media object ".concat(remoteMedia.id, ", because it has no CSI set and no CSI value was given"));
|
|
94
77
|
}
|
|
95
|
-
|
|
96
78
|
if (this.pinnedRemoteMedia.indexOf(remoteMedia) >= 0) {
|
|
97
79
|
if (targetCsi === remoteMedia.csi) {
|
|
98
80
|
// remote media already pinned to target CSI, nothing to do
|
|
99
81
|
_loggerProxy.default.logger.log("RemoteMediaGroup#pin --> remote media ".concat(remoteMedia.id, " already pinned"));
|
|
100
|
-
|
|
101
82
|
return;
|
|
102
83
|
}
|
|
103
84
|
} else {
|
|
104
85
|
var idx = this.unpinnedRemoteMedia.indexOf(remoteMedia);
|
|
105
|
-
|
|
106
86
|
if (idx < 0) {
|
|
107
87
|
throw new Error("failed to pin a remote media object ".concat(remoteMedia.id, ", because it is not found in this remote media group"));
|
|
108
88
|
}
|
|
109
|
-
|
|
110
89
|
this.unpinnedRemoteMedia.splice(idx, 1);
|
|
111
90
|
this.pinnedRemoteMedia.push(remoteMedia);
|
|
112
91
|
this.cancelActiveSpeakerMediaRequest(false);
|
|
113
92
|
this.sendActiveSpeakerMediaRequest(false);
|
|
114
93
|
}
|
|
115
|
-
|
|
116
94
|
remoteMedia.sendMediaRequest(targetCsi, false);
|
|
117
95
|
this.mediaRequestManager.commit();
|
|
118
96
|
}
|
|
97
|
+
|
|
119
98
|
/**
|
|
120
99
|
* Unpins a remote media instance, so that it will again provide media from active speakers
|
|
121
100
|
*
|
|
122
101
|
*/
|
|
123
|
-
|
|
124
102
|
}, {
|
|
125
103
|
key: "unpin",
|
|
126
104
|
value: function unpin(remoteMedia) {
|
|
127
105
|
if (this.unpinnedRemoteMedia.indexOf(remoteMedia) >= 0) {
|
|
128
106
|
_loggerProxy.default.logger.log("RemoteMediaGroup#pin --> remote media ".concat(remoteMedia.id, " already unpinned"));
|
|
129
|
-
|
|
130
107
|
return;
|
|
131
108
|
}
|
|
132
|
-
|
|
133
109
|
var idx = this.pinnedRemoteMedia.indexOf(remoteMedia);
|
|
134
|
-
|
|
135
110
|
if (idx < 0) {
|
|
136
111
|
throw new Error("failed to unpin a remote media object ".concat(remoteMedia.id, ", because it is not found in this remote media group"));
|
|
137
112
|
}
|
|
138
|
-
|
|
139
113
|
this.pinnedRemoteMedia.splice(idx, 1);
|
|
140
114
|
this.unpinnedRemoteMedia.push(remoteMedia);
|
|
141
115
|
remoteMedia.cancelMediaRequest(false);
|
|
@@ -149,18 +123,15 @@ var RemoteMediaGroup = /*#__PURE__*/function () {
|
|
|
149
123
|
if (this.unpinnedRemoteMedia.indexOf(remoteMedia) >= 0) {
|
|
150
124
|
return false;
|
|
151
125
|
}
|
|
152
|
-
|
|
153
126
|
if (this.pinnedRemoteMedia.indexOf(remoteMedia) >= 0) {
|
|
154
127
|
return true;
|
|
155
128
|
}
|
|
156
|
-
|
|
157
129
|
throw new Error("remote media object ".concat(remoteMedia.id, " not found in the group"));
|
|
158
130
|
}
|
|
159
131
|
}, {
|
|
160
132
|
key: "sendActiveSpeakerMediaRequest",
|
|
161
133
|
value: function sendActiveSpeakerMediaRequest(commit) {
|
|
162
134
|
var _this$options;
|
|
163
|
-
|
|
164
135
|
this.cancelActiveSpeakerMediaRequest(false);
|
|
165
136
|
this.mediaRequestId = this.mediaRequestManager.addRequest({
|
|
166
137
|
policyInfo: {
|
|
@@ -187,6 +158,7 @@ var RemoteMediaGroup = /*#__PURE__*/function () {
|
|
|
187
158
|
this.mediaRequestId = undefined;
|
|
188
159
|
}
|
|
189
160
|
}
|
|
161
|
+
|
|
190
162
|
/**
|
|
191
163
|
* Invalidates the remote media group by clearing the references to the receive slots
|
|
192
164
|
* used by all remote media from that group and cancelling all media requests.
|
|
@@ -195,7 +167,6 @@ var RemoteMediaGroup = /*#__PURE__*/function () {
|
|
|
195
167
|
* @param{boolean} commit whether to commit the cancellation of media requests
|
|
196
168
|
* @internal
|
|
197
169
|
*/
|
|
198
|
-
|
|
199
170
|
}, {
|
|
200
171
|
key: "stop",
|
|
201
172
|
value: function stop() {
|
|
@@ -207,11 +178,11 @@ var RemoteMediaGroup = /*#__PURE__*/function () {
|
|
|
207
178
|
return remoteMedia.stop(false);
|
|
208
179
|
});
|
|
209
180
|
this.cancelActiveSpeakerMediaRequest(false);
|
|
210
|
-
|
|
211
181
|
if (commit) {
|
|
212
182
|
this.mediaRequestManager.commit();
|
|
213
183
|
}
|
|
214
184
|
}
|
|
185
|
+
|
|
215
186
|
/**
|
|
216
187
|
* Checks if a given RemoteMedia instance belongs to this group.
|
|
217
188
|
*
|
|
@@ -219,25 +190,20 @@ var RemoteMediaGroup = /*#__PURE__*/function () {
|
|
|
219
190
|
* @param filter controls which remote media from the group to check
|
|
220
191
|
* @returns true if remote media is found
|
|
221
192
|
*/
|
|
222
|
-
|
|
223
193
|
}, {
|
|
224
194
|
key: "includes",
|
|
225
195
|
value: function includes(remoteMedia) {
|
|
226
196
|
var filter = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'all';
|
|
227
|
-
|
|
228
197
|
if (filter === 'pinned') {
|
|
229
198
|
return this.pinnedRemoteMedia.includes(remoteMedia);
|
|
230
199
|
}
|
|
231
|
-
|
|
232
200
|
if (filter === 'unpinned') {
|
|
233
201
|
return this.unpinnedRemoteMedia.includes(remoteMedia);
|
|
234
202
|
}
|
|
235
|
-
|
|
236
203
|
return this.unpinnedRemoteMedia.includes(remoteMedia) || this.pinnedRemoteMedia.includes(remoteMedia);
|
|
237
204
|
}
|
|
238
205
|
}]);
|
|
239
206
|
return RemoteMediaGroup;
|
|
240
207
|
}();
|
|
241
|
-
|
|
242
208
|
exports.RemoteMediaGroup = RemoteMediaGroup;
|
|
243
209
|
//# sourceMappingURL=remoteMediaGroup.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["RemoteMediaGroup","mediaRequestManager","receiveSlots","priority","commitMediaRequest","options","unpinnedRemoteMedia","map","slot","RemoteMedia","resolution","pinnedRemoteMedia","sendActiveSpeakerMediaRequest","filter","remoteMedia","csi","targetCsi","Error","id","indexOf","LoggerProxy","logger","log","idx","splice","push","cancelActiveSpeakerMediaRequest","sendMediaRequest","commit","cancelMediaRequest","mediaRequestId","addRequest","policyInfo","policy","crossPriorityDuplication","crossPolicyDuplication","preferLiveVideo","getUnderlyingReceiveSlot","codecInfo","codec","maxFs","getMaxFs","cancelRequest","undefined","forEach","stop","includes"],"sources":["remoteMediaGroup.ts"],"sourcesContent":["/* eslint-disable valid-jsdoc */\n/* eslint-disable require-jsdoc */\n/* eslint-disable import/prefer-default-export */\nimport LoggerProxy from '../common/logs/logger-proxy';\n\nimport {getMaxFs, RemoteMedia, RemoteVideoResolution} from './remoteMedia';\nimport {MediaRequestId, MediaRequestManager} from './mediaRequestManager';\nimport {CSI, ReceiveSlot} from './receiveSlot';\n\ntype Options = {\n resolution?: RemoteVideoResolution; // applies only to groups of type MC.MediaType.VideoMain and MC.MediaType.VideoSlides\n preferLiveVideo?: boolean; // applies only to groups of type MC.MediaType.VideoMain and MC.MediaType.VideoSlides\n};\n\nexport class RemoteMediaGroup {\n private mediaRequestManager: MediaRequestManager;\n\n private priority: number;\n\n private options: Options;\n\n private unpinnedRemoteMedia: RemoteMedia[];\n\n private mediaRequestId?: MediaRequestId; // id of the \"active-speaker\" media request id\n\n private pinnedRemoteMedia: RemoteMedia[];\n\n constructor(\n mediaRequestManager: MediaRequestManager,\n receiveSlots: ReceiveSlot[],\n priority: number,\n commitMediaRequest: boolean,\n options: Options = {}\n ) {\n this.mediaRequestManager = mediaRequestManager;\n this.priority = priority;\n this.options = options;\n\n this.unpinnedRemoteMedia = receiveSlots.map(\n (slot) =>\n new RemoteMedia(slot, this.mediaRequestManager, {\n resolution: this.options.resolution,\n })\n );\n this.pinnedRemoteMedia = [];\n\n this.sendActiveSpeakerMediaRequest(commitMediaRequest);\n }\n\n /**\n * Gets the array of remote media elements from the group\n *\n * @param {string} filter - 'all' (default) returns both pinned and unpinned\n * @returns {Array<RemoteMedia>}\n */\n public getRemoteMedia(filter: 'all' | 'pinned' | 'unpinned' = 'all') {\n if (filter === 'unpinned') {\n // return a shallow copy so that the client cannot modify this.unpinnedRemoteMedia array\n return [...this.unpinnedRemoteMedia];\n }\n if (filter === 'pinned') {\n // return a shallow copy so that the client cannot modify this.pinnedRemoteMedia array\n return [...this.pinnedRemoteMedia];\n }\n return [...this.unpinnedRemoteMedia, ...this.pinnedRemoteMedia];\n }\n\n /**\n * Pins a specific remote media instance to a specfic CSI, so the media will\n * no longer come from active speaker, but from that CSI.\n * If no CSI is given, the current CSI value is used.\n *\n */\n public pin(remoteMedia: RemoteMedia, csi?: CSI): void {\n // if csi is not specified, use the current one\n const targetCsi = csi || remoteMedia.csi;\n\n if (!targetCsi) {\n throw new Error(\n `failed to pin a remote media object ${remoteMedia.id}, because it has no CSI set and no CSI value was given`\n );\n }\n\n if (this.pinnedRemoteMedia.indexOf(remoteMedia) >= 0) {\n if (targetCsi === remoteMedia.csi) {\n // remote media already pinned to target CSI, nothing to do\n LoggerProxy.logger.log(\n `RemoteMediaGroup#pin --> remote media ${remoteMedia.id} already pinned`\n );\n\n return;\n }\n } else {\n const idx = this.unpinnedRemoteMedia.indexOf(remoteMedia);\n\n if (idx < 0) {\n throw new Error(\n `failed to pin a remote media object ${remoteMedia.id}, because it is not found in this remote media group`\n );\n }\n\n this.unpinnedRemoteMedia.splice(idx, 1);\n this.pinnedRemoteMedia.push(remoteMedia);\n\n this.cancelActiveSpeakerMediaRequest(false);\n this.sendActiveSpeakerMediaRequest(false);\n }\n\n remoteMedia.sendMediaRequest(targetCsi, false);\n this.mediaRequestManager.commit();\n }\n\n /**\n * Unpins a remote media instance, so that it will again provide media from active speakers\n *\n */\n public unpin(remoteMedia: RemoteMedia) {\n if (this.unpinnedRemoteMedia.indexOf(remoteMedia) >= 0) {\n LoggerProxy.logger.log(\n `RemoteMediaGroup#pin --> remote media ${remoteMedia.id} already unpinned`\n );\n\n return;\n }\n const idx = this.pinnedRemoteMedia.indexOf(remoteMedia);\n\n if (idx < 0) {\n throw new Error(\n `failed to unpin a remote media object ${remoteMedia.id}, because it is not found in this remote media group`\n );\n }\n\n this.pinnedRemoteMedia.splice(idx, 1);\n this.unpinnedRemoteMedia.push(remoteMedia);\n\n remoteMedia.cancelMediaRequest(false);\n this.cancelActiveSpeakerMediaRequest(false);\n this.sendActiveSpeakerMediaRequest(false);\n this.mediaRequestManager.commit();\n }\n\n public isPinned(remoteMedia: RemoteMedia) {\n if (this.unpinnedRemoteMedia.indexOf(remoteMedia) >= 0) {\n return false;\n }\n if (this.pinnedRemoteMedia.indexOf(remoteMedia) >= 0) {\n return true;\n }\n\n throw new Error(`remote media object ${remoteMedia.id} not found in the group`);\n }\n\n private sendActiveSpeakerMediaRequest(commit: boolean) {\n this.cancelActiveSpeakerMediaRequest(false);\n\n this.mediaRequestId = this.mediaRequestManager.addRequest(\n {\n policyInfo: {\n policy: 'active-speaker',\n priority: this.priority,\n crossPriorityDuplication: false,\n crossPolicyDuplication: false,\n preferLiveVideo: !!this.options?.preferLiveVideo,\n },\n receiveSlots: this.unpinnedRemoteMedia.map((remoteMedia) =>\n remoteMedia.getUnderlyingReceiveSlot()\n ) as ReceiveSlot[],\n codecInfo: this.options.resolution && {\n codec: 'h264',\n maxFs: getMaxFs(this.options.resolution),\n },\n },\n commit\n );\n }\n\n private cancelActiveSpeakerMediaRequest(commit: boolean) {\n if (this.mediaRequestId) {\n this.mediaRequestManager.cancelRequest(this.mediaRequestId, commit);\n this.mediaRequestId = undefined;\n }\n }\n\n /**\n * Invalidates the remote media group by clearing the references to the receive slots\n * used by all remote media from that group and cancelling all media requests.\n * After this call the remote media group is unusable.\n *\n * @param{boolean} commit whether to commit the cancellation of media requests\n * @internal\n */\n public stop(commit: boolean = true) {\n this.unpinnedRemoteMedia.forEach((remoteMedia) => remoteMedia.stop(false));\n this.pinnedRemoteMedia.forEach((remoteMedia) => remoteMedia.stop(false));\n this.cancelActiveSpeakerMediaRequest(false);\n\n if (commit) {\n this.mediaRequestManager.commit();\n }\n }\n\n /**\n * Checks if a given RemoteMedia instance belongs to this group.\n *\n * @param remoteMedia RemoteMedia instance to check\n * @param filter controls which remote media from the group to check\n * @returns true if remote media is found\n */\n public includes(\n remoteMedia: RemoteMedia,\n filter: 'all' | 'pinned' | 'unpinned' = 'all'\n ): boolean {\n if (filter === 'pinned') {\n return this.pinnedRemoteMedia.includes(remoteMedia);\n }\n if (filter === 'unpinned') {\n return this.unpinnedRemoteMedia.includes(remoteMedia);\n }\n\n return (\n this.unpinnedRemoteMedia.includes(remoteMedia) || this.pinnedRemoteMedia.includes(remoteMedia)\n );\n }\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"names":["RemoteMediaGroup","mediaRequestManager","receiveSlots","priority","commitMediaRequest","options","unpinnedRemoteMedia","map","slot","RemoteMedia","resolution","pinnedRemoteMedia","sendActiveSpeakerMediaRequest","filter","remoteMedia","csi","targetCsi","Error","id","indexOf","LoggerProxy","logger","log","idx","splice","push","cancelActiveSpeakerMediaRequest","sendMediaRequest","commit","cancelMediaRequest","mediaRequestId","addRequest","policyInfo","policy","crossPriorityDuplication","crossPolicyDuplication","preferLiveVideo","getUnderlyingReceiveSlot","codecInfo","codec","maxFs","getMaxFs","cancelRequest","undefined","forEach","stop","includes"],"sources":["remoteMediaGroup.ts"],"sourcesContent":["/* eslint-disable valid-jsdoc */\n/* eslint-disable require-jsdoc */\n/* eslint-disable import/prefer-default-export */\nimport LoggerProxy from '../common/logs/logger-proxy';\n\nimport {getMaxFs, RemoteMedia, RemoteVideoResolution} from './remoteMedia';\nimport {MediaRequestId, MediaRequestManager} from './mediaRequestManager';\nimport {CSI, ReceiveSlot} from './receiveSlot';\n\ntype Options = {\n resolution?: RemoteVideoResolution; // applies only to groups of type MediaType.VideoMain and MediaType.VideoSlides\n preferLiveVideo?: boolean; // applies only to groups of type MediaType.VideoMain and MediaType.VideoSlides\n};\n\nexport class RemoteMediaGroup {\n private mediaRequestManager: MediaRequestManager;\n\n private priority: number;\n\n private options: Options;\n\n private unpinnedRemoteMedia: RemoteMedia[];\n\n private mediaRequestId?: MediaRequestId; // id of the \"active-speaker\" media request id\n\n private pinnedRemoteMedia: RemoteMedia[];\n\n constructor(\n mediaRequestManager: MediaRequestManager,\n receiveSlots: ReceiveSlot[],\n priority: number,\n commitMediaRequest: boolean,\n options: Options = {}\n ) {\n this.mediaRequestManager = mediaRequestManager;\n this.priority = priority;\n this.options = options;\n\n this.unpinnedRemoteMedia = receiveSlots.map(\n (slot) =>\n new RemoteMedia(slot, this.mediaRequestManager, {\n resolution: this.options.resolution,\n })\n );\n this.pinnedRemoteMedia = [];\n\n this.sendActiveSpeakerMediaRequest(commitMediaRequest);\n }\n\n /**\n * Gets the array of remote media elements from the group\n *\n * @param {string} filter - 'all' (default) returns both pinned and unpinned\n * @returns {Array<RemoteMedia>}\n */\n public getRemoteMedia(filter: 'all' | 'pinned' | 'unpinned' = 'all') {\n if (filter === 'unpinned') {\n // return a shallow copy so that the client cannot modify this.unpinnedRemoteMedia array\n return [...this.unpinnedRemoteMedia];\n }\n if (filter === 'pinned') {\n // return a shallow copy so that the client cannot modify this.pinnedRemoteMedia array\n return [...this.pinnedRemoteMedia];\n }\n\n return [...this.unpinnedRemoteMedia, ...this.pinnedRemoteMedia];\n }\n\n /**\n * Pins a specific remote media instance to a specfic CSI, so the media will\n * no longer come from active speaker, but from that CSI.\n * If no CSI is given, the current CSI value is used.\n *\n */\n public pin(remoteMedia: RemoteMedia, csi?: CSI): void {\n // if csi is not specified, use the current one\n const targetCsi = csi || remoteMedia.csi;\n\n if (!targetCsi) {\n throw new Error(\n `failed to pin a remote media object ${remoteMedia.id}, because it has no CSI set and no CSI value was given`\n );\n }\n\n if (this.pinnedRemoteMedia.indexOf(remoteMedia) >= 0) {\n if (targetCsi === remoteMedia.csi) {\n // remote media already pinned to target CSI, nothing to do\n LoggerProxy.logger.log(\n `RemoteMediaGroup#pin --> remote media ${remoteMedia.id} already pinned`\n );\n\n return;\n }\n } else {\n const idx = this.unpinnedRemoteMedia.indexOf(remoteMedia);\n\n if (idx < 0) {\n throw new Error(\n `failed to pin a remote media object ${remoteMedia.id}, because it is not found in this remote media group`\n );\n }\n\n this.unpinnedRemoteMedia.splice(idx, 1);\n this.pinnedRemoteMedia.push(remoteMedia);\n\n this.cancelActiveSpeakerMediaRequest(false);\n this.sendActiveSpeakerMediaRequest(false);\n }\n\n remoteMedia.sendMediaRequest(targetCsi, false);\n this.mediaRequestManager.commit();\n }\n\n /**\n * Unpins a remote media instance, so that it will again provide media from active speakers\n *\n */\n public unpin(remoteMedia: RemoteMedia) {\n if (this.unpinnedRemoteMedia.indexOf(remoteMedia) >= 0) {\n LoggerProxy.logger.log(\n `RemoteMediaGroup#pin --> remote media ${remoteMedia.id} already unpinned`\n );\n\n return;\n }\n const idx = this.pinnedRemoteMedia.indexOf(remoteMedia);\n\n if (idx < 0) {\n throw new Error(\n `failed to unpin a remote media object ${remoteMedia.id}, because it is not found in this remote media group`\n );\n }\n\n this.pinnedRemoteMedia.splice(idx, 1);\n this.unpinnedRemoteMedia.push(remoteMedia);\n\n remoteMedia.cancelMediaRequest(false);\n this.cancelActiveSpeakerMediaRequest(false);\n this.sendActiveSpeakerMediaRequest(false);\n this.mediaRequestManager.commit();\n }\n\n public isPinned(remoteMedia: RemoteMedia) {\n if (this.unpinnedRemoteMedia.indexOf(remoteMedia) >= 0) {\n return false;\n }\n if (this.pinnedRemoteMedia.indexOf(remoteMedia) >= 0) {\n return true;\n }\n\n throw new Error(`remote media object ${remoteMedia.id} not found in the group`);\n }\n\n private sendActiveSpeakerMediaRequest(commit: boolean) {\n this.cancelActiveSpeakerMediaRequest(false);\n\n this.mediaRequestId = this.mediaRequestManager.addRequest(\n {\n policyInfo: {\n policy: 'active-speaker',\n priority: this.priority,\n crossPriorityDuplication: false,\n crossPolicyDuplication: false,\n preferLiveVideo: !!this.options?.preferLiveVideo,\n },\n receiveSlots: this.unpinnedRemoteMedia.map((remoteMedia) =>\n remoteMedia.getUnderlyingReceiveSlot()\n ) as ReceiveSlot[],\n codecInfo: this.options.resolution && {\n codec: 'h264',\n maxFs: getMaxFs(this.options.resolution),\n },\n },\n commit\n );\n }\n\n private cancelActiveSpeakerMediaRequest(commit: boolean) {\n if (this.mediaRequestId) {\n this.mediaRequestManager.cancelRequest(this.mediaRequestId, commit);\n this.mediaRequestId = undefined;\n }\n }\n\n /**\n * Invalidates the remote media group by clearing the references to the receive slots\n * used by all remote media from that group and cancelling all media requests.\n * After this call the remote media group is unusable.\n *\n * @param{boolean} commit whether to commit the cancellation of media requests\n * @internal\n */\n public stop(commit = true) {\n this.unpinnedRemoteMedia.forEach((remoteMedia) => remoteMedia.stop(false));\n this.pinnedRemoteMedia.forEach((remoteMedia) => remoteMedia.stop(false));\n this.cancelActiveSpeakerMediaRequest(false);\n\n if (commit) {\n this.mediaRequestManager.commit();\n }\n }\n\n /**\n * Checks if a given RemoteMedia instance belongs to this group.\n *\n * @param remoteMedia RemoteMedia instance to check\n * @param filter controls which remote media from the group to check\n * @returns true if remote media is found\n */\n public includes(\n remoteMedia: RemoteMedia,\n filter: 'all' | 'pinned' | 'unpinned' = 'all'\n ): boolean {\n if (filter === 'pinned') {\n return this.pinnedRemoteMedia.includes(remoteMedia);\n }\n if (filter === 'unpinned') {\n return this.unpinnedRemoteMedia.includes(remoteMedia);\n }\n\n return (\n this.unpinnedRemoteMedia.includes(remoteMedia) || this.pinnedRemoteMedia.includes(remoteMedia)\n );\n }\n}\n"],"mappings":"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"}
|