@azure/communication-react 1.14.0-alpha-202403140012 → 1.14.0-alpha-202403160012

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (153) hide show
  1. package/dist/communication-react.d.ts +39 -1
  2. package/dist/dist-cjs/communication-react/{RichTextSendBoxWrapper-D1KqCTKr.js → RichTextSendBoxWrapper-BCdGFyar.js} +2 -2
  3. package/dist/dist-cjs/communication-react/{RichTextSendBoxWrapper-D1KqCTKr.js.map → RichTextSendBoxWrapper-BCdGFyar.js.map} +1 -1
  4. package/dist/dist-cjs/communication-react/{index-DikMcJD4.js → index-BfFCLrEO.js} +538 -337
  5. package/dist/dist-cjs/communication-react/index-BfFCLrEO.js.map +1 -0
  6. package/dist/dist-cjs/communication-react/index.js +1 -1
  7. package/dist/dist-esm/acs-ui-common/src/telemetryVersion.js +1 -1
  8. package/dist/dist-esm/acs-ui-common/src/telemetryVersion.js.map +1 -1
  9. package/dist/dist-esm/calling-component-bindings/src/baseSelectors.js +0 -3
  10. package/dist/dist-esm/calling-component-bindings/src/baseSelectors.js.map +1 -1
  11. package/dist/dist-esm/calling-component-bindings/src/callControlSelectors.js +0 -3
  12. package/dist/dist-esm/calling-component-bindings/src/callControlSelectors.js.map +1 -1
  13. package/dist/dist-esm/calling-component-bindings/src/handlers/createCommonHandlers.js +0 -7
  14. package/dist/dist-esm/calling-component-bindings/src/handlers/createCommonHandlers.js.map +1 -1
  15. package/dist/dist-esm/calling-component-bindings/src/hooks/usePropsFor.js +3 -11
  16. package/dist/dist-esm/calling-component-bindings/src/hooks/usePropsFor.js.map +1 -1
  17. package/dist/dist-esm/calling-component-bindings/src/participantListSelector.js +3 -9
  18. package/dist/dist-esm/calling-component-bindings/src/participantListSelector.js.map +1 -1
  19. package/dist/dist-esm/calling-component-bindings/src/utils/participantListSelectorUtils.js.map +1 -1
  20. package/dist/dist-esm/calling-component-bindings/src/utils/videoGalleryUtils.js +5 -16
  21. package/dist/dist-esm/calling-component-bindings/src/utils/videoGalleryUtils.js.map +1 -1
  22. package/dist/dist-esm/calling-component-bindings/src/videoGallerySelector.js +4 -17
  23. package/dist/dist-esm/calling-component-bindings/src/videoGallerySelector.js.map +1 -1
  24. package/dist/dist-esm/calling-stateful-client/src/CallClientState.d.ts +35 -0
  25. package/dist/dist-esm/calling-stateful-client/src/CallClientState.js.map +1 -1
  26. package/dist/dist-esm/calling-stateful-client/src/CallContext.d.ts +8 -1
  27. package/dist/dist-esm/calling-stateful-client/src/CallContext.js +42 -9
  28. package/dist/dist-esm/calling-stateful-client/src/CallContext.js.map +1 -1
  29. package/dist/dist-esm/calling-stateful-client/src/CallDeclarativeCommon.js +46 -1
  30. package/dist/dist-esm/calling-stateful-client/src/CallDeclarativeCommon.js.map +1 -1
  31. package/dist/dist-esm/calling-stateful-client/src/CallSubscriber.d.ts +3 -1
  32. package/dist/dist-esm/calling-stateful-client/src/CallSubscriber.js +24 -14
  33. package/dist/dist-esm/calling-stateful-client/src/CallSubscriber.js.map +1 -1
  34. package/dist/dist-esm/calling-stateful-client/src/CaptionsSubscriber.d.ts +16 -1
  35. package/dist/dist-esm/calling-stateful-client/src/CaptionsSubscriber.js +38 -2
  36. package/dist/dist-esm/calling-stateful-client/src/CaptionsSubscriber.js.map +1 -1
  37. package/dist/dist-esm/calling-stateful-client/src/Converter.d.ts +6 -1
  38. package/dist/dist-esm/calling-stateful-client/src/Converter.js +11 -6
  39. package/dist/dist-esm/calling-stateful-client/src/Converter.js.map +1 -1
  40. package/dist/dist-esm/calling-stateful-client/src/LocalRecordingSubscriber.d.ts +17 -0
  41. package/dist/dist-esm/calling-stateful-client/src/LocalRecordingSubscriber.js +36 -0
  42. package/dist/dist-esm/calling-stateful-client/src/LocalRecordingSubscriber.js.map +1 -0
  43. package/dist/dist-esm/calling-stateful-client/src/OptimalVideoCountSubscriber.js +0 -1
  44. package/dist/dist-esm/calling-stateful-client/src/OptimalVideoCountSubscriber.js.map +1 -1
  45. package/dist/dist-esm/calling-stateful-client/src/RaiseHandSubscriber.js +0 -2
  46. package/dist/dist-esm/calling-stateful-client/src/RaiseHandSubscriber.js.map +1 -1
  47. package/dist/dist-esm/calling-stateful-client/src/RecordingSubscriber.d.ts +1 -0
  48. package/dist/dist-esm/calling-stateful-client/src/RecordingSubscriber.js +11 -0
  49. package/dist/dist-esm/calling-stateful-client/src/RecordingSubscriber.js.map +1 -1
  50. package/dist/dist-esm/calling-stateful-client/src/StatefulCallClient.d.ts +1 -0
  51. package/dist/dist-esm/calling-stateful-client/src/StatefulCallClient.js.map +1 -1
  52. package/dist/dist-esm/calling-stateful-client/src/index-public.d.ts +1 -0
  53. package/dist/dist-esm/calling-stateful-client/src/index-public.js.map +1 -1
  54. package/dist/dist-esm/chat-component-bindings/src/messageThreadSelector.js +1 -1
  55. package/dist/dist-esm/chat-component-bindings/src/messageThreadSelector.js.map +1 -1
  56. package/dist/dist-esm/chat-stateful-client/src/ChatContext.js +6 -2
  57. package/dist/dist-esm/chat-stateful-client/src/ChatContext.js.map +1 -1
  58. package/dist/dist-esm/chat-stateful-client/src/types/ChatMessageWithStatus.d.ts +1 -1
  59. package/dist/dist-esm/chat-stateful-client/src/types/ChatMessageWithStatus.js.map +1 -1
  60. package/dist/dist-esm/communication-react/src/index.js +0 -1
  61. package/dist/dist-esm/communication-react/src/index.js.map +1 -1
  62. package/dist/dist-esm/react-components/src/components/CaptionsSettingsModal.js +5 -2
  63. package/dist/dist-esm/react-components/src/components/CaptionsSettingsModal.js.map +1 -1
  64. package/dist/dist-esm/react-components/src/components/Drawer/DrawerMenu.js +19 -8
  65. package/dist/dist-esm/react-components/src/components/Drawer/DrawerMenu.js.map +1 -1
  66. package/dist/dist-esm/react-components/src/components/Drawer/DrawerMenuItem.d.ts +4 -0
  67. package/dist/dist-esm/react-components/src/components/Drawer/DrawerMenuItem.js.map +1 -1
  68. package/dist/dist-esm/react-components/src/components/Drawer/ReactionDrawerMenuItem.d.ts +29 -0
  69. package/dist/dist-esm/react-components/src/components/Drawer/ReactionDrawerMenuItem.js +60 -0
  70. package/dist/dist-esm/react-components/src/components/Drawer/ReactionDrawerMenuItem.js.map +1 -0
  71. package/dist/dist-esm/react-components/src/components/Drawer/index.d.ts +2 -0
  72. package/dist/dist-esm/react-components/src/components/Drawer/index.js +2 -0
  73. package/dist/dist-esm/react-components/src/components/Drawer/index.js.map +1 -1
  74. package/dist/dist-esm/react-components/src/components/ImageOverlay.js +16 -8
  75. package/dist/dist-esm/react-components/src/components/ImageOverlay.js.map +1 -1
  76. package/dist/dist-esm/react-components/src/components/LocalVideoTile.js +2 -6
  77. package/dist/dist-esm/react-components/src/components/LocalVideoTile.js.map +1 -1
  78. package/dist/dist-esm/react-components/src/components/ParticipantList.js +3 -17
  79. package/dist/dist-esm/react-components/src/components/ParticipantList.js.map +1 -1
  80. package/dist/dist-esm/react-components/src/components/RaiseHandButton.js +0 -7
  81. package/dist/dist-esm/react-components/src/components/RaiseHandButton.js.map +1 -1
  82. package/dist/dist-esm/react-components/src/components/RemoteVideoTile.js +1 -3
  83. package/dist/dist-esm/react-components/src/components/RemoteVideoTile.js.map +1 -1
  84. package/dist/dist-esm/react-components/src/components/VideoGallery.js +1 -3
  85. package/dist/dist-esm/react-components/src/components/VideoGallery.js.map +1 -1
  86. package/dist/dist-esm/react-components/src/components/VideoTile.js +3 -9
  87. package/dist/dist-esm/react-components/src/components/VideoTile.js.map +1 -1
  88. package/dist/dist-esm/react-components/src/components/assets/RaisedHandIcon.js +0 -2
  89. package/dist/dist-esm/react-components/src/components/assets/RaisedHandIcon.js.map +1 -1
  90. package/dist/dist-esm/react-components/src/components/index.js +0 -1
  91. package/dist/dist-esm/react-components/src/components/index.js.map +1 -1
  92. package/dist/dist-esm/react-components/src/components/styles/ReactionButton.styles.d.ts +12 -0
  93. package/dist/dist-esm/react-components/src/components/styles/ReactionButton.styles.js +47 -3
  94. package/dist/dist-esm/react-components/src/components/styles/ReactionButton.styles.js.map +1 -1
  95. package/dist/dist-esm/react-components/src/index.js.map +1 -1
  96. package/dist/dist-esm/react-components/src/localization/LocalizationProvider.js.map +1 -1
  97. package/dist/dist-esm/react-components/src/theming/icons.js +0 -5
  98. package/dist/dist-esm/react-components/src/theming/icons.js.map +1 -1
  99. package/dist/dist-esm/react-components/src/theming/themes.js +1 -3
  100. package/dist/dist-esm/react-components/src/theming/themes.js.map +1 -1
  101. package/dist/dist-esm/react-components/src/types/ParticipantListParticipant.js.map +1 -1
  102. package/dist/dist-esm/react-components/src/types/VideoGalleryParticipant.js.map +1 -1
  103. package/dist/dist-esm/react-composites/src/composites/CallComposite/adapter/AzureCommunicationCallAdapter.d.ts +1 -0
  104. package/dist/dist-esm/react-composites/src/composites/CallComposite/adapter/AzureCommunicationCallAdapter.js +43 -18
  105. package/dist/dist-esm/react-composites/src/composites/CallComposite/adapter/AzureCommunicationCallAdapter.js.map +1 -1
  106. package/dist/dist-esm/react-composites/src/composites/CallComposite/adapter/CallAdapter.js.map +1 -1
  107. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/CallArrangement.js +11 -3
  108. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/CallArrangement.js.map +1 -1
  109. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/CallControls.js +1 -15
  110. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/CallControls.js.map +1 -1
  111. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/LocalAndRemotePIP.js +0 -2
  112. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/LocalAndRemotePIP.js.map +1 -1
  113. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/buttons/RaiseHand.js +0 -8
  114. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/buttons/RaiseHand.js.map +1 -1
  115. package/dist/dist-esm/react-composites/src/composites/CallComposite/hooks/useHandlers.js +0 -3
  116. package/dist/dist-esm/react-composites/src/composites/CallComposite/hooks/useHandlers.js.map +1 -1
  117. package/dist/dist-esm/react-composites/src/composites/CallComposite/selectors/baseSelectors.js +0 -1
  118. package/dist/dist-esm/react-composites/src/composites/CallComposite/selectors/baseSelectors.js.map +1 -1
  119. package/dist/dist-esm/react-composites/src/composites/CallComposite/selectors/localAndRemotePIPSelector.js +1 -9
  120. package/dist/dist-esm/react-composites/src/composites/CallComposite/selectors/localAndRemotePIPSelector.js.map +1 -1
  121. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/CallWithChatComposite.js +0 -3
  122. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/CallWithChatComposite.js.map +1 -1
  123. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/AzureCommunicationCallWithChatAdapter.js +0 -4
  124. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/AzureCommunicationCallWithChatAdapter.js.map +1 -1
  125. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/CallWithChatAdapter.js.map +1 -1
  126. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/CallWithChatBackedCallAdapter.js +0 -2
  127. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/CallWithChatBackedCallAdapter.js.map +1 -1
  128. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/index.js.map +1 -1
  129. package/dist/dist-esm/react-composites/src/composites/ChatComposite/ChatScreen.js +1 -1
  130. package/dist/dist-esm/react-composites/src/composites/ChatComposite/ChatScreen.js.map +1 -1
  131. package/dist/dist-esm/react-composites/src/composites/common/AvatarPersona.js +1 -6
  132. package/dist/dist-esm/react-composites/src/composites/common/AvatarPersona.js.map +1 -1
  133. package/dist/dist-esm/react-composites/src/composites/common/CaptionsBanner.d.ts +1 -0
  134. package/dist/dist-esm/react-composites/src/composites/common/CaptionsBanner.js +1 -1
  135. package/dist/dist-esm/react-composites/src/composites/common/CaptionsBanner.js.map +1 -1
  136. package/dist/dist-esm/react-composites/src/composites/common/ControlBar/CommonCallControlBar.d.ts +1 -0
  137. package/dist/dist-esm/react-composites/src/composites/common/ControlBar/CommonCallControlBar.js +3 -6
  138. package/dist/dist-esm/react-composites/src/composites/common/ControlBar/CommonCallControlBar.js.map +1 -1
  139. package/dist/dist-esm/react-composites/src/composites/common/ControlBar/DesktopMoreButton.js +0 -5
  140. package/dist/dist-esm/react-composites/src/composites/common/ControlBar/DesktopMoreButton.js.map +1 -1
  141. package/dist/dist-esm/react-composites/src/composites/common/Drawer/MoreDrawer.d.ts +4 -0
  142. package/dist/dist-esm/react-composites/src/composites/common/Drawer/MoreDrawer.js +32 -33
  143. package/dist/dist-esm/react-composites/src/composites/common/Drawer/MoreDrawer.js.map +1 -1
  144. package/dist/dist-esm/react-composites/src/composites/common/Drawer/PreparedMoreDrawer.d.ts +3 -0
  145. package/dist/dist-esm/react-composites/src/composites/common/Drawer/PreparedMoreDrawer.js.map +1 -1
  146. package/dist/dist-esm/react-composites/src/composites/common/ParticipantContainer.js +1 -3
  147. package/dist/dist-esm/react-composites/src/composites/common/ParticipantContainer.js.map +1 -1
  148. package/dist/dist-esm/react-composites/src/composites/common/icons.js +0 -1
  149. package/dist/dist-esm/react-composites/src/composites/common/icons.js.map +1 -1
  150. package/dist/dist-esm/react-composites/src/composites/common/types/CommonCallControlOptions.js.map +1 -1
  151. package/dist/dist-esm/react-composites/src/composites/index.js.map +1 -1
  152. package/package.json +1 -1
  153. package/dist/dist-cjs/communication-react/index-DikMcJD4.js.map +0 -1
@@ -173,7 +173,7 @@ function getDefaultExportFromCjs (x) {
173
173
  // Copyright (c) Microsoft Corporation.
174
174
  // Licensed under the MIT License.
175
175
  // GENERATED FILE. DO NOT EDIT MANUALLY.
176
- var telemetryVersion = '1.14.0-alpha-202403140012';
176
+ var telemetryVersion = '1.14.0-alpha-202403160012';
177
177
 
178
178
 
179
179
  var telemetryVersion$1 = /*@__PURE__*/getDefaultExportFromCjs(telemetryVersion);
@@ -408,7 +408,6 @@ const getRemoteParticipants$1 = (state, props) => {
408
408
  var _a;
409
409
  return (_a = state.calls[props.callId]) === null || _a === void 0 ? void 0 : _a.remoteParticipants;
410
410
  };
411
- /* @conditional-compile-remove(raise-hand) */
412
411
  /**
413
412
  * @private
414
413
  */
@@ -440,7 +439,6 @@ const getIsScreenSharingOn = (state, props) => { var _a; return (_a = state.call
440
439
  * @private
441
440
  */
442
441
  const getIsMuted = (state, props) => { var _a; return (_a = state.calls[props.callId]) === null || _a === void 0 ? void 0 : _a.isMuted; };
443
- /* @conditional-compile-remove(optimal-video-count) */
444
442
  /**
445
443
  * @private
446
444
  */
@@ -469,7 +467,6 @@ const getLatestErrors$1 = (state) => state.latestErrors;
469
467
  * @private
470
468
  */
471
469
  const getDiagnostics = (state, props) => { var _a; return (_a = state.calls[props.callId]) === null || _a === void 0 ? void 0 : _a.diagnostics; };
472
- /* @conditional-compile-remove(PSTN-calls) */ /* @conditional-compile-remove(raise-hand) */
473
470
  /**
474
471
  * @private
475
472
  */
@@ -695,7 +692,6 @@ const cameraButtonSelector = reselect__namespace.createSelector([
695
692
  selectedCamera: deviceManager.selectedCamera
696
693
  };
697
694
  });
698
- /* @conditional-compile-remove(raise-hand) */
699
695
  /**
700
696
  * Selector for {@link RaiseHandButton} component.
701
697
  *
@@ -928,11 +924,8 @@ const createDefaultCommonCallingHandlers = memoizeOne((callClient, deviceManager
928
924
  }, options);
929
925
  }
930
926
  });
931
- /* @conditional-compile-remove(raise-hand) */
932
927
  const onRaiseHand = () => __awaiter$Q(void 0, void 0, void 0, function* () { var _a; return yield ((_a = call === null || call === void 0 ? void 0 : call.feature(communicationCalling.Features.RaiseHand)) === null || _a === void 0 ? void 0 : _a.raiseHand()); });
933
- /* @conditional-compile-remove(raise-hand) */
934
928
  const onLowerHand = () => __awaiter$Q(void 0, void 0, void 0, function* () { var _b; return yield ((_b = call === null || call === void 0 ? void 0 : call.feature(communicationCalling.Features.RaiseHand)) === null || _b === void 0 ? void 0 : _b.lowerHand()); });
935
- /* @conditional-compile-remove(raise-hand) */
936
929
  const onToggleRaiseHand = () => __awaiter$Q(void 0, void 0, void 0, function* () {
937
930
  const raiseHandFeature = call === null || call === void 0 ? void 0 : call.feature(communicationCalling.Features.RaiseHand);
938
931
  const localUserId = callClient.getState().userId;
@@ -1218,11 +1211,8 @@ const createDefaultCommonCallingHandlers = memoizeOne((callClient, deviceManager
1218
1211
  onDisposeLocalStreamView,
1219
1212
  onDisposeRemoteScreenShareStreamView,
1220
1213
  onDisposeRemoteVideoStreamView,
1221
- /* @conditional-compile-remove(raise-hand) */
1222
1214
  onRaiseHand,
1223
- /* @conditional-compile-remove(raise-hand) */
1224
1215
  onLowerHand,
1225
- /* @conditional-compile-remove(raise-hand) */
1226
1216
  onToggleRaiseHand,
1227
1217
  /* @conditional-compile-remove(reaction) */
1228
1218
  onReactionClick: onReactionClick,
@@ -1785,7 +1775,6 @@ function convertSdkParticipantToDeclarativeParticipant(participant) {
1785
1775
  videoStreams: declarativeVideoStreams,
1786
1776
  isMuted: participant.isMuted,
1787
1777
  isSpeaking: participant.isSpeaking,
1788
- /* @conditional-compile-remove(raise-hand) */
1789
1778
  raisedHand: undefined,
1790
1779
  /* @conditional-compile-remove(hide-attendee-name) */
1791
1780
  role: participant.role,
@@ -1826,9 +1815,10 @@ function convertSdkCallToDeclarativeCall(call) {
1826
1815
  remoteParticipants: declarativeRemoteParticipants,
1827
1816
  remoteParticipantsEnded: {},
1828
1817
  recording: { isRecordingActive: false },
1818
+ /* @conditional-compile-remove(local-recording-notification) */
1819
+ localRecording: { isLocalRecordingActive: false },
1829
1820
  /* @conditional-compile-remove(ppt-live) */
1830
1821
  pptLive: { isActive: false },
1831
- /* @conditional-compile-remove(raise-hand) */
1832
1822
  raiseHand: { raisedHands: [] },
1833
1823
  /* @conditional-compile-remove(reaction) */
1834
1824
  localParticipantReaction: undefined,
@@ -1852,7 +1842,6 @@ function convertSdkCallToDeclarativeCall(call) {
1852
1842
  transfer: {
1853
1843
  acceptedTransfers: {}
1854
1844
  },
1855
- /* @conditional-compile-remove(optimal-video-count) */
1856
1845
  optimalVideoCount: {
1857
1846
  maxRemoteVideoStreams: call.feature(communicationCalling.Features.OptimalVideoCount).optimalVideoCount
1858
1847
  },
@@ -1886,9 +1875,16 @@ function convertFromSDKToDeclarativeVideoStreamRendererView(view) {
1886
1875
  /**
1887
1876
  * @private
1888
1877
  */
1889
- function convertFromSDKToCaptionInfoState(caption) {
1878
+ function convertFromTeamsSDKToCaptionInfoState(caption) {
1890
1879
  return Object.assign({}, caption);
1891
1880
  }
1881
+ /* @conditional-compile-remove(acs-close-captions) */
1882
+ /**
1883
+ * @private
1884
+ */
1885
+ function convertFromSDKToCaptionInfoState(caption) {
1886
+ return Object.assign({ captionText: caption.spokenText }, caption);
1887
+ }
1892
1888
  /* @conditional-compile-remove(video-background-effects) */
1893
1889
  /** @private */
1894
1890
  function convertFromSDKToDeclarativeVideoStreamVideoEffects(videoEffects) {
@@ -1896,7 +1892,6 @@ function convertFromSDKToDeclarativeVideoStreamVideoEffects(videoEffects) {
1896
1892
  activeEffects: videoEffects
1897
1893
  };
1898
1894
  }
1899
- /* @conditional-compile-remove(raise-hand) */
1900
1895
  /**
1901
1896
  * @private
1902
1897
  */
@@ -2022,14 +2017,11 @@ let CallContext$2 = class CallContext {
2022
2017
  existingCall.localVideoStreams = call.localVideoStreams;
2023
2018
  existingCall.remoteParticipants = call.remoteParticipants;
2024
2019
  existingCall.transcription.isTranscriptionActive = call.transcription.isTranscriptionActive;
2025
- /* @conditional-compile-remove(optimal-video-count) */
2026
2020
  existingCall.optimalVideoCount.maxRemoteVideoStreams = call.optimalVideoCount.maxRemoteVideoStreams;
2027
2021
  existingCall.recording.isRecordingActive = call.recording.isRecordingActive;
2028
- /* @conditional-compile-remove(raise-hand) */
2029
2022
  existingCall.raiseHand.raisedHands = call.raiseHand.raisedHands;
2030
2023
  /* @conditional-compile-remove(ppt-live) */
2031
2024
  existingCall.pptLive.isActive = call.pptLive.isActive;
2032
- /* @conditional-compile-remove(raise-hand) */
2033
2025
  existingCall.raiseHand.localParticipantRaisedHand = call.raiseHand.localParticipantRaisedHand;
2034
2026
  /* @conditional-compile-remove(rooms) */
2035
2027
  existingCall.role = call.role;
@@ -2209,6 +2201,35 @@ let CallContext$2 = class CallContext {
2209
2201
  }
2210
2202
  });
2211
2203
  }
2204
+ /* @conditional-compile-remove(local-recording-notification) */
2205
+ setCallRecordingInfos(callId, recordingInfosAdded, lastStoppedRecording) {
2206
+ this.modifyState((draft) => {
2207
+ const call = draft.calls[this._callIdHistory.latestCallId(callId)];
2208
+ if (call) {
2209
+ call.recording.activeRecordings = recordingInfosAdded;
2210
+ call.recording.lastStoppedRecording = lastStoppedRecording;
2211
+ }
2212
+ });
2213
+ }
2214
+ /* @conditional-compile-remove(local-recording-notification) */
2215
+ setCallLocalRecordingActive(callId, isRecordingActive) {
2216
+ this.modifyState((draft) => {
2217
+ const call = draft.calls[this._callIdHistory.latestCallId(callId)];
2218
+ if (call) {
2219
+ call.localRecording.isLocalRecordingActive = isRecordingActive;
2220
+ }
2221
+ });
2222
+ }
2223
+ /* @conditional-compile-remove(local-recording-notification) */
2224
+ setCallLocalRecordingInfos(callId, localRecordingInfosAdded, lastStoppedRecording) {
2225
+ this.modifyState((draft) => {
2226
+ const call = draft.calls[this._callIdHistory.latestCallId(callId)];
2227
+ if (call) {
2228
+ call.localRecording.activeLocalRecordings = localRecordingInfosAdded;
2229
+ call.localRecording.lastStoppedLocalRecording = lastStoppedRecording;
2230
+ }
2231
+ });
2232
+ }
2212
2233
  /* @conditional-compile-remove(ppt-live) */
2213
2234
  setCallPPTLiveActive(callId, isActive) {
2214
2235
  this.modifyState((draft) => {
@@ -2231,7 +2252,6 @@ let CallContext$2 = class CallContext {
2231
2252
  }
2232
2253
  });
2233
2254
  }
2234
- /* @conditional-compile-remove(raise-hand) */
2235
2255
  setCallRaisedHands(callId, raisedHands) {
2236
2256
  this.modifyState((draft) => {
2237
2257
  const call = draft.calls[this._callIdHistory.latestCallId(callId)];
@@ -2249,7 +2269,6 @@ let CallContext$2 = class CallContext {
2249
2269
  }
2250
2270
  });
2251
2271
  }
2252
- /* @conditional-compile-remove(raise-hand) */
2253
2272
  setParticipantIsRaisedHand(callId, participantKey, raisedHand) {
2254
2273
  this.modifyState((draft) => {
2255
2274
  const call = draft.calls[this._callIdHistory.latestCallId(callId)];
@@ -2387,7 +2406,6 @@ let CallContext$2 = class CallContext {
2387
2406
  }
2388
2407
  });
2389
2408
  }
2390
- /* @conditional-compile-remove(optimal-video-count) */
2391
2409
  setOptimalVideoCount(callId, optimalVideoCount) {
2392
2410
  this.modifyState((draft) => {
2393
2411
  const call = draft.calls[this._callIdHistory.latestCallId(callId)];
@@ -2683,7 +2701,7 @@ let CallContext$2 = class CallContext {
2683
2701
  }
2684
2702
  }
2685
2703
  /* @conditional-compile-remove(close-captions) */
2686
- addCaption(callId, caption) {
2704
+ addTeamsCaption(callId, caption) {
2687
2705
  this.modifyState((draft) => {
2688
2706
  const call = draft.calls[this._callIdHistory.latestCallId(callId)];
2689
2707
  if (call) {
@@ -2691,11 +2709,20 @@ let CallContext$2 = class CallContext {
2691
2709
  if (caption.captionLanguage.toUpperCase() === currentCaptionLanguage.toUpperCase() ||
2692
2710
  currentCaptionLanguage === '' ||
2693
2711
  currentCaptionLanguage === undefined) {
2694
- this.processNewCaption(call.captionsFeature.captions, convertFromSDKToCaptionInfoState(caption));
2712
+ this.processNewCaption(call.captionsFeature.captions, convertFromTeamsSDKToCaptionInfoState(caption));
2695
2713
  }
2696
2714
  }
2697
2715
  });
2698
2716
  }
2717
+ /* @conditional-compile-remove(acs-close-captions) */
2718
+ addCaption(callId, caption) {
2719
+ this.modifyState((draft) => {
2720
+ const call = draft.calls[this._callIdHistory.latestCallId(callId)];
2721
+ if (call) {
2722
+ this.processNewCaption(call.captionsFeature.captions, convertFromSDKToCaptionInfoState(caption));
2723
+ }
2724
+ });
2725
+ }
2699
2726
  /* @conditional-compile-remove(close-captions) */
2700
2727
  clearCaptions(callId) {
2701
2728
  this.modifyState((draft) => {
@@ -2849,7 +2876,7 @@ function clearParticipantReactionState(callContext, callId, participantKey) {
2849
2876
  /**
2850
2877
  * @private
2851
2878
  */
2852
- class CaptionsSubscriber {
2879
+ class TeamsCaptionsSubscriber {
2853
2880
  constructor(callIdRef, context, captions) {
2854
2881
  this.subscribe = () => {
2855
2882
  this._captions.on('CaptionsActiveChanged', this.isCaptionsActiveChanged);
@@ -2864,7 +2891,7 @@ class CaptionsSubscriber {
2864
2891
  this._captions.off('SpokenLanguageChanged', this.isSpokenLanguageChanged);
2865
2892
  };
2866
2893
  this.onCaptionsReceived = (caption) => {
2867
- this._context.addCaption(this._callIdRef.callId, caption);
2894
+ this._context.addTeamsCaption(this._callIdRef.callId, caption);
2868
2895
  };
2869
2896
  this.isCaptionsActiveChanged = () => {
2870
2897
  this._context.setIsCaptionActive(this._callIdRef.callId, this._captions.isCaptionsFeatureActive);
@@ -2890,6 +2917,42 @@ class CaptionsSubscriber {
2890
2917
  this.subscribe();
2891
2918
  }
2892
2919
  }
2920
+ /* @conditional-compile-remove(acs-close-captions) */
2921
+ /**
2922
+ * @private
2923
+ */
2924
+ class CaptionsSubscriber {
2925
+ constructor(callIdRef, context, captions) {
2926
+ this.subscribe = () => {
2927
+ this._captions.on('CaptionsActiveChanged', this.isCaptionsActiveChanged);
2928
+ this._captions.on('SpokenLanguageChanged', this.isSpokenLanguageChanged);
2929
+ this._captions.on('CaptionsReceived', this.onCaptionsReceived);
2930
+ };
2931
+ this.unsubscribe = () => {
2932
+ this._captions.off('CaptionsActiveChanged', this.isCaptionsActiveChanged);
2933
+ this._captions.off('SpokenLanguageChanged', this.isSpokenLanguageChanged);
2934
+ this._captions.off('CaptionsReceived', this.onCaptionsReceived);
2935
+ };
2936
+ this.onCaptionsReceived = (caption) => {
2937
+ this._context.addCaption(this._callIdRef.callId, caption);
2938
+ };
2939
+ this.isCaptionsActiveChanged = () => {
2940
+ this._context.setIsCaptionActive(this._callIdRef.callId, this._captions.isCaptionsFeatureActive);
2941
+ };
2942
+ this.isSpokenLanguageChanged = () => {
2943
+ this._context.setSelectedSpokenLanguage(this._callIdRef.callId, this._captions.activeSpokenLanguage);
2944
+ };
2945
+ this._callIdRef = callIdRef;
2946
+ this._context = context;
2947
+ this._captions = captions;
2948
+ if (this._captions.isCaptionsFeatureActive) {
2949
+ this._context.setIsCaptionActive(this._callIdRef.callId, this._captions.isCaptionsFeatureActive);
2950
+ }
2951
+ this._context.setAvailableSpokenLanguages(this._callIdRef.callId, this._captions.supportedSpokenLanguages);
2952
+ this._context.setSelectedSpokenLanguage(this._callIdRef.callId, this._captions.activeSpokenLanguage);
2953
+ this.subscribe();
2954
+ }
2955
+ }
2893
2956
 
2894
2957
  // Copyright (c) Microsoft Corporation.
2895
2958
  // Licensed under the MIT License.
@@ -3693,13 +3756,21 @@ class RecordingSubscriber {
3693
3756
  constructor(callIdRef, context, recording) {
3694
3757
  this.subscribe = () => {
3695
3758
  this._recording.on('isRecordingActiveChanged', this.isAvailableChanged);
3759
+ /* @conditional-compile-remove(local-recording-notification) */
3760
+ this._recording.on('recordingsUpdated', this.isRecordingsUpdated);
3696
3761
  };
3697
3762
  this.unsubscribe = () => {
3698
3763
  this._recording.off('isRecordingActiveChanged', this.isAvailableChanged);
3764
+ /* @conditional-compile-remove(local-recording-notification) */
3765
+ this._recording.off('recordingsUpdated', this.isRecordingsUpdated);
3699
3766
  };
3700
3767
  this.isAvailableChanged = () => {
3701
3768
  this._context.setCallRecordingActive(this._callIdRef.callId, this._recording.isRecordingActive);
3702
3769
  };
3770
+ /* @conditional-compile-remove(local-recording-notification) */
3771
+ this.isRecordingsUpdated = (data) => {
3772
+ this._context.setCallRecordingInfos(this._callIdRef.callId, this._recording.recordings, data.removed);
3773
+ };
3703
3774
  this._callIdRef = callIdRef;
3704
3775
  this._context = context;
3705
3776
  this._recording = recording;
@@ -3707,6 +3778,9 @@ class RecordingSubscriber {
3707
3778
  // be an event for it.
3708
3779
  if (this._recording.isRecordingActive) {
3709
3780
  this._context.setCallRecordingActive(this._callIdRef.callId, this._recording.isRecordingActive);
3781
+ /* @conditional-compile-remove(local-recording-notification) */
3782
+ // recordings getter only returns a list of active recordings, so we can set the list of recordings here
3783
+ this._context.setCallRecordingInfos(this._callIdRef.callId, this._recording.recordings, []);
3710
3784
  }
3711
3785
  this.subscribe();
3712
3786
  }
@@ -3863,8 +3937,6 @@ const latestFromEvent = (args) => ({
3863
3937
 
3864
3938
  // Copyright (c) Microsoft Corporation.
3865
3939
  // Licensed under the MIT License.
3866
- /* @conditional-compile-remove(raise-hand) */
3867
- /* @conditional-compile-remove(raise-hand) */
3868
3940
  /**
3869
3941
  * @private
3870
3942
  */
@@ -3897,7 +3969,6 @@ class RaiseHandSubscriber {
3897
3969
 
3898
3970
  // Copyright (c) Microsoft Corporation.
3899
3971
  // Licensed under the MIT License.
3900
- /* @conditional-compile-remove(optimal-video-count) */
3901
3972
  /**
3902
3973
  * Subscribes to a Optimal Video Count Feature events and updates the call context appropriately.
3903
3974
  * @private
@@ -4001,6 +4072,42 @@ class SpotlightSubscriber {
4001
4072
  }
4002
4073
  }
4003
4074
 
4075
+ // Copyright (c) Microsoft Corporation.
4076
+ // Licensed under the MIT License.
4077
+ /* @conditional-compile-remove(local-recording-notification) */
4078
+ /**
4079
+ * @private
4080
+ */
4081
+ class LocalRecordingSubscriber {
4082
+ constructor(callIdRef, context, recording) {
4083
+ this.subscribe = () => {
4084
+ this._recording.on('isLocalRecordingActiveChanged', this.isAvailableChanged);
4085
+ this._recording.on('localRecordingsUpdated', this.isRecordingsUpdated);
4086
+ };
4087
+ this.unsubscribe = () => {
4088
+ this._recording.off('isLocalRecordingActiveChanged', this.isAvailableChanged);
4089
+ this._recording.off('localRecordingsUpdated', this.isRecordingsUpdated);
4090
+ };
4091
+ this.isAvailableChanged = () => {
4092
+ this._context.setCallLocalRecordingActive(this._callIdRef.callId, this._recording.isRecordingActive);
4093
+ };
4094
+ this.isRecordingsUpdated = (data) => {
4095
+ this._context.setCallLocalRecordingInfos(this._callIdRef.callId, this._recording.recordings, data.removed);
4096
+ };
4097
+ this._callIdRef = callIdRef;
4098
+ this._context = context;
4099
+ this._recording = recording;
4100
+ // If recording as already started when we joined the call, make sure it is reflected in state as there may not
4101
+ // be an event for it.
4102
+ if (this._recording.isRecordingActive) {
4103
+ this._context.setCallLocalRecordingActive(this._callIdRef.callId, this._recording.isRecordingActive);
4104
+ // recordings getter only returns a list of active recordings, so we can set the list of recordings here
4105
+ this._context.setCallLocalRecordingInfos(this._callIdRef.callId, this._recording.recordings, []);
4106
+ }
4107
+ this.subscribe();
4108
+ }
4109
+ }
4110
+
4004
4111
  // Copyright (c) Microsoft Corporation.
4005
4112
  // Licensed under the MIT License.
4006
4113
  /**
@@ -4035,7 +4142,7 @@ class CallSubscriber {
4035
4142
  }
4036
4143
  };
4037
4144
  this.unsubscribe = () => {
4038
- var _a, _b, _c;
4145
+ var _a, _b, _c, _d;
4039
4146
  this._call.off('stateChanged', this.stateChanged);
4040
4147
  /* @conditional-compile-remove(close-captions) */
4041
4148
  this._call.off('stateChanged', this.initCaptionSubscriber);
@@ -4062,18 +4169,20 @@ class CallSubscriber {
4062
4169
  this._diagnosticsSubscriber.unsubscribe();
4063
4170
  this._recordingSubscriber.unsubscribe();
4064
4171
  this._transcriptionSubscriber.unsubscribe();
4065
- /* @conditional-compile-remove(optimal-video-count) */
4172
+ /* @conditional-compile-remove(local-recording-notification) */
4173
+ this._localRecordingSubscriber.unsubscribe();
4066
4174
  this._optimalVideoCountSubscriber.unsubscribe();
4067
4175
  /* @conditional-compile-remove(ppt-live) */
4068
4176
  this._pptLiveSubscriber.unsubscribe();
4069
4177
  /* @conditional-compile-remove(close-captions) */
4070
- (_a = this._captionsSubscriber) === null || _a === void 0 ? void 0 : _a.unsubscribe();
4071
- /* @conditional-compile-remove(raise-hand) */
4072
- (_b = this._raiseHandSubscriber) === null || _b === void 0 ? void 0 : _b.unsubscribe();
4178
+ (_a = this._TeamsCaptionsSubscriber) === null || _a === void 0 ? void 0 : _a.unsubscribe();
4179
+ /* @conditional-compile-remove(acs-close-captions) */
4180
+ (_b = this._CaptionsSubscriber) === null || _b === void 0 ? void 0 : _b.unsubscribe();
4181
+ (_c = this._raiseHandSubscriber) === null || _c === void 0 ? void 0 : _c.unsubscribe();
4073
4182
  /* @conditional-compile-remove(capabilities) */
4074
4183
  this._capabilitiesSubscriber.unsubscribe();
4075
4184
  /* @conditional-compile-remove(reaction) */
4076
- (_c = this._reactionSubscriber) === null || _c === void 0 ? void 0 : _c.unsubscribe();
4185
+ (_d = this._reactionSubscriber) === null || _d === void 0 ? void 0 : _d.unsubscribe();
4077
4186
  /* @conditional-compile-remove(spotlight) */
4078
4187
  this._spotlightSubscriber.unsubscribe();
4079
4188
  };
@@ -4083,11 +4192,17 @@ class CallSubscriber {
4083
4192
  /* @conditional-compile-remove(close-captions) */
4084
4193
  this.initCaptionSubscriber = () => {
4085
4194
  // subscribe to captions here so that we don't call captions when call is not initialized
4086
- if (this._call.state === 'Connected' && !this._captionsSubscriber) {
4195
+ if (this._call.state === 'Connected' &&
4196
+ !this._TeamsCaptionsSubscriber &&
4197
+ /* @conditional-compile-remove(acs-close-captions) */ !this._CaptionsSubscriber) {
4087
4198
  if (this._call.feature(communicationCalling.Features.Captions).captions.kind === 'TeamsCaptions') {
4088
- this._captionsSubscriber = new CaptionsSubscriber(this._callIdRef, this._context, this._call.feature(communicationCalling.Features.Captions).captions);
4089
- this._call.off('stateChanged', this.initCaptionSubscriber);
4199
+ this._TeamsCaptionsSubscriber = new TeamsCaptionsSubscriber(this._callIdRef, this._context, this._call.feature(communicationCalling.Features.Captions).captions);
4090
4200
  }
4201
+ else {
4202
+ /* @conditional-compile-remove(acs-close-captions) */
4203
+ this._CaptionsSubscriber = new CaptionsSubscriber(this._callIdRef, this._context, this._call.feature(communicationCalling.Features.Captions).captions);
4204
+ }
4205
+ this._call.off('stateChanged', this.initCaptionSubscriber);
4091
4206
  }
4092
4207
  };
4093
4208
  this.idChanged = () => {
@@ -4161,14 +4276,14 @@ class CallSubscriber {
4161
4276
  this._diagnosticsSubscriber = new UserFacingDiagnosticsSubscriber(this._callIdRef, this._context, this._call.feature(communicationCalling.Features.UserFacingDiagnostics));
4162
4277
  this._participantSubscribers = new Map();
4163
4278
  this._recordingSubscriber = new RecordingSubscriber(this._callIdRef, this._context, this._call.feature(communicationCalling.Features.Recording));
4279
+ /* @conditional-compile-remove(local-recording-notification) */
4280
+ this._localRecordingSubscriber = new LocalRecordingSubscriber(this._callIdRef, this._context, this._call.feature(communicationCalling.Features.LocalRecording));
4164
4281
  /* @conditional-compile-remove(ppt-live) */
4165
4282
  this._pptLiveSubscriber = new PPTLiveSubscriber(this._callIdRef, this._context, this._call);
4166
4283
  this._transcriptionSubscriber = new TranscriptionSubscriber(this._callIdRef, this._context, this._call.feature(communicationCalling.Features.Transcription));
4167
- /* @conditional-compile-remove(raise-hand) */
4168
4284
  this._raiseHandSubscriber = new RaiseHandSubscriber(this._callIdRef, this._context, this._call.feature(communicationCalling.Features.RaiseHand));
4169
4285
  /* @conditional-compile-remove(reaction) */
4170
4286
  this._reactionSubscriber = new ReactionSubscriber(this._callIdRef, this._context, this._call.feature(communicationCalling.Features.Reaction));
4171
- /* @conditional-compile-remove(optimal-video-count) */
4172
4287
  this._optimalVideoCountSubscriber = new OptimalVideoCountSubscriber({
4173
4288
  callIdRef: this._callIdRef,
4174
4289
  context: this._context,
@@ -4554,7 +4669,13 @@ class ProxyCallCommon {
4554
4669
  /* @conditional-compile-remove(close-captions) */
4555
4670
  if (args[0] === communicationCalling.Features.Captions) {
4556
4671
  const captionsFeature = target.feature(communicationCalling.Features.Captions).captions;
4557
- const proxyFeature = new ProxyTeamsCaptions(this._context, target);
4672
+ let proxyFeature;
4673
+ /* @conditional-compile-remove(acs-close-captions) */
4674
+ if (captionsFeature.kind === 'Captions') {
4675
+ proxyFeature = new ProxyCaptions(this._context, target);
4676
+ return { captions: new Proxy(captionsFeature, proxyFeature) };
4677
+ }
4678
+ proxyFeature = new ProxyTeamsCaptions(this._context, target);
4558
4679
  return { captions: new Proxy(captionsFeature, proxyFeature) };
4559
4680
  }
4560
4681
  /* @conditional-compile-remove(call-transfer) */
@@ -4621,6 +4742,44 @@ class ProxyTeamsCaptions {
4621
4742
  }
4622
4743
  }
4623
4744
  }
4745
+ /* @conditional-compile-remove(acs-close-captions) */
4746
+ /**
4747
+ * @private
4748
+ */
4749
+ class ProxyCaptions {
4750
+ constructor(context, call) {
4751
+ this._context = context;
4752
+ this._call = call;
4753
+ }
4754
+ get(target, prop) {
4755
+ switch (prop) {
4756
+ case 'startCaptions':
4757
+ return this._context.withAsyncErrorTeedToState((...args) => __awaiter$I(this, void 0, void 0, function* () {
4758
+ var _a, _b;
4759
+ this._context.setStartCaptionsInProgress(this._call.id, true);
4760
+ const ret = yield target.startCaptions(...args);
4761
+ this._context.setSelectedSpokenLanguage(this._call.id, (_b = (_a = args[0]) === null || _a === void 0 ? void 0 : _a.spokenLanguage) !== null && _b !== void 0 ? _b : 'en-us');
4762
+ return ret;
4763
+ }), 'Call.feature');
4764
+ case 'stopCaptions':
4765
+ return this._context.withAsyncErrorTeedToState((...args) => __awaiter$I(this, void 0, void 0, function* () {
4766
+ const ret = yield target.stopCaptions(...args);
4767
+ this._context.setIsCaptionActive(this._call.id, false);
4768
+ this._context.setStartCaptionsInProgress(this._call.id, false);
4769
+ this._context.clearCaptions(this._call.id);
4770
+ return ret;
4771
+ }), 'Call.feature');
4772
+ case 'setSpokenLanguage':
4773
+ return this._context.withAsyncErrorTeedToState((...args) => __awaiter$I(this, void 0, void 0, function* () {
4774
+ const ret = yield target.setSpokenLanguage(...args);
4775
+ this._context.setSelectedSpokenLanguage(this._call.id, args[0]);
4776
+ return ret;
4777
+ }), 'Call.feature');
4778
+ default:
4779
+ return Reflect.get(target, prop);
4780
+ }
4781
+ }
4782
+ }
4624
4783
  /* @conditional-compile-remove(spotlight) */
4625
4784
  /**
4626
4785
  * @private
@@ -6313,7 +6472,6 @@ const lightTheme = {
6313
6472
  callRedDark: '#8b2c3d',
6314
6473
  callRedDarker: '#772a38',
6315
6474
  iconWhite: '#ffffff',
6316
- /* @conditional-compile-remove(raise-hand) */
6317
6475
  raiseHandGold: '#eaa300'
6318
6476
  },
6319
6477
  semanticColors: {
@@ -6356,14 +6514,13 @@ const darkTheme = {
6356
6514
  callRedDark: '#a42e43',
6357
6515
  callRedDarker: '#8b2c3d',
6358
6516
  iconWhite: '#ffffff',
6359
- /* @conditional-compile-remove(raise-hand) */
6360
6517
  raiseHandGold: '#eaa300'
6361
6518
  },
6362
6519
  semanticColors: {
6363
6520
  errorText: '#f1707b'
6364
6521
  }
6365
6522
  };
6366
- /* @conditional-compile-remove(image-overlay) */
6523
+ /* @conditional-compile-remove(image-overlay-theme) */
6367
6524
  /**
6368
6525
  * Preset dark theme for the ImageOverlay component.
6369
6526
  *
@@ -6551,13 +6708,9 @@ const DEFAULT_COMPONENT_ICONS = {
6551
6708
  ControlButtonParticipantsContextualMenuItem: React.createElement(reactIcons.People20Regular, null),
6552
6709
  ControlButtonScreenShareStart: React.createElement(reactIcons.ShareScreenStart20Filled, null),
6553
6710
  ControlButtonScreenShareStop: React.createElement(reactIcons.ShareScreenStop20Filled, null),
6554
- /* @conditional-compile-remove(raise-hand) */
6555
6711
  ControlButtonRaiseHand: React.createElement(ControlButtonRaiseHandIcon, null),
6556
- /* @conditional-compile-remove(raise-hand) */
6557
6712
  ControlButtonLowerHand: React.createElement(ControlButtonLowerHandIcon, null),
6558
- /* @conditional-compile-remove(raise-hand) */
6559
6713
  RaiseHandContextualMenuItem: React.createElement(reactIcons.HandRight20Regular, null),
6560
- /* @conditional-compile-remove(raise-hand) */
6561
6714
  LowerHandContextualMenuItem: React.createElement(reactIcons.HandRightOff20Regular, null),
6562
6715
  /* @conditional-compile-remove(reaction) */
6563
6716
  ReactionButtonIcon: React.createElement(reactIcons.Emoji20Regular, null),
@@ -9158,18 +9311,23 @@ const ImageOverlay = (props) => {
9158
9311
  /* @conditional-compile-remove(image-overlay) */
9159
9312
  const localeStrings = useLocale$1().strings.imageOverlay;
9160
9313
  const [isImageLoaded, setIsImageLoaded] = React.useState(true);
9161
- const imageStyle = isImageLoaded ? normalImageStyle : brokenImageStyle(imageOverlayTheme);
9314
+ /* @conditional-compile-remove(image-overlay) */
9315
+ const overlayTheme = React.useMemo(() => {
9316
+ /* @conditional-compile-remove(image-overlay-theme) */
9317
+ return imageOverlayTheme;
9318
+ }, []);
9319
+ const imageStyle = isImageLoaded ? normalImageStyle : brokenImageStyle(overlayTheme);
9162
9320
  const renderHeaderBar = () => {
9163
9321
  return (React.createElement(react.Stack, { className: react.mergeStyles(headerStyle) },
9164
9322
  React.createElement(react.Stack, { className: react.mergeStyles(titleBarContainerStyle) },
9165
9323
  titleIcon,
9166
- React.createElement(react.Stack.Item, { className: react.mergeStyles(titleStyle$2(imageOverlayTheme)), "aria-label": title || 'Image' }, title)),
9324
+ React.createElement(react.Stack.Item, { className: react.mergeStyles(titleStyle$2(overlayTheme)), "aria-label": title || 'Image' }, title)),
9167
9325
  React.createElement(react.Stack, { className: react.mergeStyles(controlBarContainerStyle) },
9168
9326
  onDownloadButtonClicked && (React.createElement(react.DefaultButton, { className: react.mergeStyles(downloadButtonStyle),
9169
9327
  /* @conditional-compile-remove(image-overlay) */
9170
9328
  text: localeStrings.downloadButtonLabel, onClick: () => onDownloadButtonClicked && onDownloadButtonClicked(imageSrc), onRenderIcon: () => React.createElement(react.Icon, { iconName: downloadIcon.iconName, className: react.mergeStyles(downloadIconStyle) }), "aria-live": 'polite', "aria-label": localeStrings.downloadButtonLabel, disabled: imageSrc === '' })),
9171
- onDownloadButtonClicked && (React.createElement(react.IconButton, { iconProps: downloadIcon, className: react.mergeStyles(smallDownloadButtonContainerStyle(imageOverlayTheme)), onClick: () => onDownloadButtonClicked && onDownloadButtonClicked(imageSrc), "aria-label": localeStrings.downloadButtonLabel, "aria-live": 'polite', disabled: imageSrc === '' })),
9172
- React.createElement(react.IconButton, { iconProps: cancelIcon, className: react.mergeStyles(closeButtonStyles(imageOverlayTheme)), onClick: onDismiss,
9329
+ onDownloadButtonClicked && (React.createElement(react.IconButton, { iconProps: downloadIcon, className: react.mergeStyles(smallDownloadButtonContainerStyle(overlayTheme)), onClick: () => onDownloadButtonClicked && onDownloadButtonClicked(imageSrc), "aria-label": localeStrings.downloadButtonLabel, "aria-live": 'polite', disabled: imageSrc === '' })),
9330
+ React.createElement(react.IconButton, { iconProps: cancelIcon, className: react.mergeStyles(closeButtonStyles(overlayTheme)), onClick: onDismiss,
9173
9331
  /* @conditional-compile-remove(image-overlay) */
9174
9332
  ariaLabel: localeStrings.dismissButtonAriaLabel, "aria-live": 'polite' }))));
9175
9333
  };
@@ -9180,8 +9338,8 @@ const ImageOverlay = (props) => {
9180
9338
  event.persist();
9181
9339
  } }))));
9182
9340
  };
9183
- return (React.createElement(react.Modal, { titleAriaId: title, isOpen: isOpen, onDismiss: onDismiss, overlay: { styles: Object.assign({}, overlayStyles(imageOverlayTheme)) }, styles: { main: focusTrapZoneStyle, scrollableContent: scrollableContentStyle }, isDarkOverlay: true },
9184
- React.createElement(FluentThemeProvider, { fluentTheme: imageOverlayTheme, rootStyle: themeProviderRootStyle },
9341
+ return (React.createElement(react.Modal, { titleAriaId: title, isOpen: isOpen, onDismiss: onDismiss, overlay: { styles: Object.assign({}, overlayStyles(overlayTheme)) }, styles: { main: focusTrapZoneStyle, scrollableContent: scrollableContentStyle }, isDarkOverlay: true },
9342
+ React.createElement(FluentThemeProvider, { fluentTheme: overlayTheme, rootStyle: themeProviderRootStyle },
9185
9343
  renderHeaderBar(),
9186
9344
  renderBodyWithLightDismiss())));
9187
9345
  };
@@ -12861,8 +13019,6 @@ const participantStateStringTrampoline$1 = (props, strings) => {
12861
13019
 
12862
13020
  // Copyright (c) Microsoft Corporation.
12863
13021
  // Licensed under the MIT License.
12864
- /* @conditional-compile-remove(raise-hand) */
12865
- /* @conditional-compile-remove(raise-hand) */
12866
13022
  /**
12867
13023
  * Raised hand icon for ParticipantList and VideoTitle.
12868
13024
  *
@@ -13131,16 +13287,12 @@ const onRenderParticipantDefault = (participant, strings, myUserId, onRenderAvat
13131
13287
  };
13132
13288
  /* @conditional-compile-remove(hide-attendee-name) */
13133
13289
  displayName = formatDisplayName();
13134
- /* @conditional-compile-remove(raise-hand) */
13135
13290
  const callingPalette = theme.callingPalette;
13136
- const onRenderIcon = (callingParticipant === null || callingParticipant === void 0 ? void 0 : callingParticipant.isScreenSharing) ||
13137
- (callingParticipant === null || callingParticipant === void 0 ? void 0 : callingParticipant.isMuted) ||
13138
- (
13139
- /* @conditional-compile-remove(raise-hand) */ callingParticipant === null || callingParticipant === void 0 ? void 0 : callingParticipant.raisedHand)
13291
+ const onRenderIcon = (callingParticipant === null || callingParticipant === void 0 ? void 0 : callingParticipant.isScreenSharing) || (callingParticipant === null || callingParticipant === void 0 ? void 0 : callingParticipant.isMuted) || (callingParticipant === null || callingParticipant === void 0 ? void 0 : callingParticipant.raisedHand)
13140
13292
  ? () => {
13141
13293
  var _a;
13142
13294
  return (React.createElement(react.Stack, { horizontal: true, tokens: { childrenGap: '0.5rem' } },
13143
- /* @conditional-compile-remove(raise-hand) */ callingParticipant.raisedHand && (React.createElement(react.Stack, { horizontal: true, tokens: { childrenGap: '0.2rem' }, style: {
13295
+ callingParticipant.raisedHand && (React.createElement(react.Stack, { horizontal: true, tokens: { childrenGap: '0.2rem' }, style: {
13144
13296
  alignItems: 'center',
13145
13297
  padding: '0.1rem 0.2rem',
13146
13298
  backgroundColor: theme === null || theme === void 0 ? void 0 : theme.palette.neutralLighter,
@@ -13155,7 +13307,6 @@ const onRenderParticipantDefault = (participant, strings, myUserId, onRenderAvat
13155
13307
  /* @conditional-compile-remove(spotlight) */ callingParticipant.spotlight && (React.createElement(react.Icon, { iconName: "ParticipantItemSpotlighted", className: iconStyles$2 }))));
13156
13308
  }
13157
13309
  : () => null;
13158
- /* @conditional-compile-remove(raise-hand) */
13159
13310
  const onRenderAvatarWithRaiseHand = (callingParticipant === null || callingParticipant === void 0 ? void 0 : callingParticipant.raisedHand) && onRenderAvatar
13160
13311
  ? (userId, options, defaultOnRender) => onRenderAvatar(userId, Object.assign(Object.assign({}, options), { styles: { root: { border: callingPalette.raiseHandGold } } }), defaultOnRender)
13161
13312
  : onRenderAvatar;
@@ -13168,11 +13319,9 @@ const onRenderParticipantDefault = (participant, strings, myUserId, onRenderAvat
13168
13319
  * Sort participants by raised hand order position
13169
13320
  */
13170
13321
  const sortParticipants = (participants) => {
13171
- /* @conditional-compile-remove(raise-hand) */
13172
13322
  const isParticipantListCallParticipant = function (participant) {
13173
13323
  return 'raisedHand' in participant;
13174
13324
  };
13175
- /* @conditional-compile-remove(raise-hand) */
13176
13325
  participants.sort((a, b) => {
13177
13326
  if (!isParticipantListCallParticipant(a) || !isParticipantListCallParticipant(b)) {
13178
13327
  return 0;
@@ -13218,7 +13367,6 @@ const ParticipantList$k = (props) => {
13218
13367
  totalParticipantCount,
13219
13368
  /* @conditional-compile-remove(total-participant-count) */
13220
13369
  strings, participantAriaLabelledBy } = props;
13221
- /* @conditional-compile-remove(raise-hand) */
13222
13370
  const theme = useTheme();
13223
13371
  const ids = useIdentifiers();
13224
13372
  const participantItemStrings = useLocale$1().strings.participantItem;
@@ -13253,7 +13401,6 @@ const ParticipantList$k = (props) => {
13253
13401
  onFetchParticipantMenuItems,
13254
13402
  onRemoveParticipant,
13255
13403
  (_b = (_a = props.styles) === null || _a === void 0 ? void 0 : _a.participantItemStyles) === null || _b === void 0 ? void 0 : _b.participantSubMenuItemsStyles,
13256
- /* @conditional-compile-remove(raise-hand) */
13257
13404
  participantItemStrings.removeButtonLabel
13258
13405
  ]);
13259
13406
  const participantItemStyles = React.useMemo(() => { var _a; return react.merge(participantListItemStyle, (_a = props.styles) === null || _a === void 0 ? void 0 : _a.participantItemStyles); }, [(_c = props.styles) === null || _c === void 0 ? void 0 : _c.participantItemStyles]);
@@ -13262,9 +13409,7 @@ const ParticipantList$k = (props) => {
13262
13409
  return (React.createElement(react.Stack, { "data-ui-id": ids.participantList, className: react.mergeStyles(participantListStyle$1, (_e = props.styles) === null || _e === void 0 ? void 0 : _e.root), role: 'menu' },
13263
13410
  displayedParticipants.map((participant) => onRenderParticipant
13264
13411
  ? onRenderParticipant(participant)
13265
- : onRenderParticipantDefault(participant, participantItemStrings, myUserId, onRenderAvatar, createParticipantMenuItems, participantItemStyles, props.onParticipantClick, showParticipantOverflowTooltip, participantAriaLabelledBy,
13266
- /* @conditional-compile-remove(raise-hand) */
13267
- theme)),
13412
+ : onRenderParticipantDefault(participant, participantItemStrings, myUserId, onRenderAvatar, createParticipantMenuItems, participantItemStyles, props.onParticipantClick, showParticipantOverflowTooltip, participantAriaLabelledBy, theme)),
13268
13413
  /* @conditional-compile-remove(total-participant-count) */ overflowParticipantCountString &&
13269
13414
  totalParticipantCount &&
13270
13415
  totalParticipantCount > displayedParticipants.length && (React.createElement(react.Text, { style: { fontWeight: 400, margin: '0.5rem' } }, _formatString(overflowParticipantCountString, {
@@ -13299,7 +13444,7 @@ const DrawerMenuItem = (props) => {
13299
13444
  const onKeyPress = (ev) => onClick && submitWithKeyboard(ev, onClick);
13300
13445
  const secondaryIcon = props.secondaryIconProps ? (React.createElement(MenuItemIcon, Object.assign({}, props.secondaryIconProps))) : props.subMenuProps ? (React.createElement(MenuItemIcon, { iconName: "ChevronRight" })) : undefined;
13301
13446
  return (React.createElement(react.FocusZone, { shouldFocusOnMount: props.shouldFocusOnMount },
13302
- React.createElement(react.Stack, { tabIndex: 0, role: "menuitem", horizontal: true, className: react.mergeStyles(drawerMenuItemRootStyles(theme.palette.neutralLight, theme.fonts.small), props.disabled ? disabledDrawerMenuItemRootStyles(theme.palette.neutralQuaternaryAlt) : undefined, (_a = props.styles) === null || _a === void 0 ? void 0 : _a.root), onKeyPress: props.disabled ? undefined : onKeyPress, onClick: props.disabled ? undefined : onClick, tokens: menuItemChildrenGap, id: props.id },
13447
+ React.createElement(react.Stack, { tabIndex: 0, role: "menuitem", horizontal: true, className: react.mergeStyles(drawerMenuItemRootStyles$1(theme.palette.neutralLight, theme.fonts.small), props.disabled ? disabledDrawerMenuItemRootStyles$1(theme.palette.neutralQuaternaryAlt) : undefined, (_a = props.styles) === null || _a === void 0 ? void 0 : _a.root), onKeyPress: props.disabled ? undefined : onKeyPress, onClick: props.disabled ? undefined : onClick, tokens: menuItemChildrenGap, id: props.id },
13303
13448
  props.iconProps && (React.createElement(react.Stack.Item, { role: "presentation", styles: props.disabled ? { root: { color: theme.palette.neutralTertiaryAlt } } : undefined },
13304
13449
  React.createElement(MenuItemIcon, Object.assign({}, props.iconProps)))),
13305
13450
  React.createElement(react.Stack.Item, { styles: drawerMenuItemTextStyles, grow: true },
@@ -13313,10 +13458,10 @@ const DrawerMenuItem = (props) => {
13313
13458
  };
13314
13459
  const MenuItemIcon = (props) => (React.createElement(react.FontIcon, Object.assign({ className: react.mergeStyles(iconStyles$1) }, props)));
13315
13460
  const menuItemChildrenGap = { childrenGap: '0.5rem' };
13316
- const drawerMenuItemRootStyles = (hoverBackground, fontSize) => (Object.assign(Object.assign({}, fontSize), { height: '3rem', lineHeight: '3rem', padding: '0rem 0.75rem', cursor: 'pointer', ':hover, :focus': {
13461
+ const drawerMenuItemRootStyles$1 = (hoverBackground, fontSize) => (Object.assign(Object.assign({}, fontSize), { height: '3rem', lineHeight: '3rem', padding: '0rem 0.75rem', cursor: 'pointer', ':hover, :focus': {
13317
13462
  background: hoverBackground
13318
13463
  } }));
13319
- const disabledDrawerMenuItemRootStyles = (background) => ({
13464
+ const disabledDrawerMenuItemRootStyles$1 = (background) => ({
13320
13465
  pointerEvents: 'none',
13321
13466
  background: background,
13322
13467
  ':hover, :focus': {
@@ -13442,6 +13587,9 @@ const drawerContentContainerStyles = {
13442
13587
 
13443
13588
  // Copyright (c) Microsoft Corporation.
13444
13589
  // Licensed under the MIT License.
13590
+ const isDrawerMenuItem = (item) => {
13591
+ return item.onRendererContent === undefined;
13592
+ };
13445
13593
  /**
13446
13594
  * Takes a set of menu items and returns a created menu inside a {@link _DrawerSurface}.
13447
13595
  *
@@ -13458,7 +13606,7 @@ const _DrawerMenu = (props) => {
13458
13606
  var _a;
13459
13607
  let items = props.items;
13460
13608
  for (const subMenuKey of selectedKeyPath) {
13461
- items = (_a = items === null || items === void 0 ? void 0 : items.find((item) => item.itemKey === subMenuKey)) === null || _a === void 0 ? void 0 : _a.subMenuProps;
13609
+ items = (_a = items === null || items === void 0 ? void 0 : items.find((item) => isDrawerMenuItem(item) && item.itemKey === subMenuKey)) === null || _a === void 0 ? void 0 : _a.subMenuProps;
13462
13610
  }
13463
13611
  return items;
13464
13612
  }, [props.items, selectedKeyPath]);
@@ -13473,7 +13621,7 @@ const _DrawerMenu = (props) => {
13473
13621
  }, [selectedKeyPath]);
13474
13622
  // Ensure the first item has a border radius that matches the DrawerSurface
13475
13623
  const borderRadius = useTheme().effects.roundedCorner4;
13476
- const firstItemStyle = menuItemsToRender && ((_a = menuItemsToRender[0]) === null || _a === void 0 ? void 0 : _a.styles);
13624
+ const firstItemStyle = (menuItemsToRender === null || menuItemsToRender === void 0 ? void 0 : menuItemsToRender[0]) && ((_a = menuItemsToRender[0]) === null || _a === void 0 ? void 0 : _a.styles);
13477
13625
  const modifiedFirstItemStyle = React.useMemo(() => react.merge(firstItemStyle !== null && firstItemStyle !== void 0 ? firstItemStyle : {}, {
13478
13626
  root: {
13479
13627
  borderTopRightRadius: borderRadius,
@@ -13482,14 +13630,192 @@ const _DrawerMenu = (props) => {
13482
13630
  }), [firstItemStyle, borderRadius]);
13483
13631
  return (React.createElement(_DrawerSurface, { disableMaxHeight: props.disableMaxHeight, styles: (_b = props.styles) === null || _b === void 0 ? void 0 : _b.drawerSurfaceStyles, onLightDismiss: props.onLightDismiss, heading: props.heading },
13484
13632
  React.createElement(react.Stack, { styles: props.styles, role: "menu", "data-ui-id": "drawer-menu" }, menuItemsToRender === null || menuItemsToRender === void 0 ? void 0 :
13485
- menuItemsToRender.slice(0, 1).map((item) => (React.createElement(DrawerMenuItem, Object.assign({}, item, { key: `${item.itemKey}` + '0', shouldFocusOnMount: true, styles: modifiedFirstItemStyle, onItemClick: (ev, itemKey) => {
13486
- onItemClick(item, ev, itemKey);
13487
- } })))), menuItemsToRender === null || menuItemsToRender === void 0 ? void 0 :
13488
- menuItemsToRender.slice(1).map((item, i) => (React.createElement(DrawerMenuItem, Object.assign({}, item, { key: `${item.itemKey}` + `${i + 1}`, onItemClick: (ev, itemKey) => {
13489
- onItemClick(item, ev, itemKey);
13490
- } })))))));
13633
+ menuItemsToRender.slice(0, 1).map((item) => {
13634
+ var _a;
13635
+ return isDrawerMenuItem(item) ? (React.createElement(DrawerMenuItem, Object.assign({}, item, { key: `${item.itemKey}` + '0', shouldFocusOnMount: item.itemKey === 'reactions' ? false : true, styles: modifiedFirstItemStyle, onItemClick: item.itemKey === 'reactions'
13636
+ ? undefined
13637
+ : (ev, itemKey) => {
13638
+ onItemClick(item, ev, itemKey);
13639
+ } }))) : ((_a = item.onRendererContent) === null || _a === void 0 ? void 0 : _a.call(item));
13640
+ }), menuItemsToRender === null || menuItemsToRender === void 0 ? void 0 :
13641
+ menuItemsToRender.slice(1).map((item, i) => {
13642
+ var _a;
13643
+ return isDrawerMenuItem(item) ? (React.createElement(DrawerMenuItem, Object.assign({}, item, { key: `${item.itemKey}` + `${i + 1}`, onItemClick: (ev, itemKey) => {
13644
+ onItemClick(item, ev, itemKey);
13645
+ } }))) : ((_a = item.onRendererContent) === null || _a === void 0 ? void 0 : _a.call(item));
13646
+ }))));
13647
+ };
13648
+
13649
+ // Copyright (c) Microsoft Corporation.
13650
+ // Licensed under the MIT License.
13651
+ /* @conditional-compile-remove(reaction) */
13652
+ /* @conditional-compile-remove(reaction) */
13653
+ /**
13654
+ * @private
13655
+ */
13656
+ const playFrames$1 = react.memoizeFunction(() => react.keyframes({
13657
+ from: {
13658
+ backgroundPosition: '0px 8568px'
13659
+ },
13660
+ to: {
13661
+ backgroundPosition: '0px 0px'
13662
+ }
13663
+ }));
13664
+ /* @conditional-compile-remove(reaction) */
13665
+ /**
13666
+ * @param backgroundImage - the uri for the reaction emoji resource
13667
+ * @param animationPlayState - the value is either 'running' or 'paused' based on the mouse hover event
13668
+ *
13669
+ * @private
13670
+ */
13671
+ const emojiStyles = (backgroundImage, animationPlayState) => {
13672
+ const imageResourceUrl = `url(${backgroundImage})`;
13673
+ return {
13674
+ display: 'flex',
13675
+ flexDirection: 'column',
13676
+ height: '100%',
13677
+ width: '100%',
13678
+ backgroundImage: imageResourceUrl,
13679
+ animationName: playFrames$1(),
13680
+ animationDuration: '8.12s',
13681
+ animationTimingFunction: `steps(102)`,
13682
+ animationPlayState: animationPlayState,
13683
+ animationIterationCount: 'infinite',
13684
+ justifyContent: 'center',
13685
+ alignItems: 'center',
13686
+ backgroundPosition: 'center',
13687
+ backgroundSize: `2.75rem 133.875rem`,
13688
+ transition: 'opacity 2s',
13689
+ backgroundColor: 'transparent',
13690
+ transform: `${animationPlayState === 'running' ? 'scale(0.8)' : 'scale(0.6)'}`
13691
+ };
13692
+ };
13693
+ /* @conditional-compile-remove(reaction) */
13694
+ /**
13695
+ *
13696
+ * @private
13697
+ */
13698
+ const reactionEmojiMenuStyles = () => {
13699
+ return {
13700
+ display: 'flex',
13701
+ justifyContent: 'center',
13702
+ alignItems: 'center',
13703
+ flexDirection: 'row',
13704
+ width: '13.75rem',
13705
+ height: '2.625rem'
13706
+ };
13707
+ };
13708
+ /* @conditional-compile-remove(reaction) */
13709
+ /**
13710
+ *
13711
+ * @private
13712
+ */
13713
+ const reactionToolTipHostStyle = () => {
13714
+ return {
13715
+ root: {
13716
+ display: 'flex',
13717
+ flexDirection: 'column',
13718
+ height: '100%',
13719
+ width: '100%'
13720
+ }
13721
+ };
13722
+ };
13723
+ /* @conditional-compile-remove(reaction) */
13724
+ /**
13725
+ *
13726
+ * @private
13727
+ */
13728
+ const mobileViewMenuItemStyle = () => {
13729
+ return {
13730
+ display: 'flex',
13731
+ justifyContent: 'space-between',
13732
+ alignItems: 'center',
13733
+ flexDirection: 'row',
13734
+ width: '100%',
13735
+ height: '2.625rem'
13736
+ };
13737
+ };
13738
+ /* @conditional-compile-remove(reaction) */
13739
+ /**
13740
+ * @param backgroundImage - the uri for the reaction emoji resource
13741
+ * @param animationPlayState - the value is either 'running' or 'paused' based on the mouse hover event
13742
+ *
13743
+ * @private
13744
+ */
13745
+ const mobileViewEmojiStyles = (backgroundImage, animationPlayState) => {
13746
+ const imageResourceUrl = `url(${backgroundImage})`;
13747
+ return {
13748
+ display: 'flex',
13749
+ flexDirection: 'column',
13750
+ height: '100%',
13751
+ width: '2.75rem',
13752
+ backgroundImage: imageResourceUrl,
13753
+ animationName: playFrames$1(),
13754
+ animationDuration: '8.12s',
13755
+ animationTimingFunction: `steps(102)`,
13756
+ animationPlayState: animationPlayState,
13757
+ animationIterationCount: 'infinite',
13758
+ justifyContent: 'center',
13759
+ alignItems: 'center',
13760
+ backgroundPosition: 'center',
13761
+ backgroundSize: `2.75rem 133.875rem`,
13762
+ transition: 'opacity 2s',
13763
+ backgroundColor: 'transparent',
13764
+ transform: `${animationPlayState === 'running' ? 'scale(0.8)' : 'scale(0.6)'}`
13765
+ };
13491
13766
  };
13492
13767
 
13768
+ // Copyright (c) Microsoft Corporation.
13769
+ // Licensed under the MIT License.
13770
+ /* @conditional-compile-remove(reaction) */
13771
+ /* @conditional-compile-remove(reaction) */
13772
+ /**
13773
+ * Maps the individual item in menuProps.items passed in the {@link DrawerMenu} into a UI component.
13774
+ *
13775
+ * @internal
13776
+ */
13777
+ const _ReactionDrawerMenuItem = (props) => {
13778
+ var _a, _b, _c, _d, _e;
13779
+ const theme = useTheme();
13780
+ const resources = props.reactionResources;
13781
+ const emojiResource = new Map([
13782
+ ['like', (_a = resources === null || resources === void 0 ? void 0 : resources.likeReaction) === null || _a === void 0 ? void 0 : _a.url],
13783
+ ['heart', (_b = resources === null || resources === void 0 ? void 0 : resources.heartReaction) === null || _b === void 0 ? void 0 : _b.url],
13784
+ ['laugh', (_c = resources === null || resources === void 0 ? void 0 : resources.laughReaction) === null || _c === void 0 ? void 0 : _c.url],
13785
+ ['applause', (_d = resources === null || resources === void 0 ? void 0 : resources.applauseReaction) === null || _d === void 0 ? void 0 : _d.url],
13786
+ ['surprised', (_e = resources === null || resources === void 0 ? void 0 : resources.surprisedReaction) === null || _e === void 0 ? void 0 : _e.url]
13787
+ ]);
13788
+ const emojis = ['like', 'heart', 'laugh', 'applause', 'surprised'];
13789
+ const borderRadius = useTheme().effects.roundedCorner4;
13790
+ const modifiedFirstItemStyle = {
13791
+ root: {
13792
+ borderTopRightRadius: borderRadius,
13793
+ borderTopLeftRadius: borderRadius,
13794
+ marginTop: '12px'
13795
+ }
13796
+ };
13797
+ return (React.createElement(react.Stack, { id: "reaction", role: "menuitem", horizontal: true, className: react.mergeStyles(drawerMenuItemRootStyles(theme.palette.neutralLight, theme.fonts.small), props.disabled ? disabledDrawerMenuItemRootStyles(theme.palette.neutralQuaternaryAlt) : undefined, modifiedFirstItemStyle.root) },
13798
+ React.createElement("div", { style: mobileViewMenuItemStyle() }, emojis.map((emoji, index) => {
13799
+ const resourceUrl = emojiResource.get(emoji.toString());
13800
+ return (React.createElement(react.IconButton, { key: index, onClick: () => {
13801
+ var _a;
13802
+ (_a = props.onReactionClick) === null || _a === void 0 ? void 0 : _a.call(props, emoji);
13803
+ }, style: mobileViewEmojiStyles(resourceUrl ? resourceUrl : '', 'running') }));
13804
+ }))));
13805
+ };
13806
+ /* @conditional-compile-remove(reaction) */
13807
+ const drawerMenuItemRootStyles = (hoverBackground, fontSize) => (Object.assign(Object.assign({}, fontSize), { height: '3rem', lineHeight: '3rem', padding: '0rem 0.75rem', cursor: 'pointer', ':hover, :focus': {
13808
+ background: hoverBackground
13809
+ } }));
13810
+ /* @conditional-compile-remove(reaction) */
13811
+ const disabledDrawerMenuItemRootStyles = (background) => ({
13812
+ pointerEvents: 'none',
13813
+ background: background,
13814
+ ':hover, :focus': {
13815
+ background: background
13816
+ }
13817
+ });
13818
+
13493
13819
  // Copyright (c) Microsoft Corporation.
13494
13820
  // Licensed under the MIT License.
13495
13821
  /** @private */
@@ -13933,7 +14259,7 @@ const raiseHandLimitedSpaceStyles = {
13933
14259
  /**
13934
14260
  * @private
13935
14261
  */
13936
- const playFrames$1 = react.memoizeFunction(() => react.keyframes({
14262
+ const playFrames = react.memoizeFunction(() => react.keyframes({
13937
14263
  from: {
13938
14264
  backgroundPosition: '0px 8568px'
13939
14265
  },
@@ -13951,7 +14277,7 @@ const reactionRenderingStyle = (args) => {
13951
14277
  height: '100%',
13952
14278
  width: '100%',
13953
14279
  overflow: 'hidden',
13954
- animationName: playFrames$1(),
14280
+ animationName: playFrames(),
13955
14281
  backgroundImage: imageUrl,
13956
14282
  animationDuration: '5.12s',
13957
14283
  animationTimingFunction: `steps(102)`,
@@ -14333,9 +14659,7 @@ const VideoTileMoreOptionsButton = (props) => {
14333
14659
  const VideoTile = (props) => {
14334
14660
  const { children, displayName, initialsName, isMirrored, isMuted,
14335
14661
  /* @conditional-compile-remove(spotlight) */
14336
- isSpotlighted, isPinned, onRenderPlaceholder, renderElement, showLabel = true, showMuteIndicator = true, styles, userId, noVideoAvailableAriaLabel, isSpeaking,
14337
- /* @conditional-compile-remove(raise-hand) */
14338
- raisedHand,
14662
+ isSpotlighted, isPinned, onRenderPlaceholder, renderElement, showLabel = true, showMuteIndicator = true, styles, userId, noVideoAvailableAriaLabel, isSpeaking, raisedHand,
14339
14663
  /* @conditional-compile-remove(reaction) */
14340
14664
  reaction, personaMinSize = DEFAULT_PERSONA_MIN_SIZE_PX, personaMaxSize = DEFAULT_PERSONA_MAX_SIZE_PX, contextualMenu,
14341
14665
  /* @conditional-compile-remove(reaction) */
@@ -14399,9 +14723,7 @@ const VideoTile = (props) => {
14399
14723
  const participantStateString = participantStateStringTrampoline(props, locale);
14400
14724
  const canShowContextMenuButton = isHovered || isFocused;
14401
14725
  let raisedHandBackgroundColor = '';
14402
- /* @conditional-compile-remove(raise-hand) */
14403
14726
  const callingPalette = theme.callingPalette;
14404
- /* @conditional-compile-remove(raise-hand) */
14405
14727
  raisedHandBackgroundColor = callingPalette.raiseHandGold;
14406
14728
  /* @conditional-compile-remove(reaction) */
14407
14729
  const backgroundImageUrl = reaction !== undefined && reactionResources !== undefined
@@ -14436,7 +14758,7 @@ const VideoTile = (props) => {
14436
14758
  return (React.createElement(react.Stack, Object.assign({ "data-ui-id": ids.videoTile, className: react.mergeStyles(rootStyles, {
14437
14759
  background: theme.palette.neutralLighter,
14438
14760
  borderRadius: theme.effects.roundedCorner4
14439
- }, (isSpeaking || /* @conditional-compile-remove(raise-hand) */ raisedHand) && {
14761
+ }, (isSpeaking || raisedHand) && {
14440
14762
  '&::after': {
14441
14763
  content: `''`,
14442
14764
  position: 'absolute',
@@ -14477,7 +14799,7 @@ const VideoTile = (props) => {
14477
14799
  React.createElement(react.Icon, { iconName: "VideoTilePinned", className: react.mergeStyles(pinIconStyle) }))),
14478
14800
  React.createElement(VideoTileMoreOptionsButton, { contextualMenu: contextualMenu, canShowContextMenuButton: canShowContextMenuButton })))),
14479
14801
  children && (React.createElement(react.Stack, { className: react.mergeStyles(overlayContainerStyles, styles === null || styles === void 0 ? void 0 : styles.overlayContainer) }, children)),
14480
- /* @conditional-compile-remove(raise-hand) */ raisedHand && (React.createElement(react.Stack, { horizontal: true, tokens: { childrenGap: '0.2rem' }, className: raiseHandContainerStyles(theme, !canShowLabel) },
14802
+ raisedHand && (React.createElement(react.Stack, { horizontal: true, tokens: { childrenGap: '0.2rem' }, className: raiseHandContainerStyles(theme, !canShowLabel) },
14481
14803
  React.createElement(react.Stack.Item, null,
14482
14804
  React.createElement(react.Text, null, raisedHand.raisedHandOrderPosition)),
14483
14805
  React.createElement(react.Stack.Item, null,
@@ -14599,9 +14921,7 @@ const _RemoteVideoTile = React.memo((props) => {
14599
14921
  /* @conditional-compile-remove(hide-attendee-name) */
14600
14922
  displayName = formatDisplayName();
14601
14923
  return (React.createElement(react.Stack, { tabIndex: menuKind === 'drawer' ? 0 : undefined, onKeyDown: menuKind === 'drawer' ? onKeyDown : undefined, style: remoteVideoTileWrapperStyle },
14602
- React.createElement(VideoTile, Object.assign({ key: userId, userId: userId, initialsName: (_b = remoteParticipant.displayName) !== null && _b !== void 0 ? _b : '', renderElement: renderVideoStreamElement, displayName: displayName, onRenderPlaceholder: onRenderAvatar, isMuted: remoteParticipant.isMuted,
14603
- /* @conditional-compile-remove(raise-hand) */
14604
- raisedHand: remoteParticipant.raisedHand,
14924
+ React.createElement(VideoTile, Object.assign({ key: userId, userId: userId, initialsName: (_b = remoteParticipant.displayName) !== null && _b !== void 0 ? _b : '', renderElement: renderVideoStreamElement, displayName: displayName, onRenderPlaceholder: onRenderAvatar, isMuted: remoteParticipant.isMuted, raisedHand: remoteParticipant.raisedHand,
14605
14925
  /* @conditional-compile-remove(reaction) */
14606
14926
  reaction: remoteParticipant.reaction, isSpeaking: remoteParticipant.isSpeaking, showMuteIndicator: showMuteIndicator, personaMinSize: props.personaMinSize, showLabel: props.showLabel,
14607
14927
  /* @conditional-compile-remove(one-to-n-calling) */
@@ -14856,9 +15176,7 @@ const LocalVideoCameraCycleButton = (props) => {
14856
15176
  * @internal
14857
15177
  */
14858
15178
  const _LocalVideoTile = React.memo((props) => {
14859
- const { isAvailable, isMuted, onCreateLocalStreamView, onDisposeLocalStreamView, localVideoViewOptions, renderElement, userId, showLabel, displayName, initialsName, onRenderAvatar, showMuteIndicator, styles, showCameraSwitcherInLocalPreview, localVideoCameraCycleButtonProps, localVideoCameraSwitcherLabel, localVideoSelectedDescription,
14860
- /* @conditional-compile-remove(raise-hand) */
14861
- raisedHand,
15179
+ const { isAvailable, isMuted, onCreateLocalStreamView, onDisposeLocalStreamView, localVideoViewOptions, renderElement, userId, showLabel, displayName, initialsName, onRenderAvatar, showMuteIndicator, styles, showCameraSwitcherInLocalPreview, localVideoCameraCycleButtonProps, localVideoCameraSwitcherLabel, localVideoSelectedDescription, raisedHand,
14862
15180
  /* @conditional-compile-remove(reaction) */
14863
15181
  reaction,
14864
15182
  /* @conditional-compile-remove(spotlight) */
@@ -14963,9 +15281,7 @@ const _LocalVideoTile = React.memo((props) => {
14963
15281
  ]);
14964
15282
  return (React.createElement(react.Stack, { className: react.mergeStyles({ width: '100%', height: '100%' }),
14965
15283
  /* @conditional-compile-remove(spotlight) */ onKeyDown: menuKind === 'drawer' ? onKeyDown : undefined },
14966
- React.createElement(VideoTile, Object.assign({ key: userId !== null && userId !== void 0 ? userId : 'local-video-tile', userId: userId, renderElement: renderVideoStreamElement, showLabel: showLabel, displayName: displayName, initialsName: initialsName, styles: videoTileStyles, onRenderPlaceholder: onRenderAvatar, isMuted: isMuted, showMuteIndicator: showMuteIndicator, personaMinSize: props.personaMinSize,
14967
- /* @conditional-compile-remove(raise-hand) */
14968
- raisedHand: raisedHand,
15284
+ React.createElement(VideoTile, Object.assign({ key: userId !== null && userId !== void 0 ? userId : 'local-video-tile', userId: userId, renderElement: renderVideoStreamElement, showLabel: showLabel, displayName: displayName, initialsName: initialsName, styles: videoTileStyles, onRenderPlaceholder: onRenderAvatar, isMuted: isMuted, showMuteIndicator: showMuteIndicator, personaMinSize: props.personaMinSize, raisedHand: raisedHand,
14969
15285
  /* @conditional-compile-remove(reaction) */
14970
15286
  reaction: reaction,
14971
15287
  /* @conditional-compile-remove(spotlight) */
@@ -17157,9 +17473,7 @@ const VideoGallery = (props) => {
17157
17473
  return layout === 'default' ? strings.localVideoLabel : isNarrow ? '' : strings.localVideoLabel;
17158
17474
  };
17159
17475
  return (React.createElement(react.Stack, { styles: localVideoTileContainerStyles, key: "local-video-tile-key", tabIndex: 0, "aria-label": strings.localVideoMovementLabel, role: 'dialog' },
17160
- React.createElement(_LocalVideoTile, { userId: localParticipant.userId, onCreateLocalStreamView: onCreateLocalStreamView, onDisposeLocalStreamView: onDisposeLocalStreamView, isAvailable: (_a = localParticipant === null || localParticipant === void 0 ? void 0 : localParticipant.videoStream) === null || _a === void 0 ? void 0 : _a.isAvailable, isMuted: localParticipant.isMuted, renderElement: (_b = localParticipant === null || localParticipant === void 0 ? void 0 : localParticipant.videoStream) === null || _b === void 0 ? void 0 : _b.renderElement, displayName: showDisplayNameTrampoline(), initialsName: initialsName, localVideoViewOptions: localVideoViewOptions, onRenderAvatar: onRenderAvatar, showLabel: showLocalVideoTileLabel, showMuteIndicator: showMuteIndicator, showCameraSwitcherInLocalPreview: showCameraSwitcherInLocalPreview, localVideoCameraCycleButtonProps: localVideoCameraCycleButtonProps, localVideoCameraSwitcherLabel: strings.localVideoCameraSwitcherLabel, localVideoSelectedDescription: strings.localVideoSelectedDescription, styles: localVideoTileStyles,
17161
- /* @conditional-compile-remove(raise-hand) */
17162
- raisedHand: localParticipant.raisedHand,
17476
+ React.createElement(_LocalVideoTile, { userId: localParticipant.userId, onCreateLocalStreamView: onCreateLocalStreamView, onDisposeLocalStreamView: onDisposeLocalStreamView, isAvailable: (_a = localParticipant === null || localParticipant === void 0 ? void 0 : localParticipant.videoStream) === null || _a === void 0 ? void 0 : _a.isAvailable, isMuted: localParticipant.isMuted, renderElement: (_b = localParticipant === null || localParticipant === void 0 ? void 0 : localParticipant.videoStream) === null || _b === void 0 ? void 0 : _b.renderElement, displayName: showDisplayNameTrampoline(), initialsName: initialsName, localVideoViewOptions: localVideoViewOptions, onRenderAvatar: onRenderAvatar, showLabel: showLocalVideoTileLabel, showMuteIndicator: showMuteIndicator, showCameraSwitcherInLocalPreview: showCameraSwitcherInLocalPreview, localVideoCameraCycleButtonProps: localVideoCameraCycleButtonProps, localVideoCameraSwitcherLabel: strings.localVideoCameraSwitcherLabel, localVideoSelectedDescription: strings.localVideoSelectedDescription, styles: localVideoTileStyles, raisedHand: localParticipant.raisedHand,
17163
17477
  /* @conditional-compile-remove(reaction) */
17164
17478
  reaction: localParticipant.reaction,
17165
17479
  /* @conditional-compile-remove(spotlight) */
@@ -18514,8 +18828,6 @@ const screenshareButtonStyles = (theme) => ({
18514
18828
 
18515
18829
  // Copyright (c) Microsoft Corporation.
18516
18830
  // Licensed under the MIT License.
18517
- /* @conditional-compile-remove(raise-hand) */
18518
- /* @conditional-compile-remove(raise-hand) */
18519
18831
  /**
18520
18832
  * A button to start / stop screen sharing.
18521
18833
  *
@@ -18533,7 +18845,6 @@ const RaiseHandButton = (props) => {
18533
18845
  const onRenderLowerHandIcon = () => (React.createElement(_HighContrastAwareIcon, { disabled: props.disabled, iconName: "ControlButtonLowerHand" }));
18534
18846
  return (React.createElement(ControlBarButton, Object.assign({}, props, { className: react.mergeStyles(styles, props.styles), onClick: (_a = props.onToggleRaiseHand) !== null && _a !== void 0 ? _a : props.onClick, onRenderOnIcon: (_b = props.onRenderOnIcon) !== null && _b !== void 0 ? _b : onRenderLowerHandIcon, onRenderOffIcon: (_c = props.onRenderOffIcon) !== null && _c !== void 0 ? _c : onRenderRaiseHandIcon, strings: strings, labelKey: (_d = props.labelKey) !== null && _d !== void 0 ? _d : 'raiseHandButtonLabel', disabled: props.disabled })));
18535
18847
  };
18536
- /* @conditional-compile-remove(raise-hand) */
18537
18848
  const raiseHandButtonStyles = (theme) => ({
18538
18849
  rootChecked: {
18539
18850
  background: theme.palette.themePrimary,
@@ -18548,81 +18859,6 @@ const raiseHandButtonStyles = (theme) => ({
18548
18859
  labelChecked: { color: react.DefaultPalette.white }
18549
18860
  });
18550
18861
 
18551
- // Copyright (c) Microsoft Corporation.
18552
- // Licensed under the MIT License.
18553
- /* @conditional-compile-remove(reaction) */
18554
- /* @conditional-compile-remove(reaction) */
18555
- /**
18556
- * @private
18557
- */
18558
- const playFrames = react.memoizeFunction(() => react.keyframes({
18559
- from: {
18560
- backgroundPosition: '0px 8568px'
18561
- },
18562
- to: {
18563
- backgroundPosition: '0px 0px'
18564
- }
18565
- }));
18566
- /* @conditional-compile-remove(reaction) */
18567
- /**
18568
- * @param backgroundImage - the uri for the reaction emoji resource
18569
- * @param animationPlayState - the value is either 'running' or 'paused' based on the mouse hover event
18570
- *
18571
- * @private
18572
- */
18573
- const emojiStyles = (backgroundImage, animationPlayState) => {
18574
- const imageResourceUrl = `url(${backgroundImage})`;
18575
- return {
18576
- display: 'flex',
18577
- flexDirection: 'column',
18578
- height: '100%',
18579
- width: '100%',
18580
- backgroundImage: imageResourceUrl,
18581
- animationName: playFrames(),
18582
- animationDuration: '8.12s',
18583
- animationTimingFunction: `steps(102)`,
18584
- animationPlayState: animationPlayState,
18585
- animationIterationCount: 'infinite',
18586
- justifyContent: 'center',
18587
- alignItems: 'center',
18588
- backgroundPosition: 'center',
18589
- backgroundSize: `44px 2142px`,
18590
- transition: 'opacity 2s',
18591
- backgroundColor: 'transparent',
18592
- transform: `${animationPlayState === 'running' ? 'scale(0.8)' : 'scale(0.6)'}`
18593
- };
18594
- };
18595
- /* @conditional-compile-remove(reaction) */
18596
- /**
18597
- *
18598
- * @private
18599
- */
18600
- const reactionEmojiMenuStyles = () => {
18601
- return {
18602
- display: 'flex',
18603
- justifyContent: 'center',
18604
- alignItems: 'center',
18605
- flexDirection: 'row',
18606
- width: '220px',
18607
- height: '42px'
18608
- };
18609
- };
18610
- /* @conditional-compile-remove(reaction) */
18611
- /**
18612
- *
18613
- * @private
18614
- */
18615
- const reactionToolTipHostStyle = () => {
18616
- return {
18617
- root: {
18618
- display: 'flex',
18619
- flexDirection: 'column',
18620
- height: '100%',
18621
- width: '100%'
18622
- }
18623
- };
18624
- };
18625
-
18626
18862
  // Copyright (c) Microsoft Corporation.
18627
18863
  // Licensed under the MIT License.
18628
18864
  /* @conditional-compile-remove(reaction) */
@@ -20488,7 +20724,9 @@ const _CaptionsSettingsModal = (props) => {
20488
20724
  const captionLanguageCode = selectedCaptionLanguage.key;
20489
20725
  if (isCaptionsFeatureActive) {
20490
20726
  onSetSpokenLanguage(spokenLanguageCode);
20491
- onSetCaptionLanguage(captionLanguageCode);
20727
+ if (changeCaptionLanguage) {
20728
+ onSetCaptionLanguage(captionLanguageCode);
20729
+ }
20492
20730
  }
20493
20731
  else {
20494
20732
  yield onStartCaptions({ spokenLanguage: spokenLanguageCode });
@@ -20501,7 +20739,8 @@ const _CaptionsSettingsModal = (props) => {
20501
20739
  onSetCaptionLanguage,
20502
20740
  onStartCaptions,
20503
20741
  selectedSpokenLanguage.key,
20504
- selectedCaptionLanguage.key
20742
+ selectedCaptionLanguage.key,
20743
+ changeCaptionLanguage
20505
20744
  ]);
20506
20745
  const spokenLanguageDropdownOptions = React.useMemo(() => {
20507
20746
  return supportedSpokenLanguages.map((languageCode) => {
@@ -20902,9 +21141,7 @@ const _videoGalleryRemoteParticipantsMemo = (remoteParticipants, isHideAttendeeN
20902
21141
  displayName = maskDisplayNameWithRole(displayName, localUserRole, participant.role, isHideAttendeeNamesEnabled);
20903
21142
  /* @conditional-compile-remove(reaction) */
20904
21143
  const remoteParticipantReaction = memoizedConvertToVideoTileReaction(participant.reactionState);
20905
- return memoizedFn(toFlatCommunicationIdentifier(participant.identifier), participant.isMuted, checkIsSpeaking(participant), participant.videoStreams, state, displayName,
20906
- /* @conditional-compile-remove(raise-hand) */
20907
- participant.raisedHand,
21144
+ return memoizedFn(toFlatCommunicationIdentifier(participant.identifier), participant.isMuted, checkIsSpeaking(participant), participant.videoStreams, state, displayName, participant.raisedHand,
20908
21145
  /* @conditional-compile-remove(reaction) */
20909
21146
  remoteParticipantReaction,
20910
21147
  /* @conditional-compile-remove(spotlight) */
@@ -20914,18 +21151,14 @@ const _videoGalleryRemoteParticipantsMemo = (remoteParticipants, isHideAttendeeN
20914
21151
  }));
20915
21152
  });
20916
21153
  };
20917
- const memoizedAllConvertRemoteParticipant = memoizeFnAll((userId, isMuted, isSpeaking, videoStreams, state, displayName,
20918
- /* @conditional-compile-remove(raise-hand) */
20919
- raisedHand, // temp unknown type to build stable
21154
+ const memoizedAllConvertRemoteParticipant = memoizeFnAll((userId, isMuted, isSpeaking, videoStreams, state, displayName, raisedHand, // temp unknown type to build stable
20920
21155
  /* @conditional-compile-remove(reaction) */
20921
21156
  reaction, // temp unknown type to build stable
20922
21157
  /* @conditional-compile-remove(spotlight) */
20923
21158
  spotlight, // temp unknown type to build stable
20924
21159
  /* @conditional-compile-remove(ppt-live) */
20925
21160
  contentSharingStream) => {
20926
- return convertRemoteParticipantToVideoGalleryRemoteParticipant(userId, isMuted, isSpeaking, videoStreams, state, displayName,
20927
- /* @conditional-compile-remove(raise-hand) */
20928
- raisedHand,
21161
+ return convertRemoteParticipantToVideoGalleryRemoteParticipant(userId, isMuted, isSpeaking, videoStreams, state, displayName, raisedHand,
20929
21162
  /* @conditional-compile-remove(reaction) */
20930
21163
  reaction,
20931
21164
  /* @conditional-compile-remove(spotlight) */
@@ -20934,9 +21167,7 @@ contentSharingStream) => {
20934
21167
  contentSharingStream);
20935
21168
  });
20936
21169
  /** @private */
20937
- const convertRemoteParticipantToVideoGalleryRemoteParticipant = (userId, isMuted, isSpeaking, videoStreams, state, displayName,
20938
- /* @conditional-compile-remove(raise-hand) */
20939
- raisedHand, // temp unknown type to build stable
21170
+ const convertRemoteParticipantToVideoGalleryRemoteParticipant = (userId, isMuted, isSpeaking, videoStreams, state, displayName, raisedHand, // temp unknown type to build stable
20940
21171
  /* @conditional-compile-remove(reaction) */
20941
21172
  reaction, // temp unknown type to build stable
20942
21173
  /* @conditional-compile-remove(spotlight) */
@@ -20971,7 +21202,6 @@ contentSharingStream) => {
20971
21202
  /* @conditional-compile-remove(one-to-n-calling) */
20972
21203
  /* @conditional-compile-remove(PSTN-calls) */
20973
21204
  state,
20974
- /* @conditional-compile-remove(raise-hand) */
20975
21205
  raisedHand: raisedHand,
20976
21206
  /* @conditional-compile-remove(reaction) */
20977
21207
  reaction: reaction,
@@ -21003,8 +21233,7 @@ const convertRemoteContentSharingStreamToVideoGalleryStream = (stream) => {
21003
21233
  };
21004
21234
  /** @private */
21005
21235
  const memoizeLocalParticipant = memoizeOne((identifier, displayName, isMuted, isScreenSharingOn, localVideoStream,
21006
- /* @conditional-compile-remove(rooms) */ role,
21007
- /* @conditional-compile-remove(raise-hand) */ raisedHand,
21236
+ /* @conditional-compile-remove(rooms) */ role, raisedHand,
21008
21237
  /* @conditional-compile-remove(reaction) */ reaction,
21009
21238
  /* @conditional-compile-remove(spotlight) */ localSpotlight,
21010
21239
  /* @conditional-compile-remove(spotlight) */ capabilities) => {
@@ -21021,7 +21250,6 @@ const memoizeLocalParticipant = memoizeOne((identifier, displayName, isMuted, is
21021
21250
  },
21022
21251
  /* @conditional-compile-remove(rooms) */
21023
21252
  role,
21024
- /* @conditional-compile-remove(raise-hand) */
21025
21253
  raisedHand: raisedHand,
21026
21254
  /* @conditional-compile-remove(reaction) */
21027
21255
  reaction: reaction,
@@ -21068,11 +21296,9 @@ const videoGallerySelector = reselect.createSelector([
21068
21296
  getDisplayName$2,
21069
21297
  getIdentifier,
21070
21298
  getDominantSpeakers,
21071
- /* @conditional-compile-remove(optimal-video-count) */
21072
21299
  getOptimalVideoCount,
21073
21300
  /* @conditional-compile-remove(rooms) */
21074
21301
  getRole$1,
21075
- /* @conditional-compile-remove(raise-hand) */
21076
21302
  getLocalParticipantRaisedHand$1,
21077
21303
  /* @conditional-compile-remove(hide-attendee-name) */
21078
21304
  isHideAttendeeNamesEnabled,
@@ -21082,13 +21308,9 @@ const videoGallerySelector = reselect.createSelector([
21082
21308
  getSpotlightCallFeature,
21083
21309
  /* @conditional-compile-remove(spotlight) */
21084
21310
  getCapabilities
21085
- ], (screenShareRemoteParticipantId, remoteParticipants, localVideoStreams, isMuted, isScreenSharingOn, displayName, identifier, dominantSpeakers,
21086
- /* @conditional-compile-remove(optimal-video-count) */
21087
- optimalVideoCount,
21311
+ ], (screenShareRemoteParticipantId, remoteParticipants, localVideoStreams, isMuted, isScreenSharingOn, displayName, identifier, dominantSpeakers, optimalVideoCount,
21088
21312
  /* @conditional-compile-remove(rooms) */
21089
- role,
21090
- /* @conditional-compile-remove(raise-hand) */
21091
- raisedHand,
21313
+ role, raisedHand,
21092
21314
  /* @conditional-compile-remove(hide-attendee-name) */
21093
21315
  isHideAttendeeNamesEnabled,
21094
21316
  /* @conditional-compile-remove(reaction) */
@@ -21110,17 +21332,13 @@ capabilities) => {
21110
21332
  const spotlightedParticipantIds = memoizeSpotlightedParticipantIds(spotlightCallFeature === null || spotlightCallFeature === void 0 ? void 0 : spotlightCallFeature.spotlightedParticipants);
21111
21333
  return {
21112
21334
  screenShareParticipant: screenShareRemoteParticipant
21113
- ? convertRemoteParticipantToVideoGalleryRemoteParticipant(toFlatCommunicationIdentifier(screenShareRemoteParticipant.identifier), screenShareRemoteParticipant.isMuted, checkIsSpeaking(screenShareRemoteParticipant), screenShareRemoteParticipant.videoStreams, screenShareRemoteParticipant.state, screenShareRemoteParticipant.displayName,
21114
- /* @conditional-compile-remove(raise-hand) */
21115
- screenShareRemoteParticipant.raisedHand,
21335
+ ? convertRemoteParticipantToVideoGalleryRemoteParticipant(toFlatCommunicationIdentifier(screenShareRemoteParticipant.identifier), screenShareRemoteParticipant.isMuted, checkIsSpeaking(screenShareRemoteParticipant), screenShareRemoteParticipant.videoStreams, screenShareRemoteParticipant.state, screenShareRemoteParticipant.displayName, screenShareRemoteParticipant.raisedHand,
21116
21336
  /* @conditional-compile-remove(spotlight) */
21117
21337
  screenShareRemoteParticipant.spotlight)
21118
21338
  : undefined,
21119
21339
  localParticipant: memoizeLocalParticipant(identifier, displayName, isMuted, isScreenSharingOn, localVideoStream,
21120
21340
  /* @conditional-compile-remove(rooms) */
21121
- role,
21122
- /* @conditional-compile-remove(raise-hand) */
21123
- raisedHand,
21341
+ role, raisedHand,
21124
21342
  /* @conditional-compile-remove(reaction) */
21125
21343
  localParticipantReactionState,
21126
21344
  /* @conditional-compile-remove(spotlight) */
@@ -21133,7 +21351,6 @@ capabilities) => {
21133
21351
  /* @conditional-compile-remove(hide-attendee-name) */
21134
21352
  role),
21135
21353
  dominantSpeakers: dominantSpeakerIds,
21136
- /* @conditional-compile-remove(optimal-video-count) */
21137
21354
  maxRemoteVideoStreams: optimalVideoCount,
21138
21355
  /* @conditional-compile-remove(spotlight) */
21139
21356
  spotlightedParticipants: spotlightedParticipantIds,
@@ -21177,9 +21394,7 @@ const convertRemoteParticipantsToParticipantListParticipants = (remoteParticipan
21177
21394
  const remoteParticipantReaction = memoizedConvertToVideoTileReaction(participant.reactionState);
21178
21395
  /* @conditional-compile-remove(spotlight) */
21179
21396
  const spotlight = memoizedSpotlight(spotlightedParticipants, toFlatCommunicationIdentifier(participant.identifier));
21180
- return memoizeFn(toFlatCommunicationIdentifier(participant.identifier), displayName, state, participant.isMuted, isScreenSharing, participant.isSpeaking,
21181
- /* @conditional-compile-remove(raise-hand) */
21182
- participant.raisedHand, localUserCanRemoveOthers,
21397
+ return memoizeFn(toFlatCommunicationIdentifier(participant.identifier), displayName, state, participant.isMuted, isScreenSharing, participant.isSpeaking, participant.raisedHand, localUserCanRemoveOthers,
21183
21398
  /* @conditional-compile-remove(reaction) */
21184
21399
  remoteParticipantReaction,
21185
21400
  /* @conditional-compile-remove(spotlight) */
@@ -21214,7 +21429,7 @@ const participantListSelector = reselect.createSelector([
21214
21429
  getRemoteParticipantsExcludingConsumers,
21215
21430
  getIsScreenSharingOn,
21216
21431
  getIsMuted,
21217
- /* @conditional-compile-remove(raise-hand) */ getLocalParticipantRaisedHand$1,
21432
+ getLocalParticipantRaisedHand$1,
21218
21433
  getRole$1,
21219
21434
  getParticipantCount,
21220
21435
  /* @conditional-compile-remove(hide-attendee-name) */
@@ -21223,9 +21438,7 @@ const participantListSelector = reselect.createSelector([
21223
21438
  getLocalParticipantReactionState,
21224
21439
  /* @conditional-compile-remove(spotlight) */
21225
21440
  getSpotlightCallFeature
21226
- ], (userId, displayName, remoteParticipants, isScreenSharingOn, isMuted,
21227
- /* @conditional-compile-remove(raise-hand) */
21228
- raisedHand, role, partitipantCount,
21441
+ ], (userId, displayName, remoteParticipants, isScreenSharingOn, isMuted, raisedHand, role, partitipantCount,
21229
21442
  /* @conditional-compile-remove(hide-attendee-name) */
21230
21443
  isHideAttendeeNamesEnabled,
21231
21444
  /* @conditional-compile-remove(reaction) */
@@ -21249,7 +21462,6 @@ spotlightCallFeature) => {
21249
21462
  displayName: displayName,
21250
21463
  isScreenSharing: isScreenSharingOn,
21251
21464
  isMuted: isMuted,
21252
- /* @conditional-compile-remove(raise-hand) */
21253
21465
  raisedHand: raisedHand,
21254
21466
  state: 'Connected',
21255
21467
  // Local participant can never remove themselves.
@@ -21564,10 +21776,6 @@ const getSelector$1 = (component) => {
21564
21776
  if (component === HoldButton) {
21565
21777
  return findConditionalCompiledSelector(component);
21566
21778
  }
21567
- /* @conditional-compile-remove(raise-hand) */
21568
- if (component === RaiseHandButton) {
21569
- return findConditionalCompiledSelector(component);
21570
- }
21571
21779
  /* @conditional-compile-remove(reaction) */
21572
21780
  if (component === ReactionButton) {
21573
21781
  return findConditionalCompiledSelector(component);
@@ -21599,20 +21807,18 @@ const findSelector$1 = (component) => {
21599
21807
  return emptySelector;
21600
21808
  case ErrorBar:
21601
21809
  return errorBarSelector$1;
21810
+ case RaiseHandButton:
21811
+ return raiseHandButtonSelector;
21602
21812
  }
21603
21813
  return undefined;
21604
21814
  };
21605
- /* @conditional-compile-remove(PSTN-calls) */ /* @conditional-compile-remove(raise-hand) */
21815
+ /* @conditional-compile-remove(PSTN-calls) */
21606
21816
  const findConditionalCompiledSelector = (component) => {
21607
21817
  switch (component) {
21608
21818
  /* @conditional-compile-remove(PSTN-calls) */
21609
21819
  case HoldButton:
21610
21820
  /* @conditional-compile-remove(PSTN-calls) */
21611
21821
  return holdButtonSelector;
21612
- /* @conditional-compile-remove(raise-hand) */
21613
- case RaiseHandButton:
21614
- /* @conditional-compile-remove(raise-hand) */
21615
- return raiseHandButtonSelector;
21616
21822
  /* @conditional-compile-remove(reaction) */
21617
21823
  case ReactionButton:
21618
21824
  /* @conditional-compile-remove(reaction) */
@@ -22140,7 +22346,7 @@ const generateImageAttachmentImgHtml = (message, attachment) => {
22140
22346
  const getResourceSourceUrl = (result) => {
22141
22347
  let src = '';
22142
22348
  if (result) {
22143
- if (result.error) {
22349
+ if (result.error || !result.sourceUrl) {
22144
22350
  // In case of an error we set src to some invalid value to show broken image
22145
22351
  src = 'blob://';
22146
22352
  }
@@ -22836,7 +23042,9 @@ let ChatContext$1 = class ChatContext {
22836
23042
  if (cache) {
22837
23043
  Object.keys(cache).forEach((resourceUrl) => {
22838
23044
  const resource = cache[resourceUrl];
22839
- URL.revokeObjectURL(resource.sourceUrl);
23045
+ if (resource.sourceUrl) {
23046
+ URL.revokeObjectURL(resource.sourceUrl);
23047
+ }
22840
23048
  });
22841
23049
  }
22842
23050
  thread.chatMessages[messageId].resourceCache = undefined;
@@ -22877,7 +23085,9 @@ let ChatContext$1 = class ChatContext {
22877
23085
  }
22878
23086
  if (message && message.resourceCache && message.resourceCache[resourceUrl]) {
22879
23087
  const resource = message.resourceCache[resourceUrl];
22880
- URL.revokeObjectURL(resource.sourceUrl);
23088
+ if (resource.sourceUrl) {
23089
+ URL.revokeObjectURL(resource.sourceUrl);
23090
+ }
22881
23091
  delete message.resourceCache[resourceUrl];
22882
23092
  }
22883
23093
  });
@@ -23976,7 +24186,6 @@ const COMPOSITE_ONLY_ICONS = {
23976
24186
  FloatingLocalVideoGalleryLayout: React.createElement(reactIcons.BoardSplit20Regular, null),
23977
24187
  FocusedContentGalleryLayout: React.createElement(reactIcons.ContentView20Regular, null),
23978
24188
  LargeGalleryLayout: React.createElement(reactIcons.Table20Regular, null),
23979
- /* @conditional-compile-remove(control-bar-button-injection) */
23980
24189
  DefaultCustomButton: React.createElement(reactIcons.Circle20Regular, null),
23981
24190
  DtmfDialpadButton: React.createElement(reactIcons.Dialpad20Regular, null),
23982
24191
  /* @conditional-compile-remove(spotlight) */
@@ -25062,9 +25271,7 @@ const AvatarPersona = (props) => {
25062
25271
  }
25063
25272
  }))();
25064
25273
  }, [data, dataProvider, userId]);
25065
- /* @conditional-compile-remove(raise-hand) */
25066
25274
  let activePersona = '';
25067
- /* @conditional-compile-remove(raise-hand) */
25068
25275
  if (props.allowActiveBorder) {
25069
25276
  // Display a border for raised handed participants in participant list
25070
25277
  activePersona = react.mergeStyles({
@@ -25077,9 +25284,7 @@ const AvatarPersona = (props) => {
25077
25284
  });
25078
25285
  react.mergeStyles(activePersona, props.styles);
25079
25286
  }
25080
- return (React.createElement(react.Persona, Object.assign({}, props, {
25081
- /* @conditional-compile-remove(raise-hand) */
25082
- className: activePersona, text: (_a = data === null || data === void 0 ? void 0 : data.text) !== null && _a !== void 0 ? _a : text, imageUrl: (_b = data === null || data === void 0 ? void 0 : data.imageUrl) !== null && _b !== void 0 ? _b : imageUrl, imageInitials: (_c = data === null || data === void 0 ? void 0 : data.imageInitials) !== null && _c !== void 0 ? _c : imageInitials, initialsColor: (_d = data === null || data === void 0 ? void 0 : data.initialsColor) !== null && _d !== void 0 ? _d : initialsColor, initialsTextColor: (_f = (_e = data === null || data === void 0 ? void 0 : data.initialsTextColor) !== null && _e !== void 0 ? _e : initialsTextColor) !== null && _f !== void 0 ? _f : 'white',
25287
+ return (React.createElement(react.Persona, Object.assign({}, props, { className: activePersona, text: (_a = data === null || data === void 0 ? void 0 : data.text) !== null && _a !== void 0 ? _a : text, imageUrl: (_b = data === null || data === void 0 ? void 0 : data.imageUrl) !== null && _b !== void 0 ? _b : imageUrl, imageInitials: (_c = data === null || data === void 0 ? void 0 : data.imageInitials) !== null && _c !== void 0 ? _c : imageInitials, initialsColor: (_d = data === null || data === void 0 ? void 0 : data.initialsColor) !== null && _d !== void 0 ? _d : initialsColor, initialsTextColor: (_f = (_e = data === null || data === void 0 ? void 0 : data.initialsTextColor) !== null && _e !== void 0 ? _e : initialsTextColor) !== null && _f !== void 0 ? _f : 'white',
25083
25288
  // default disable tooltip unless specified
25084
25289
  showOverflowTooltip: showOverflowTooltip !== null && showOverflowTooltip !== void 0 ? showOverflowTooltip : false,
25085
25290
  /* @conditional-compile-remove(PSTN-calls) */ /* @conditional-compile-remove(one-to-n-calling) */
@@ -25393,9 +25598,7 @@ const ParticipantListWithHeading = (props) => {
25393
25598
  /* @conditional-compile-remove(total-participant-count) */ totalParticipantCount)),
25394
25599
  React.createElement(react.FocusZone, { className: participantListContainerStyle, shouldFocusOnMount: true },
25395
25600
  React.createElement(ParticipantList$k, Object.assign({}, participantListProps, { styles: props.isMobile ? participantListMobileStyle : participantListStyle, onRenderAvatar: (userId, options) => (React.createElement(React.Fragment, null,
25396
- React.createElement(AvatarPersona, Object.assign({ "data-ui-id": "chat-composite-participant-custom-avatar", userId: userId }, options, { hidePersonaDetails: !!(options === null || options === void 0 ? void 0 : options.text), dataProvider: onFetchAvatarPersonaData,
25397
- /* @conditional-compile-remove(raise-hand) */
25398
- allowActiveBorder: true })),
25601
+ React.createElement(AvatarPersona, Object.assign({ "data-ui-id": "chat-composite-participant-custom-avatar", userId: userId }, options, { hidePersonaDetails: !!(options === null || options === void 0 ? void 0 : options.text), dataProvider: onFetchAvatarPersonaData, allowActiveBorder: true })),
25399
25602
  (options === null || options === void 0 ? void 0 : options.text) && (React.createElement(react.Text, { nowrap: true, styles: displayNameStyles$1 }, options === null || options === void 0 ? void 0 : options.text)))), onFetchParticipantMenuItems: onFetchParticipantMenuItems, showParticipantOverflowTooltip: !props.isMobile, participantAriaLabelledBy: subheadingUniqueId })))));
25400
25603
  };
25401
25604
  const paneTitleTrampoline = (paneTitle, totalParticipantCount) => {
@@ -25473,7 +25676,7 @@ const useSelector$2 = (selector, selectorProps) => {
25473
25676
  // Copyright (c) Microsoft Corporation.
25474
25677
  // Licensed under the MIT License.
25475
25678
  /* @conditional-compile-remove(rich-text-editor) */
25476
- const RichTextSendBoxWrapper = React.lazy(() => Promise.resolve().then(function () { return require('./RichTextSendBoxWrapper-D1KqCTKr.js'); }).then((module) => ({ default: module.RichTextSendBoxWrapper })));
25679
+ const RichTextSendBoxWrapper = React.lazy(() => Promise.resolve().then(function () { return require('./RichTextSendBoxWrapper-BCdGFyar.js'); }).then((module) => ({ default: module.RichTextSendBoxWrapper })));
25477
25680
  /**
25478
25681
  * @private
25479
25682
  */
@@ -25567,7 +25770,7 @@ const ChatScreen = (props) => {
25567
25770
  }, [messageThreadProps.messages]);
25568
25771
  const getResourceSourceUrl = (result) => {
25569
25772
  let src = '';
25570
- if (result.error) {
25773
+ if (result.error || !result.sourceUrl) {
25571
25774
  src = 'blob://';
25572
25775
  }
25573
25776
  else {
@@ -26446,15 +26649,12 @@ const createCompositeHandlers = memoizeOne((adapter) => {
26446
26649
  yield adapter.removeParticipant(_toCommunicationIdentifier(userId));
26447
26650
  }
26448
26651
  }),
26449
- /* @conditional-compile-remove(raise-hand) */
26450
26652
  onRaiseHand: () => __awaiter$j(void 0, void 0, void 0, function* () {
26451
26653
  yield adapter.raiseHand();
26452
26654
  }),
26453
- /* @conditional-compile-remove(raise-hand) */
26454
26655
  onLowerHand: () => __awaiter$j(void 0, void 0, void 0, function* () {
26455
26656
  yield adapter.lowerHand();
26456
26657
  }),
26457
- /* @conditional-compile-remove(raise-hand) */
26458
26658
  onToggleRaiseHand: () => __awaiter$j(void 0, void 0, void 0, function* () {
26459
26659
  var _b;
26460
26660
  ((_b = adapter.getState().call) === null || _b === void 0 ? void 0 : _b.raiseHand.localParticipantRaisedHand)
@@ -26857,7 +27057,7 @@ const CaptionsBanner = (props) => {
26857
27057
  /* @conditional-compile-remove(close-captions) */
26858
27058
  const desktopViewBannerWidth = windowWidth > 620 ? '35rem' : '80%';
26859
27059
  return (React.createElement(React.Fragment, null,
26860
- /* @conditional-compile-remove(close-captions) */ isCaptionsSettingsOpen && (React.createElement(CaptionsSettingsModal, { showCaptionsSettingsModal: isCaptionsSettingsOpen, onDismissCaptionsSettings: onDismissCaptionsSettings, changeCaptionLanguage: true })),
27060
+ /* @conditional-compile-remove(close-captions) */ isCaptionsSettingsOpen && (React.createElement(CaptionsSettingsModal, { showCaptionsSettingsModal: isCaptionsSettingsOpen, onDismissCaptionsSettings: onDismissCaptionsSettings, changeCaptionLanguage: props.isTeamsCall })),
26861
27061
  /* @conditional-compile-remove(close-captions) */ React.createElement("div", { className: containerClassName },
26862
27062
  React.createElement(react.Stack, { horizontalAlign: "center" },
26863
27063
  React.createElement(react.Stack.Item, { style: { width: props.isMobile ? mobileViewBannerWidth : desktopViewBannerWidth } },
@@ -27014,7 +27214,6 @@ const getDeviceManager = (state) => state.devices;
27014
27214
  * @private
27015
27215
  */
27016
27216
  const getIsScreenShareOn = (state) => { var _a, _b; return (_b = (_a = state.call) === null || _a === void 0 ? void 0 : _a.isScreenSharingOn) !== null && _b !== void 0 ? _b : false; };
27017
- /* @conditional-compile-remove(raise-hand) */
27018
27217
  /**
27019
27218
  * @private
27020
27219
  */
@@ -27301,7 +27500,6 @@ const callArrangementContainerStyles = (verticalControlBar) => {
27301
27500
 
27302
27501
  // Copyright (c) Microsoft Corporation.
27303
27502
  // Licensed under the MIT License.
27304
- /* @conditional-compile-remove(raise-hand) */
27305
27503
  /** @private */
27306
27504
  const RaiseHand = (props) => {
27307
27505
  const raiseHandButtonProps = usePropsFor$1(RaiseHandButton);
@@ -27313,7 +27511,6 @@ const RaiseHand = (props) => {
27313
27511
  }
27314
27512
  return (React.createElement(RaiseHandButton, Object.assign({ "data-ui-id": "call-composite-raisehand-button" }, raiseHandButtonProps, { showLabel: props.displayType !== 'compact', disabled: raiseHandButtonDisabled || props.disabled, styles: styles })));
27315
27513
  };
27316
- /* @conditional-compile-remove(raise-hand) */
27317
27514
  const isDisabled$1 = (option) => {
27318
27515
  if (option === undefined || option === true || option === false) {
27319
27516
  return false;
@@ -27461,7 +27658,6 @@ const CallControls = (props) => {
27461
27658
  const options = React.useMemo(() => inferCallControlOptions(!!props.isMobile, props.options), [props.isMobile, props.options]);
27462
27659
  /* @conditional-compile-remove(PSTN-calls) */ /* @conditional-compile-remove(rooms) */
27463
27660
  const adapter = useAdapter();
27464
- /* @conditional-compile-remove(PSTN-calls) */ /* @conditional-compile-remove(one-to-n-calling) */ /* @conditional-compile-remove(close-captions) */ /* @conditional-compile-remove(raise-hand) */
27465
27661
  const localeStrings = useLocale();
27466
27662
  /* @conditional-compile-remove(one-to-n-calling) @conditional-compile-remove(PSTN-calls) */
27467
27663
  const peopleButtonStrings = React.useMemo(() => ({
@@ -27469,14 +27665,12 @@ const CallControls = (props) => {
27469
27665
  tooltipOffContent: localeStrings.strings.call.peopleButtonTooltipOpen,
27470
27666
  tooltipOnContent: localeStrings.strings.call.peopleButtonTooltipClose
27471
27667
  }), [localeStrings]);
27472
- /* @conditional-compile-remove(PSTN-calls) */ /* @conditional-compile-remove(one-to-n-calling) */ /* @conditional-compile-remove(close-captions) */ /* @conditional-compile-remove(raise-hand) */
27473
27668
  const moreButtonStrings = React.useMemo(() => ({
27474
27669
  label: localeStrings.strings.call.moreButtonCallingLabel,
27475
27670
  tooltipOffContent: localeStrings.strings.callWithChat.moreDrawerButtonTooltip
27476
27671
  }), [localeStrings]);
27477
27672
  /* @conditional-compile-remove(PSTN-calls) */ /* @conditional-compile-remove(one-to-n-calling) */
27478
27673
  const holdButtonProps = usePropsFor$1(HoldButton);
27479
- /* @conditional-compile-remove(raise-hand) */
27480
27674
  const raiseHandButtonProps = usePropsFor$1(RaiseHandButton);
27481
27675
  /* @conditional-compile-remove(reaction) */
27482
27676
  const capabilitiesSelector = useSelector$1(capabilitySelector);
@@ -27566,15 +27760,12 @@ const CallControls = (props) => {
27566
27760
  }
27567
27761
  /* @conditional-compile-remove(reaction) */
27568
27762
  const reactionResources = adapter.getState().reactions;
27569
- /* @conditional-compile-remove(raise-hand) */
27570
27763
  const raiseHandButtonIsEnabled = isEnabled$2(options === null || options === void 0 ? void 0 : options.raiseHandButton);
27571
- /* @conditional-compile-remove(raise-hand) */
27572
27764
  let showRaiseHandButtonInControlBar = raiseHandButtonIsEnabled;
27573
27765
  /* @conditional-compile-remove(rooms) */
27574
27766
  const role = (_a = adapter.getState().call) === null || _a === void 0 ? void 0 : _a.role;
27575
27767
  /* @conditional-compile-remove(rooms) */
27576
27768
  const hideRaiseHandButtonInRoomsCall = adapter.getState().isRoomsCall && role && ['Consumer', 'Unknown'].includes(role);
27577
- /* @conditional-compile-remove(raise-hand) */
27578
27769
  if (showRaiseHandButtonInControlBar && (props.isMobile ? numberOfButtons < 5 : true)) {
27579
27770
  numberOfButtons++;
27580
27771
  }
@@ -27596,7 +27787,6 @@ const CallControls = (props) => {
27596
27787
  ['data-ui-id']: 'call-composite-more-menu-devices-button'
27597
27788
  });
27598
27789
  }
27599
- /* @conditional-compile-remove(raise-hand) */
27600
27790
  if (!showRaiseHandButtonInControlBar && /* @conditional-compile-remove(rooms) */ !hideRaiseHandButtonInRoomsCall) {
27601
27791
  moreButtonMenuItems.push({
27602
27792
  key: 'raiseHandButtonKey',
@@ -27654,7 +27844,7 @@ const CallControls = (props) => {
27654
27844
  cameraButtonIsEnabled && (React.createElement(Camera, { displayType: options === null || options === void 0 ? void 0 : options.displayType, disabled: isDisabled$4(options === null || options === void 0 ? void 0 : options.cameraButton) })),
27655
27845
  /* @conditional-compile-remove(reaction) */
27656
27846
  showReactionButtonInControlBar && reactionResources && (React.createElement(Reaction, { displayType: options === null || options === void 0 ? void 0 : options.displayType, reactionResource: reactionResources })),
27657
- /* @conditional-compile-remove(raise-hand) */ showRaiseHandButtonInControlBar &&
27847
+ showRaiseHandButtonInControlBar &&
27658
27848
  /* @conditional-compile-remove(rooms) */ !hideRaiseHandButtonInRoomsCall && (React.createElement(RaiseHand, { displayType: options === null || options === void 0 ? void 0 : options.displayType })),
27659
27849
  screenShareButtonIsEnabled && (React.createElement(ScreenShare, { option: options === null || options === void 0 ? void 0 : options.screenShareButton, displayType: options === null || options === void 0 ? void 0 : options.displayType, disabled: isDisabled$4(options === null || options === void 0 ? void 0 : options.screenShareButton) })),
27660
27850
  showParticipantsButtonInControlBar && (React.createElement(Participants, { option: options === null || options === void 0 ? void 0 : options.participantsButton, callInvitationURL: props.callInvitationURL, onFetchParticipantMenuItems: props.onFetchParticipantMenuItems, displayType: options === null || options === void 0 ? void 0 : options.displayType, increaseFlyoutItemSize: props.increaseFlyoutItemSize, isMobile: props.isMobile, disabled: isDisabled$4(options === null || options === void 0 ? void 0 : options.participantsButton) })) && (
@@ -27668,7 +27858,6 @@ const CallControls = (props) => {
27668
27858
  // styles={commonButtonStyles}
27669
27859
  showLabel: (options === null || options === void 0 ? void 0 : options.displayType) !== 'compact', disableTooltip: props.isMobile }));
27670
27860
  }),
27671
- /* @conditional-compile-remove(PSTN-calls) */ /* @conditional-compile-remove(one-to-n-calling) */ /* @conditional-compile-remove(close-captions) */ /* @conditional-compile-remove(raise-hand) */
27672
27861
  showMoreButton && (React.createElement(MoreButton, { disableTooltip: props.isMobile, "data-ui-id": "common-call-composite-more-button", strings: moreButtonStrings, menuIconProps: { hidden: true }, menuProps: { items: moreButtonMenuItems }, showLabel: (options === null || options === void 0 ? void 0 : options.displayType) !== 'compact' })),
27673
27862
  isEnabled$2(options === null || options === void 0 ? void 0 : options.endCallButton) && React.createElement(EndCall, { displayType: options === null || options === void 0 ? void 0 : options.displayType })))));
27674
27863
  };
@@ -28173,15 +28362,12 @@ const DesktopMoreButton = (props) => {
28173
28362
  (_h = (_g = galleryOptions.subMenuProps) === null || _g === void 0 ? void 0 : _g.items) === null || _h === void 0 ? void 0 : _h.push(overflowGalleryOption);
28174
28363
  moreButtonContextualMenuItems.push(galleryOptions);
28175
28364
  }
28176
- /* @conditional-compile-remove(control-bar-button-injection) */
28177
28365
  const customDrawerButtons = React.useMemo(() => generateCustomCallDesktopOverflowButtons(onFetchCustomButtonPropsTrampoline(typeof props.callControls === 'object' ? props.callControls : undefined), typeof props.callControls === 'object' ? props.callControls.displayType : undefined), [props.callControls]);
28178
- /* @conditional-compile-remove(control-bar-button-injection) */
28179
28366
  customDrawerButtons['primary'].slice(CUSTOM_BUTTON_OPTIONS.MAX_PRIMARY_DESKTOP_CUSTOM_BUTTONS).forEach((element) => {
28180
28367
  moreButtonContextualMenuItems.push(Object.assign({ itemProps: {
28181
28368
  styles: buttonFlyoutIncreasedSizeStyles
28182
28369
  } }, element));
28183
28370
  });
28184
- /* @conditional-compile-remove(control-bar-button-injection) */
28185
28371
  customDrawerButtons['secondary']
28186
28372
  .slice(CUSTOM_BUTTON_OPTIONS.MAX_SECONDARY_DESKTOP_CUSTOM_BUTTONS)
28187
28373
  .forEach((element) => {
@@ -28189,7 +28375,6 @@ const DesktopMoreButton = (props) => {
28189
28375
  styles: buttonFlyoutIncreasedSizeStyles
28190
28376
  } }, element));
28191
28377
  });
28192
- /* @conditional-compile-remove(control-bar-button-injection) */
28193
28378
  customDrawerButtons['overflow'].forEach((element) => {
28194
28379
  moreButtonContextualMenuItems.push(Object.assign({ itemProps: {
28195
28380
  styles: buttonFlyoutIncreasedSizeStyles
@@ -28412,7 +28597,7 @@ const CommonCallControlBar = (props) => {
28412
28597
  const reactionResources = props.callAdapter.getState().reactions;
28413
28598
  return (React.createElement("div", { ref: controlBarSizeRef },
28414
28599
  React.createElement(CallAdapterProvider, { adapter: props.callAdapter },
28415
- /* @conditional-compile-remove(close-captions) */ showCaptionsSettingsModal && (React.createElement(CaptionsSettingsModal, { showCaptionsSettingsModal: showCaptionsSettingsModal, onDismissCaptionsSettings: onDismissCaptionsSettings, changeCaptionLanguage: props.isCaptionsOn }))),
28600
+ /* @conditional-compile-remove(close-captions) */ showCaptionsSettingsModal && (React.createElement(CaptionsSettingsModal, { showCaptionsSettingsModal: showCaptionsSettingsModal, onDismissCaptionsSettings: onDismissCaptionsSettings, changeCaptionLanguage: props.isCaptionsOn && props.isTeamsCall }))),
28416
28601
  React.createElement(react.Stack, { horizontal: true, reversed: !props.mobileView && !isOutOfSpace, horizontalAlign: "space-between", className: react.mergeStyles(callControlsContainerStyles, controlBarContainerStyles, controlBarDesktopContainerStyles) },
28417
28602
  React.createElement(react.Stack.Item, { grow: true, className: react.mergeStyles(controlBarWrapperDesktopStyles) },
28418
28603
  React.createElement(CallAdapterProvider, { adapter: props.callAdapter },
@@ -28434,7 +28619,7 @@ const CommonCallControlBar = (props) => {
28434
28619
  isReactionAllowed &&
28435
28620
  isEnabled$1(options.reactionButton) &&
28436
28621
  reactionResources && (React.createElement(Reaction, { displayType: options.displayType, styles: commonButtonStyles, disabled: props.disableButtonsForHoldScreen, reactionResource: reactionResources })),
28437
- /* @conditional-compile-remove(raise-hand) */ !props.mobileView &&
28622
+ !props.mobileView &&
28438
28623
  isEnabled$1(options.raiseHandButton) &&
28439
28624
  /* @conditional-compile-remove(rooms) */ !hideRaiseHandButtonInRoomsCall && (React.createElement(RaiseHand, { displayType: options.displayType, styles: commonButtonStyles,
28440
28625
  /* @conditional-compile-remove(PSTN-calls) */ /* @conditional-compile-remove(one-to-n-calling) */
@@ -28457,9 +28642,7 @@ const CommonCallControlBar = (props) => {
28457
28642
  props.mobileView && (React.createElement(MoreButton, { "data-ui-id": "common-call-composite-more-button", strings: moreButtonStrings, onClick: props.onMoreButtonClicked, disabled: props.disableButtonsForLobbyPage, disableTooltip: props.mobileView })),
28458
28643
  !props.mobileView && showDesktopMoreButton && (React.createElement(DesktopMoreButton, { disableButtonsForHoldScreen: props.disableButtonsForHoldScreen, styles: commonButtonStyles,
28459
28644
  /*@conditional-compile-remove(PSTN-calls) */
28460
- onClickShowDialpad: props.onClickShowDialpad,
28461
- /* @conditional-compile-remove(control-bar-button-injection) */
28462
- callControls: props.callControls,
28645
+ onClickShowDialpad: props.onClickShowDialpad, callControls: props.callControls,
28463
28646
  /* @conditional-compile-remove(close-captions) */
28464
28647
  isCaptionsSupported: props.isCaptionsSupported,
28465
28648
  /* @conditional-compile-remove(close-captions) */
@@ -28777,14 +28960,12 @@ const MoreDrawer = (props) => {
28777
28960
  const callAdapter = useAdapter();
28778
28961
  const drawerMenuItems = [];
28779
28962
  const { speakers, onSelectSpeaker, onLightDismiss } = props;
28780
- /* @conditional-compile-remove(PSTN-calls) */ /* @conditional-compile-remove(one-to-n-calling) */ /* @conditional-compile-remove(close-captions) */ /* @conditional-compile-remove(raise-hand) */
28781
28963
  const localeStrings = useLocale();
28782
28964
  /* @conditional-compile-remove(PSTN-calls) */ /* @conditional-compile-remove(one-to-n-calling) */
28783
28965
  const holdButtonProps = usePropsFor$1(HoldButton);
28784
28966
  const callees = useSelector$1(getTargetCallees);
28785
28967
  const allowDtmfDialer = showDtmfDialer(callees);
28786
28968
  const [dtmfDialerChecked, setDtmfDialerChecked] = React.useState((_a = props.dtmfDialerPresent) !== null && _a !== void 0 ? _a : false);
28787
- /* @conditional-compile-remove(raise-hand) */
28788
28969
  const raiseHandButtonProps = usePropsFor$1(RaiseHandButton);
28789
28970
  const onSpeakerItemClick = React.useCallback((_ev, itemKey) => {
28790
28971
  const selected = speakers === null || speakers === void 0 ? void 0 : speakers.find((speaker) => speaker.id === itemKey);
@@ -28796,6 +28977,13 @@ const MoreDrawer = (props) => {
28796
28977
  onLightDismiss();
28797
28978
  }, [speakers, onSelectSpeaker, onLightDismiss]);
28798
28979
  const drawerSelectionOptions = inferCallWithChatControlOptions(props.callControls);
28980
+ /* @conditional-compile-remove(reaction) */
28981
+ if (props.reactionResources !== undefined) {
28982
+ drawerMenuItems.push({
28983
+ itemKey: 'reactions',
28984
+ onRendererContent: () => (React.createElement(_ReactionDrawerMenuItem, { onReactionClick: props.onReactionClick, reactionResources: props.reactionResources }))
28985
+ });
28986
+ }
28799
28987
  if (props.speakers && props.speakers.length > 0) {
28800
28988
  drawerMenuItems.push({
28801
28989
  itemKey: 'speakers',
@@ -28955,7 +29143,6 @@ const MoreDrawer = (props) => {
28955
29143
  const role = (_e = callAdapter.getState().call) === null || _e === void 0 ? void 0 : _e.role;
28956
29144
  /*@conditional-compile-remove(rooms) */
28957
29145
  const hideRaiseHandButtonInRoomsCall = callAdapter.getState().isRoomsCall && role && ['Consumer', 'Unknown'].includes(role);
28958
- /* @conditional-compile-remove(raise-hand) */
28959
29146
  if (drawerSelectionOptions !== false &&
28960
29147
  isEnabled(drawerSelectionOptions === null || drawerSelectionOptions === void 0 ? void 0 : drawerSelectionOptions.raiseHandButton) &&
28961
29148
  /*@conditional-compile-remove(rooms) */ !hideRaiseHandButtonInRoomsCall) {
@@ -29015,9 +29202,6 @@ const MoreDrawer = (props) => {
29015
29202
  const spokenLanguageString = supportedSpokenLanguageStrings
29016
29203
  ? supportedSpokenLanguageStrings[currentSpokenLanguage]
29017
29204
  : currentSpokenLanguage;
29018
- const captionLanguageString = supportedCaptionLanguageStrings
29019
- ? supportedCaptionLanguageStrings[currentCaptionLanguage]
29020
- : currentCaptionLanguage;
29021
29205
  drawerMenuItems.push({
29022
29206
  itemKey: 'captions',
29023
29207
  id: 'common-call-composite-captions-button',
@@ -29058,36 +29242,37 @@ const MoreDrawer = (props) => {
29058
29242
  styles: { root: { lineHeight: 0 } }
29059
29243
  }
29060
29244
  });
29061
- captionsDrawerItems.push({
29062
- itemKey: 'ChangeCaptionLanguage',
29063
- text: props.strings.captionLanguageMenuTitle,
29064
- id: 'common-call-composite-captions-subtitle-settings-button',
29065
- secondaryText: captionLanguageString,
29066
- iconProps: {
29067
- iconName: 'ChangeCaptionLanguageIcon',
29068
- styles: { root: { lineHeight: 0 } }
29069
- },
29070
- disabled: props.disableButtonsForHoldScreen || !captionSettingsProp.isCaptionsFeatureActive,
29071
- onItemClick: () => {
29072
- setIsCaptionLanguageDrawerOpen(true);
29073
- },
29074
- secondaryIconProps: {
29075
- iconName: 'ChevronRight',
29076
- styles: { root: { lineHeight: 0 } }
29077
- }
29078
- });
29245
+ if (props.isTeamsCall) {
29246
+ const captionLanguageString = supportedCaptionLanguageStrings
29247
+ ? supportedCaptionLanguageStrings[currentCaptionLanguage]
29248
+ : currentCaptionLanguage;
29249
+ captionsDrawerItems.push({
29250
+ itemKey: 'ChangeCaptionLanguage',
29251
+ text: props.strings.captionLanguageMenuTitle,
29252
+ id: 'common-call-composite-captions-subtitle-settings-button',
29253
+ secondaryText: captionLanguageString,
29254
+ iconProps: {
29255
+ iconName: 'ChangeCaptionLanguageIcon',
29256
+ styles: { root: { lineHeight: 0 } }
29257
+ },
29258
+ disabled: props.disableButtonsForHoldScreen || !captionSettingsProp.isCaptionsFeatureActive,
29259
+ onItemClick: () => {
29260
+ setIsCaptionLanguageDrawerOpen(true);
29261
+ },
29262
+ secondaryIconProps: {
29263
+ iconName: 'ChevronRight',
29264
+ styles: { root: { lineHeight: 0 } }
29265
+ }
29266
+ });
29267
+ }
29079
29268
  }
29080
- /* @conditional-compile-remove(control-bar-button-injection) */
29081
29269
  const customDrawerButtons = React.useMemo(() => generateCustomCallDrawerButtons(onFetchCustomButtonPropsTrampoline(drawerSelectionOptions !== false ? drawerSelectionOptions : undefined), drawerSelectionOptions !== false ? drawerSelectionOptions === null || drawerSelectionOptions === void 0 ? void 0 : drawerSelectionOptions.displayType : undefined), [drawerSelectionOptions]);
29082
- /* @conditional-compile-remove(control-bar-button-injection) */
29083
29270
  customDrawerButtons['primary'].slice(CUSTOM_BUTTON_OPTIONS.MAX_PRIMARY_MOBILE_CUSTOM_BUTTONS).forEach((element) => {
29084
29271
  drawerMenuItems.push(element);
29085
29272
  });
29086
- /* @conditional-compile-remove(control-bar-button-injection) */
29087
29273
  customDrawerButtons['secondary'].forEach((element) => {
29088
29274
  drawerMenuItems.push(element);
29089
29275
  });
29090
- /* @conditional-compile-remove(control-bar-button-injection) */
29091
29276
  customDrawerButtons['overflow'].forEach((element) => {
29092
29277
  drawerMenuItems.push(element);
29093
29278
  });
@@ -30342,7 +30527,6 @@ const LocalAndRemotePIP = (props) => {
30342
30527
  showCameraSwitcherInLocalPreview: false,
30343
30528
  isAvailable: (_a = localParticipant.videoStream) === null || _a === void 0 ? void 0 : _a.isAvailable,
30344
30529
  renderElement: (_b = localParticipant.videoStream) === null || _b === void 0 ? void 0 : _b.renderElement,
30345
- /* @conditional-compile-remove(raise-hand) */
30346
30530
  raisedHand: localParticipant.raisedHand
30347
30531
  });
30348
30532
  }, [
@@ -30351,7 +30535,6 @@ const LocalAndRemotePIP = (props) => {
30351
30535
  (_b = localParticipant.videoStream) === null || _b === void 0 ? void 0 : _b.renderElement,
30352
30536
  onCreateLocalStreamView,
30353
30537
  onDisposeLocalStreamView,
30354
- /* @conditional-compile-remove(raise-hand) */
30355
30538
  localParticipant.raisedHand
30356
30539
  ]);
30357
30540
  const remoteVideoTileProps = React.useMemo(() => {
@@ -30441,18 +30624,11 @@ const updateUserDisplayNamesTrampoline = (remoteParticipants) => {
30441
30624
  * Picture in picture in picture needs to display the most-dominant remote speaker, as well as the local participant video.
30442
30625
  * @private
30443
30626
  */
30444
- const localAndRemotePIPSelector = reselect__namespace.createSelector([
30445
- getDisplayName,
30446
- dominantRemoteParticipantSelector,
30447
- localVideoSelector,
30448
- /* @conditional-compile-remove(raise-hand) */ getLocalParticipantRaisedHand
30449
- ], (displayName, dominantRemoteParticipant, localVideoStreamInfo,
30450
- /* @conditional-compile-remove(raise-hand) */ raisedHand) => {
30627
+ const localAndRemotePIPSelector = reselect__namespace.createSelector([getDisplayName, dominantRemoteParticipantSelector, localVideoSelector, getLocalParticipantRaisedHand], (displayName, dominantRemoteParticipant, localVideoStreamInfo, raisedHand) => {
30451
30628
  return {
30452
30629
  localParticipant: {
30453
30630
  displayName,
30454
30631
  videoStream: localVideoStreamInfo,
30455
- /* @conditional-compile-remove(raise-hand) */
30456
30632
  raisedHand: raisedHand
30457
30633
  },
30458
30634
  dominantRemoteParticipant
@@ -31089,7 +31265,9 @@ const CallArrangement = (props) => {
31089
31265
  /* @conditional-compile-remove(PSTN-calls) */ /* @conditional-compile-remove(one-to-n-calling) */
31090
31266
  disableButtonsForHoldScreen: isInLocalHold, peopleButtonChecked: isPeoplePaneOpen, onPeopleButtonClicked: togglePeoplePane, onMoreButtonClicked: onMoreButtonClicked,
31091
31267
  /* @conditional-compile-remove(close-captions) */
31092
- isCaptionsSupported: isTeamsCall && hasJoinedCall,
31268
+ isCaptionsSupported: hasJoinedCall,
31269
+ /* @conditional-compile-remove(close-captions) */
31270
+ isTeamsCall: isTeamsCall,
31093
31271
  /* @conditional-compile-remove(close-captions) */
31094
31272
  isCaptionsOn: isCaptionsOn,
31095
31273
  /* @conditional-compile-remove(video-background-effects) */
@@ -31101,7 +31279,11 @@ const CallArrangement = (props) => {
31101
31279
  /* @conditional-compile-remove(PSTN-calls) */ /* @conditional-compile-remove(one-to-n-calling) */
31102
31280
  disableButtonsForHoldScreen: isInLocalHold,
31103
31281
  /* @conditional-compile-remove(close-captions) */
31104
- isCaptionsSupported: isTeamsCall && hasJoinedCall, onUserSetGalleryLayout: props.onUserSetGalleryLayoutChange, userSetGalleryLayout: props.userSetGalleryLayout, onSetDialpadPage: props.onSetDialpadPage, dtmfDialerPresent: props.dtmfDialerPresent }))),
31282
+ isCaptionsSupported: hasJoinedCall,
31283
+ /* @conditional-compile-remove(close-captions) */
31284
+ isTeamsCall: isTeamsCall, onUserSetGalleryLayout: props.onUserSetGalleryLayoutChange, userSetGalleryLayout: props.userSetGalleryLayout, onSetDialpadPage: props.onSetDialpadPage, dtmfDialerPresent: props.dtmfDialerPresent,
31285
+ /* @conditional-compile-remove(reaction) */
31286
+ reactionResources: adapter.getState().reactions }))),
31105
31287
  React.createElement(react.Stack, { horizontal: true, grow: true },
31106
31288
  React.createElement(react.Stack.Item, { style: callCompositeContainerCSS },
31107
31289
  React.createElement(react.Stack.Item, { styles: callGalleryStyles, grow: true },
@@ -31118,7 +31300,9 @@ const CallArrangement = (props) => {
31118
31300
  canUnmute && !!props.mutedNotificationProps && (React.createElement(MutedNotification, Object.assign({}, props.mutedNotificationProps)))),
31119
31301
  renderGallery && props.onRenderGalleryContent && props.onRenderGalleryContent(),
31120
31302
  /* @conditional-compile-remove(close-captions) */
31121
- /* @conditional-compile-remove(PSTN-calls) */ /* @conditional-compile-remove(one-to-n-calling) */ !isInLocalHold && (React.createElement(CaptionsBanner, { isMobile: props.mobileView, onFetchAvatarPersonaData: props.onFetchAvatarPersonaData }))))),
31303
+ /* @conditional-compile-remove(PSTN-calls) */ /* @conditional-compile-remove(one-to-n-calling) */ !isInLocalHold && (React.createElement(CaptionsBanner, { isMobile: props.mobileView, onFetchAvatarPersonaData: props.onFetchAvatarPersonaData,
31304
+ /* @conditional-compile-remove(close-captions) */
31305
+ isTeamsCall: isTeamsCall }))))),
31122
31306
  React.createElement(SidePane, { mobileView: props.mobileView,
31123
31307
  /* @conditional-compile-remove(video-background-effects) */
31124
31308
  maxWidth: isVideoPaneOpen ? `${VIDEO_EFFECTS_SIDE_PANE_WIDTH_REM}rem` : undefined, minWidth: isVideoPaneOpen ? `${VIDEO_EFFECTS_SIDE_PANE_WIDTH_REM}rem` : undefined, updateSidePaneRenderer: props.updateSidePaneRenderer, onPeopleButtonClicked: props.mobileView && !shouldShowPeopleTabHeaderButton(props.callControlProps.options)
@@ -34725,7 +34909,6 @@ class AzureCommunicationCallAdapter {
34725
34909
  this.startCall.bind(this);
34726
34910
  this.startScreenShare.bind(this);
34727
34911
  this.stopScreenShare.bind(this);
34728
- /* @conditional-compile-remove(raise-hand) */
34729
34912
  this.raiseHand.bind(this);
34730
34913
  /* @conditional-compile-remove(reaction) */
34731
34914
  this.onReactionClick.bind(this);
@@ -35038,7 +35221,6 @@ class AzureCommunicationCallAdapter {
35038
35221
  }));
35039
35222
  });
35040
35223
  }
35041
- /* @conditional-compile-remove(raise-hand) */
35042
35224
  raiseHand() {
35043
35225
  return __awaiter$5(this, void 0, void 0, function* () {
35044
35226
  return yield this.asyncTeeErrorToEventEmitter(() => __awaiter$5(this, void 0, void 0, function* () {
@@ -35046,7 +35228,6 @@ class AzureCommunicationCallAdapter {
35046
35228
  }));
35047
35229
  });
35048
35230
  }
35049
- /* @conditional-compile-remove(raise-hand) */
35050
35231
  lowerHand() {
35051
35232
  return __awaiter$5(this, void 0, void 0, function* () {
35052
35233
  return yield this.asyncTeeErrorToEventEmitter(() => __awaiter$5(this, void 0, void 0, function* () {
@@ -35262,25 +35443,49 @@ class AzureCommunicationCallAdapter {
35262
35443
  }
35263
35444
  /* @conditional-compile-remove(close-captions) */
35264
35445
  subscribeToCaptionEvents() {
35265
- var _a;
35266
- if (this.call && this.call.state === 'Connected' && this.context.getState().isTeamsCall) {
35267
- const captionsFeature = (_a = this.call) === null || _a === void 0 ? void 0 : _a.feature(communicationCalling.Features.Captions).captions;
35268
- captionsFeature.on('CaptionsReceived', this.captionsReceived.bind(this));
35269
- captionsFeature.on('CaptionsActiveChanged', this.isCaptionsActiveChanged.bind(this));
35270
- captionsFeature.on('CaptionLanguageChanged', this.isCaptionLanguageChanged.bind(this));
35271
- captionsFeature.on('SpokenLanguageChanged', this.isSpokenLanguageChanged.bind(this));
35446
+ var _a, _b;
35447
+ if (this.call && this.call.state === 'Connected') {
35448
+ if (this.context.getState().isTeamsCall) {
35449
+ const captionsFeature = (_a = this.call) === null || _a === void 0 ? void 0 : _a.feature(communicationCalling.Features.Captions).captions;
35450
+ captionsFeature.on('CaptionsReceived', this.teamsCaptionsReceived.bind(this));
35451
+ captionsFeature.on('CaptionsActiveChanged', this.isCaptionsActiveChanged.bind(this));
35452
+ captionsFeature.on('CaptionLanguageChanged', this.isCaptionLanguageChanged.bind(this));
35453
+ captionsFeature.on('SpokenLanguageChanged', this.isSpokenLanguageChanged.bind(this));
35454
+ }
35455
+ else {
35456
+ /* @conditional-compile-remove(acs-close-captions) */
35457
+ const captionsFeature = (_b = this.call) === null || _b === void 0 ? void 0 : _b.feature(communicationCalling.Features.Captions).captions;
35458
+ /* @conditional-compile-remove(acs-close-captions) */
35459
+ captionsFeature.on('CaptionsReceived', this.captionsReceived.bind(this));
35460
+ /* @conditional-compile-remove(acs-close-captions) */
35461
+ captionsFeature.on('CaptionsActiveChanged', this.isCaptionsActiveChanged.bind(this));
35462
+ /* @conditional-compile-remove(acs-close-captions) */
35463
+ captionsFeature.on('SpokenLanguageChanged', this.isSpokenLanguageChanged.bind(this));
35464
+ }
35272
35465
  }
35273
35466
  }
35274
35467
  /* @conditional-compile-remove(close-captions) */
35275
35468
  unsubscribeFromCaptionEvents() {
35276
- var _a, _b;
35277
- if (this.call && this.call.state === 'Connected' && this.context.getState().isTeamsCall) {
35278
- const captionsFeature = (_a = this.call) === null || _a === void 0 ? void 0 : _a.feature(communicationCalling.Features.Captions).captions;
35279
- captionsFeature.off('CaptionsReceived', this.captionsReceived.bind(this));
35280
- captionsFeature.off('CaptionsActiveChanged', this.isCaptionsActiveChanged.bind(this));
35281
- captionsFeature.off('CaptionLanguageChanged', this.isCaptionLanguageChanged.bind(this));
35282
- captionsFeature.off('SpokenLanguageChanged', this.isSpokenLanguageChanged.bind(this));
35283
- (_b = this.call) === null || _b === void 0 ? void 0 : _b.off('stateChanged', this.subscribeToCaptionEvents.bind(this));
35469
+ var _a, _b, _c;
35470
+ if (this.call && this.call.state === 'Connected') {
35471
+ if (this.context.getState().isTeamsCall) {
35472
+ const captionsFeature = (_a = this.call) === null || _a === void 0 ? void 0 : _a.feature(communicationCalling.Features.Captions).captions;
35473
+ captionsFeature.off('CaptionsReceived', this.teamsCaptionsReceived.bind(this));
35474
+ captionsFeature.off('CaptionsActiveChanged', this.isCaptionsActiveChanged.bind(this));
35475
+ captionsFeature.off('CaptionLanguageChanged', this.isCaptionLanguageChanged.bind(this));
35476
+ captionsFeature.off('SpokenLanguageChanged', this.isSpokenLanguageChanged.bind(this));
35477
+ }
35478
+ else {
35479
+ /* @conditional-compile-remove(acs-close-captions) */
35480
+ const captionsFeature = (_b = this.call) === null || _b === void 0 ? void 0 : _b.feature(communicationCalling.Features.Captions).captions;
35481
+ /* @conditional-compile-remove(acs-close-captions) */
35482
+ captionsFeature.off('CaptionsReceived', this.captionsReceived.bind(this));
35483
+ /* @conditional-compile-remove(acs-close-captions) */
35484
+ captionsFeature.off('CaptionsActiveChanged', this.isCaptionsActiveChanged.bind(this));
35485
+ /* @conditional-compile-remove(acs-close-captions) */
35486
+ captionsFeature.off('SpokenLanguageChanged', this.isSpokenLanguageChanged.bind(this));
35487
+ }
35488
+ (_c = this.call) === null || _c === void 0 ? void 0 : _c.off('stateChanged', this.subscribeToCaptionEvents.bind(this));
35284
35489
  }
35285
35490
  }
35286
35491
  subscribeCallEvents() {
@@ -35344,6 +35549,10 @@ class AzureCommunicationCallAdapter {
35344
35549
  this.emitter.emit('isLocalScreenSharingActiveChanged', { isScreenSharingOn: (_a = this.call) === null || _a === void 0 ? void 0 : _a.isScreenSharingOn });
35345
35550
  }
35346
35551
  /* @conditional-compile-remove(close-captions) */
35552
+ teamsCaptionsReceived(captionsInfo) {
35553
+ this.emitter.emit('captionsReceived', { captionsInfo });
35554
+ }
35555
+ /* @conditional-compile-remove(acs-close-captions) */
35347
35556
  captionsReceived(captionsInfo) {
35348
35557
  this.emitter.emit('captionsReceived', { captionsInfo });
35349
35558
  }
@@ -35897,9 +36106,7 @@ class CallWithChatBackedCallAdapter {
35897
36106
  this.unmute = () => __awaiter$4(this, void 0, void 0, function* () { return yield this.callWithChatAdapter.unmute(); });
35898
36107
  this.startScreenShare = () => __awaiter$4(this, void 0, void 0, function* () { return yield this.callWithChatAdapter.startScreenShare(); });
35899
36108
  this.stopScreenShare = () => __awaiter$4(this, void 0, void 0, function* () { return yield this.callWithChatAdapter.stopScreenShare(); });
35900
- /* @conditional-compile-remove(raise-hand) */
35901
36109
  this.raiseHand = () => __awaiter$4(this, void 0, void 0, function* () { return yield this.callWithChatAdapter.raiseHand(); });
35902
- /* @conditional-compile-remove(raise-hand) */
35903
36110
  this.lowerHand = () => __awaiter$4(this, void 0, void 0, function* () { return yield this.callWithChatAdapter.lowerHand(); });
35904
36111
  /* @conditional-compile-remove(reaction) */
35905
36112
  this.onReactionClick = (reaction) => __awaiter$4(this, void 0, void 0, function* () { return yield this.callWithChatAdapter.onReactionClick(reaction); });
@@ -36423,7 +36630,6 @@ const CallWithChatScreen = (props) => {
36423
36630
  const callControlOptionsFromProps = React.useMemo(() => (Object.assign({}, (typeof props.callControls === 'object' ? props.callControls : {}))), [props.callControls]);
36424
36631
  const injectedCustomButtonsFromProps = React.useMemo(() => {
36425
36632
  var _a;
36426
- /* @conditional-compile-remove(control-bar-button-injection) */
36427
36633
  return [...((_a = callControlOptionsFromProps.onFetchCustomButtonProps) !== null && _a !== void 0 ? _a : [])];
36428
36634
  }, [callControlOptionsFromProps]);
36429
36635
  const callCompositeOptions = React.useMemo(() => ({
@@ -36431,7 +36637,6 @@ const CallWithChatScreen = (props) => {
36431
36637
  ? false
36432
36638
  : Object.assign(Object.assign({}, callControlOptionsFromProps), { onFetchCustomButtonProps: [
36433
36639
  ...(showChatButton ? [customChatButton] : []),
36434
- /* @conditional-compile-remove(control-bar-button-injection) */
36435
36640
  ...injectedCustomButtonsFromProps
36436
36641
  ], legacyControlBarExperience: false }),
36437
36642
  /* @conditional-compile-remove(call-readiness) */
@@ -36770,9 +36975,7 @@ class AzureCommunicationCallWithChatAdapter {
36770
36975
  this.unmute.bind(this);
36771
36976
  this.startScreenShare.bind(this);
36772
36977
  this.stopScreenShare.bind(this);
36773
- /* @conditional-compile-remove(raise-hand) */
36774
36978
  this.raiseHand.bind(this);
36775
- /* @conditional-compile-remove(raise-hand) */
36776
36979
  this.lowerHand.bind(this);
36777
36980
  /* @conditional-compile-remove(reaction) */
36778
36981
  this.onReactionClick.bind(this);
@@ -36967,14 +37170,12 @@ class AzureCommunicationCallWithChatAdapter {
36967
37170
  yield this.callAdapter.stopScreenShare();
36968
37171
  });
36969
37172
  }
36970
- /* @conditional-compile-remove(raise-hand) */
36971
37173
  /** Raise hand for local user. */
36972
37174
  raiseHand() {
36973
37175
  return __awaiter$2(this, void 0, void 0, function* () {
36974
37176
  yield this.callAdapter.raiseHand();
36975
37177
  });
36976
37178
  }
36977
- /* @conditional-compile-remove(raise-hand) */
36978
37179
  /** Lower hand for local user. */
36979
37180
  lowerHand() {
36980
37181
  return __awaiter$2(this, void 0, void 0, function* () {
@@ -38052,4 +38253,4 @@ exports.useTeamsCall = useTeamsCall;
38052
38253
  exports.useTeamsCallAdapter = useTeamsCallAdapter;
38053
38254
  exports.useTeamsCallAgent = useTeamsCallAgent;
38054
38255
  exports.useTheme = useTheme;
38055
- //# sourceMappingURL=index-DikMcJD4.js.map
38256
+ //# sourceMappingURL=index-BfFCLrEO.js.map