@azure/communication-react 1.14.0-alpha-202403020011 → 1.14.0-alpha-202403050012

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 (54) hide show
  1. package/dist/communication-react.d.ts +23 -0
  2. package/dist/dist-cjs/communication-react/index.js +199 -83
  3. package/dist/dist-cjs/communication-react/index.js.map +1 -1
  4. package/dist/dist-esm/acs-ui-common/src/telemetryVersion.js +1 -1
  5. package/dist/dist-esm/acs-ui-common/src/telemetryVersion.js.map +1 -1
  6. package/dist/dist-esm/calling-component-bindings/src/handlers/createCommonHandlers.d.ts +1 -0
  7. package/dist/dist-esm/calling-component-bindings/src/handlers/createCommonHandlers.js +6 -0
  8. package/dist/dist-esm/calling-component-bindings/src/handlers/createCommonHandlers.js.map +1 -1
  9. package/dist/dist-esm/react-components/src/components/Survey/TagsSurvey/TagsSurvey.js +6 -10
  10. package/dist/dist-esm/react-components/src/components/Survey/TagsSurvey/TagsSurvey.js.map +1 -1
  11. package/dist/dist-esm/react-composites/src/composites/CallComposite/Strings.d.ts +8 -0
  12. package/dist/dist-esm/react-composites/src/composites/CallComposite/Strings.js.map +1 -1
  13. package/dist/dist-esm/react-composites/src/composites/CallComposite/adapter/AzureCommunicationCallAdapter.d.ts +1 -0
  14. package/dist/dist-esm/react-composites/src/composites/CallComposite/adapter/AzureCommunicationCallAdapter.js +8 -0
  15. package/dist/dist-esm/react-composites/src/composites/CallComposite/adapter/AzureCommunicationCallAdapter.js.map +1 -1
  16. package/dist/dist-esm/react-composites/src/composites/CallComposite/adapter/CallAdapter.d.ts +4 -0
  17. package/dist/dist-esm/react-composites/src/composites/CallComposite/adapter/CallAdapter.js.map +1 -1
  18. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/CallArrangement.js +72 -23
  19. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/CallArrangement.js.map +1 -1
  20. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/SidePane/SidePane.d.ts +1 -0
  21. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/SidePane/SidePane.js +2 -1
  22. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/SidePane/SidePane.js.map +1 -1
  23. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/SidePane/usePeoplePane.d.ts +1 -0
  24. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/SidePane/usePeoplePane.js +25 -1
  25. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/SidePane/usePeoplePane.js.map +1 -1
  26. package/dist/dist-esm/react-composites/src/composites/CallComposite/hooks/useHandlers.js +4 -0
  27. package/dist/dist-esm/react-composites/src/composites/CallComposite/hooks/useHandlers.js.map +1 -1
  28. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/AzureCommunicationCallWithChatAdapter.d.ts +1 -0
  29. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/AzureCommunicationCallWithChatAdapter.js +6 -0
  30. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/AzureCommunicationCallWithChatAdapter.js.map +1 -1
  31. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/CallWithChatAdapter.d.ts +4 -0
  32. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/CallWithChatAdapter.js.map +1 -1
  33. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/CallWithChatBackedCallAdapter.d.ts +2 -1
  34. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/CallWithChatBackedCallAdapter.js +6 -0
  35. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/CallWithChatBackedCallAdapter.js.map +1 -1
  36. package/dist/dist-esm/react-composites/src/composites/ChatComposite/ChatScreen.js +37 -40
  37. package/dist/dist-esm/react-composites/src/composites/ChatComposite/ChatScreen.js.map +1 -1
  38. package/dist/dist-esm/react-composites/src/composites/ChatComposite/adapter/AzureCommunicationChatAdapter.js +1 -1
  39. package/dist/dist-esm/react-composites/src/composites/ChatComposite/adapter/AzureCommunicationChatAdapter.js.map +1 -1
  40. package/dist/dist-esm/react-composites/src/composites/common/ExitSpotlightButton.js +1 -1
  41. package/dist/dist-esm/react-composites/src/composites/common/ExitSpotlightButton.js.map +1 -1
  42. package/dist/dist-esm/react-composites/src/composites/common/SidePaneHeader.d.ts +3 -0
  43. package/dist/dist-esm/react-composites/src/composites/common/SidePaneHeader.js +6 -1
  44. package/dist/dist-esm/react-composites/src/composites/common/SidePaneHeader.js.map +1 -1
  45. package/dist/dist-esm/react-composites/src/composites/common/TabHeader.d.ts +1 -0
  46. package/dist/dist-esm/react-composites/src/composites/common/TabHeader.js +5 -1
  47. package/dist/dist-esm/react-composites/src/composites/common/TabHeader.js.map +1 -1
  48. package/dist/dist-esm/react-composites/src/composites/common/icons.d.ts +6 -0
  49. package/dist/dist-esm/react-composites/src/composites/common/icons.js +6 -2
  50. package/dist/dist-esm/react-composites/src/composites/common/icons.js.map +1 -1
  51. package/dist/dist-esm/react-composites/src/composites/common/styles/Pane.styles.js +8 -1
  52. package/dist/dist-esm/react-composites/src/composites/common/styles/Pane.styles.js.map +1 -1
  53. package/dist/dist-esm/react-composites/src/composites/localization/locales/en-US/strings.json +2 -0
  54. package/package.json +1 -1
@@ -174,7 +174,7 @@ function getDefaultExportFromCjs (x) {
174
174
  // Copyright (c) Microsoft Corporation.
175
175
  // Licensed under the MIT License.
176
176
  // GENERATED FILE. DO NOT EDIT MANUALLY.
177
- var telemetryVersion = '1.14.0-alpha-202403020011';
177
+ var telemetryVersion = '1.14.0-alpha-202403050012';
178
178
 
179
179
 
180
180
  var telemetryVersion$1 = /*@__PURE__*/getDefaultExportFromCjs(telemetryVersion);
@@ -1171,6 +1171,10 @@ const createDefaultCommonCallingHandlers = memoizeOne((callClient, deviceManager
1171
1171
  yield (call === null || call === void 0 ? void 0 : call.feature(communicationCalling.Features.Spotlight).stopSpotlight(participants));
1172
1172
  });
1173
1173
  /* @conditional-compile-remove(spotlight) */
1174
+ const onStopAllSpotlight = () => __awaiter$Q(void 0, void 0, void 0, function* () {
1175
+ yield (call === null || call === void 0 ? void 0 : call.feature(communicationCalling.Features.Spotlight).stopAllSpotlight());
1176
+ });
1177
+ /* @conditional-compile-remove(spotlight) */
1174
1178
  const canSpotlight = call === null || call === void 0 ? void 0 : call.feature(communicationCalling.Features.Capabilities).capabilities.spotlightParticipant.isPresent;
1175
1179
  /* @conditional-compile-remove(spotlight) */
1176
1180
  const onStartLocalSpotlight = canSpotlight
@@ -1251,6 +1255,8 @@ const createDefaultCommonCallingHandlers = memoizeOne((callClient, deviceManager
1251
1255
  /* @conditional-compile-remove(spotlight) */
1252
1256
  onStopSpotlight,
1253
1257
  /* @conditional-compile-remove(spotlight) */
1258
+ onStopAllSpotlight,
1259
+ /* @conditional-compile-remove(spotlight) */
1254
1260
  onStartLocalSpotlight,
1255
1261
  /* @conditional-compile-remove(spotlight) */
1256
1262
  onStopLocalSpotlight,
@@ -19312,16 +19318,12 @@ const _TagsSurvey = (props) => {
19312
19318
  else {
19313
19319
  if (issue) {
19314
19320
  setSelectedTags((prevState) => {
19315
- var _a;
19316
- if ((_a = prevState[issueCategory]) === null || _a === void 0 ? void 0 : _a.issues) {
19317
- prevState[issueCategory].issues = prevState[issueCategory].issues.filter(function (value) {
19318
- return value !== issue;
19319
- });
19320
- if (prevState[issueCategory].issues.length === 0) {
19321
- delete prevState[issueCategory];
19322
- }
19323
- }
19324
- return prevState;
19321
+ var _a, _b;
19322
+ // 'prevState[issueCategory]?.issues as ...' typing is required here to avoid a typescript limitation
19323
+ // "This expression is not callable" caused by filter().
19324
+ // More information can be found here: https://github.com/microsoft/TypeScript/issues/44373
19325
+ const categoryIssues = (_b = (_a = prevState[issueCategory]) === null || _a === void 0 ? void 0 : _a.issues) === null || _b === void 0 ? void 0 : _b.filter((value) => value !== issue);
19326
+ return Object.assign(Object.assign({}, prevState), { [issueCategory]: Object.assign(Object.assign({}, (prevState[issueCategory] || {})), { issues: categoryIssues }) });
19325
19327
  });
19326
19328
  }
19327
19329
  else {
@@ -23613,7 +23615,11 @@ const COMPOSITE_ONLY_ICONS = {
23613
23615
  /* @conditional-compile-remove(control-bar-button-injection) */
23614
23616
  DefaultCustomButton: React.createElement(reactIcons.Circle20Regular, null),
23615
23617
  /* @conditional-compile-remove(dtmf-dialer) */
23616
- DtmfDialpadButton: React.createElement(reactIcons.Dialpad20Regular, null)
23618
+ DtmfDialpadButton: React.createElement(reactIcons.Dialpad20Regular, null),
23619
+ /* @conditional-compile-remove(spotlight) */
23620
+ PeoplePaneMoreButton: React.createElement(reactIcons.MoreHorizontal20Filled, null),
23621
+ /* @conditional-compile-remove(spotlight) */
23622
+ StopAllSpotlightMenuButton: React.createElement(reactIcons.VideoPersonStarOff20Filled, null)
23617
23623
  };
23618
23624
  /**
23619
23625
  * The default set of icons that are available to used in the Composites.
@@ -23646,7 +23652,7 @@ const CallCompositeIcon = (props) => (React.createElement(react.FontIcon, Object
23646
23652
  */
23647
23653
  const CallWithChatCompositeIcon = (props) => (React.createElement(react.FontIcon, Object.assign({}, props)));
23648
23654
 
23649
- var call$k={cameraLabel:"Camera",noCamerasLabel:"No cameras found",cameraPermissionDenied:"Your browser is blocking access to your camera",cameraTurnedOff:"Your camera is turned off",chatButtonLabel:"Chat",close:"Close",complianceBannerNowOnlyRecording:"You are now only recording this meeting.",complianceBannerNowOnlyTranscription:"You are now only transcribing this meeting.",complianceBannerRecordingAndTranscriptionSaved:"Recording and transcription are being saved.",complianceBannerRecordingAndTranscriptionStarted:"Recording and transcription have started.",complianceBannerRecordingAndTranscriptionStopped:"Recording and transcription have stopped.",complianceBannerRecordingSaving:"Recording is being saved.",complianceBannerRecordingStarted:"Recording has started.",complianceBannerRecordingStopped:"Recording has stopped.",complianceBannerTranscriptionStarted:"Transcription has started.",complianceBannerTranscriptionConsent:"By joining, you are giving consent for this meeting to be transcribed.",complianceBannerTranscriptionSaving:"Transcription is being saved.",complianceBannerTranscriptionStopped:"Transcription has stopped.",configurationPageTitle:"Start a call",copyInviteLinkButtonLabel:"Copy invite link",copyInviteLinkActionedAriaLabel:"Invite link copied",defaultPlaceHolder:"Select an option",dismissSidePaneButtonLabel:"Close",videoEffectsPaneTitle:"Effects",videoEffectsPaneBackgroundSelectionTitle:"Background",configurationPageVideoEffectsButtonLabel:"Effects",unableToStartVideoEffect:"Unable to apply video effect.",blurBackgroundEffectButtonLabel:"Blur",blurBackgroundTooltip:"Blur Background",removeBackgroundEffectButtonLabel:"None",removeBackgroundTooltip:"Remove Background",cameraOffBackgroundEffectWarningText:"Your camera is off. Turn on camera to see video effect.",failedToJoinCallDueToNoNetworkMoreDetails:"Call was disconnected due to a network issue. Check your connection and join again.",failedToJoinCallDueToNoNetworkTitle:"Call disconnected",failedToJoinTeamsMeetingReasonAccessDeniedMoreDetails:"You were not granted entry in the call. If this was a mistake, re-join the call.",failedToJoinTeamsMeetingReasonAccessDeniedTitle:"Dismissed from lobby",learnMore:"Learn more",leavingCallTitle:"Leaving...",leftCallMoreDetails:"If this was a mistake, re-join the call.",leftCallTitle:"You left the call",lobbyScreenConnectingToCallTitle:"Joining call",lobbyScreenWaitingToBeAdmittedTitle:"Waiting to be admitted",microphonePermissionDenied:"Your browser is blocking access to your microphone",microphoneToggleInLobbyNotAllowed:"Cannot mute or unmute while in lobby.",mutedMessage:"You're muted",networkReconnectMoreDetails:"Looks like something went wrong. We're trying to get back into the call.",networkReconnectTitle:"Hold on",notInvitedToRoomDetails:"You are not able to join this room because you do not have an invite.",notInvitedToRoomTitle:"Not invited to room",peopleButtonLabel:"People",selectedPeopleButtonLabel:"People Button Selected",peoplePaneTitle:"People",peopleButtonTooltipOpen:"Show participants",peopleButtonTooltipClose:"Hide participants",peoplePaneSubTitle:"In this call {numberOfPeople}",privacyPolicy:"Privacy policy",rejoinCallButtonLabel:"Re-join call",removedFromCallMoreDetails:"Another participant removed you from the call.",removedFromCallTitle:"You were removed",removeMenuLabel:"Remove",startSpotlightParticipantListMenuLabel:"Spotlight for everyone",addSpotlightParticipantListMenuLabel:"Add spotlight",stopSpotlightParticipantListMenuLabel:"Stop spotlighting",stopSpotlightOnSelfParticipantListMenuLabel:"Exit spotlight",spotlightLimitReachedParticipantListMenuTitle:"Spotlight limit reached",returnToCallButtonAriaDescription:"Return to Call",returnToCallButtonAriaLabel:"Back",roomNotFoundDetails:"The room ID provided could not be found.",roomNotFoundTitle:"Room not found",roomNotValidDetails:"This room is not valid at this current time.",roomNotValidTitle:"Room not valid",inviteToRoomRemovedDetails:"Your invite to join this room was removed.",inviteToRoomRemovedTitle:"Invite to room removed",soundLabel:"Sound",noMicrophonesLabel:"No microphones found",noSpeakersLabel:"No speakers found",startCallButtonLabel:"Start call",openDialpadButtonLabel:"Dial phone number",peoplePaneAddPeopleButtonLabel:"Add People",dialpadStartCallButtonLabel:"Call",dialpadModalTitle:"Dial Phone Number",dialpadModalAriaLabel:"Dialpad",dialpadCloseModalButtonAriaLabel:"Close dialpad",moreButtonCallingLabel:"More",resumeCallButtonLabel:"Resume",resumingCallButtonLabel:"Resuming...",resumeCallButtonAriaLabel:"Resume call",resumingCallButtonAriaLabel:"Resume call",holdScreenLabel:"You're on hold",openDtmfDialpadLabel:"Show dialpad",dtmfDialpadPlaceholderText:"Enter number",outboundCallingNoticeString:"Calling...",participantJoinedNoticeString:"{displayName} joined",twoParticipantJoinedNoticeString:"{displayName1} and {displayName2} have joined",threeParticipantJoinedNoticeString:"{displayName1}, {displayName2} and {displayName3} have joined",participantLeftNoticeString:"{displayName} left",twoParticipantLeftNoticeString:"{displayName1} and {displayName2} have left",threeParticipantLeftNoticeString:"{displayName1}, {displayName2} and {displayName3} have left",unnamedParticipantString:"unnamed participant",manyUnnamedParticipantsJoined:"unnamed participant and {numOfParticipants} other participants joined",manyUnnamedParticipantsLeft:"unnamed participant and {numOfParticipants} other participants left",manyParticipantsJoined:"{displayName1}, {displayName2}, {displayName3} and {numOfParticipants} other participants joined",manyParticipantsLeft:"{displayName1}, {displayName2}, {displayName3} and {numOfParticipants} other participants left",liveCaptionsLabel:"Live captions",captionsSettingsLabel:"Caption settings",startCaptionsButtonOnLabel:"Turn on captions",startCaptionsButtonOffLabel:"Turn off captions",startCaptionsButtonTooltipOnContent:"Turn off captions",startCaptionsButtonTooltipOffContent:"Turn on captions",captionsSettingsModalTitle:"Captions Settings",captionsSettingsSpokenLanguageDropdownLabel:"Spoken language",captionsSettingsCaptionLanguageDropdownLabel:"Captions language",captionsSettingsSpokenLanguageDropdownInfoText:"Language that everyone on this call is speaking.",captionsSettingsCaptionLanguageDropdownInfoText:"Captions will appear in this langugage.",captionsSettingsConfirmButtonLabel:"Confirm",captionsSettingsCancelButtonLabel:"Cancel",captionsSettingsModalAriaLabel:"Captions Setting Modal",captionsSettingsCloseModalButtonAriaLabel:"Close Captions Setting",captionsBannerMoreButtonCallingLabel:"More",captionsBannerMoreButtonTooltip:"More options",dismissModalAriaLabel:"Local and remote picture and picture, press enter to return to call",callRejectedTitle:"The call could not be completed",callRejectedMoreDetails:"The person you are trying to reach is unavailable. Please try again later.",callTimeoutTitle:"The call could not be completed",callTimeoutDetails:"The person you are trying to reach is unavailable. Please try again later.",callTimeoutBotTitle:"The call could not be completed",callTimeoutBotDetails:"The service that you are trying to reach is unavailable. Please try again later.",dtmfDialerButtonLabel:"Dialpad",dtmfDialerButtonTooltipOn:"Show dialpad",dtmfDialerButtonTooltipOff:"Hide dialpad",dtmfDialerMoreButtonLabelOn:"Show dialpad",dtmfDialerMoreButtonLabelOff:"Hide dialpad",spokenLanguageStrings:{"ar-ae":"Arabic - U.A.E.","ar-sa":"Arabic - Saudi Arabia","da-dk":"Danish","de-de":"German - Germany","en-au":"English - Australia","en-ca":"English - Canada","en-gb":"English - United Kingdom","en-in":"English - India","en-nz":"English - New Zealand","en-us":"English - United States","es-es":"Spanish - Spain (Modern Sort)","es-mx":"Spanish - Mexico","fi-fi":"Finnish","fr-ca":"French - Canada","fr-fr":"French - France","hi-in":"Hindi","it-it":"Italian - Italy","ja-jp":"Japanese","ko-kr":"Korean","nb-no":"Norwegian (Bokmål)","nl-be":"Dutch - Belgium","nl-nl":"Dutch - Netherlands","pl-pl":"Polish","pt-br":"Portuguese - Brazil","ru-ru":"Russian","sv-se":"Swedish","zh-cn":"Chinese - People's Republic of China","zh-hk":"Chinese - Hong Kong SAR","cs-cz":"Czech","pt-pt":"Portuguese - Portugal","tr-tr":"Turkish","vi-vn":"Vietnamese","th-th":"Thai","he-il":"Hebrew","cy-gb":"Welsh","uk-ua":"Ukrainian","el-gr":"Greek","hu-hu":"Hungarian","ro-ro":"Romanian","sk-sk":"Slovak","zh-tw":"Chinese - Taiwan"},captionLanguageStrings:{ar:"Arabic",da:"Danish",de:"German",en:"English",es:"Spanish",fi:"Finnish","fr-ca":"French - Canada",fr:"French - France",hi:"Hindi",it:"Italian",ja:"Japanese",ko:"Korean",nb:"Norwegian (Bokmål)",nl:"Dutch",pl:"Polish",pt:"Portuguese - Brazil",ru:"Russian",sv:"Swedish","zh-Hans":"Chinese (Simplified)","zh-Hant":"Chinese (Traditional)",cs:"Czech","pt-pt":"Portuguese - Portugal",tr:"Turkish",vi:"Vietnamese",th:"Thai",he:"Hebrew",cy:"Welsh",uk:"Ukrainian",el:"Greek",hu:"Hungarian",ro:"Romanian",sk:"Slovak"},captionsBannerSpinnerText:"Starting captions...",transferPageTransferorText:"Transferring...",transferPageTransferTargetText:"Connecting...",transferPageUnknownTransferorDisplayName:"Unknown",transferPageUnknownTransferTargetDisplayName:"Unknown",transferPageNoticeString:"You are being transferred",participantCouldNotBeReachedTitle:"Target participant is currently not available",participantCouldNotBeReachedMoreDetails:"Please contact participant when they are available",permissionToReachTargetParticipantNotAllowedTitle:"Permission to reach target participant is not allowed",permissionToReachTargetParticipantNotAllowedMoreDetails:"Please check that the target participant is in the same tenant",unableToResolveTenantTitle:"Unable to resolve tenant id for the target participant",unableToResolveTenantMoreDetails:"Please check the participant id is entered correctly",participantIdIsMalformedTitle:"Participant id is not in the correct format",participantIdIsMalformedMoreDetails:"Please check that the participant id is in the correct format",moreButtonGalleryControlLabel:"View",moreButtonGalleryPositionToggleLabel:"Move gallery to top",moreButtonGallerySpeakerLayoutLabel:"Speaker",moreButtonGalleryFloatingLocalLayoutLabel:"Dynamic",moreButtonGalleryDefaultLayoutLabel:"Gallery view",moreButtonGalleryFocusedContentLayoutLabel:"Focus on content",moreButtonLargeGalleryDefaultLayoutLabel:"Large Gallery",capabilityChangedNotification:{turnVideoOn:{lostDueToMeetingOption:"Your camera has been disabled. You can no longer share video.",grantedDueToMeetingOption:"Your camera has been enabled. Turn it on if you'd like to share video."},unmuteMic:{lostDueToMeetingOption:"Your mic has been disabled. You can no longer unmute.",grantedDueToMeetingOption:"Your mic has been enabled. Unmute if you'd like to speak."},shareScreen:{lostDueToRoleChangeToAttendee:"Your role has been changed. Some actions, like sharing content, won't be available to you.",grantedDueToRoleChangeToPresenter:"You're a presenter. You can share content and facilitate the meeting."}},surveyTitle:"Help us improve",starSurveyHelperText:"How was the quality of the call?",starSurveyOneStarText:"The quality was bad.",starSurveyTwoStarText:"The quality was poor.",starSurveyThreeStarText:"The quality was good.",starSurveyFourStarText:"The quality was great.",starSurveyFiveStarText:"The quality was excellent.",surveyConfirmButtonLabel:"Send Feedback",starRatingAriaLabel:"Select {0} of {1} stars",surveySkipButtonLabel:"Skip",tagsSurveyQuestion:"What could have been better?",tagsSurveyTextFieldDefaultText:"Other, please specify",tagsSurveyHelperText:"Check any issues you experienced",surveyTextboxDefaultText:"Other, please specify",endOfSurveyText:"Thank you for your feedback!",surveyIssues:{overallRating:{callCannotJoin:"I could not join call",callCannotInvite:"I could not invite others into the call",hadToRejoin:"I had to rejoin the call",callEndedUnexpectedly:"Call ended for me unexpectedly",otherIssues:"I was having other issues with the call"},audioRating:{noLocalAudio:"The other side could not hear any sound",noRemoteAudio:"I could not hear any sound",echo:"I heard echos on the call",audioNoise:"I heard noise on the call",lowVolume:"Volume was low",audioStoppedUnexpectedly:"Audio stopped unexpectedly",distortedSpeech:"Audio was distorted",audioInterruption:"Audio was interrupted",otherIssues:"I was having other audio issues in this call"},videoRating:{noVideoReceived:"I could not see any video",noVideoSent:"Others could not see me",lowQuality:"Video quality was low",freezes:"Video frozen",stoppedUnexpectedly:"Video stopped unexpectedly",darkVideoReceived:"I can only see dark screens when others turn on their camera",audioVideoOutOfSync:"Audio and Video was out of sync",otherIssues:"I was having other video issues in this call"},screenshareRating:{noContentLocal:"Other people could not see my screenshare",noContentRemote:"I could not see other people's screenshare",cannotPresent:"I could not present my screen",lowQuality:"Screen share quality was low",freezes:"Screen share frozen",stoppedUnexpectedly:"Screen share stopped unexpectedly",largeDelay:"Screen share has a large delay",otherIssues:"I was having other screen share issues in this call"}},SurveyIssuesHeadingStrings:{overallRating:"Overall",audioRating:"Audio",videoRating:"Video",screenshareRating:"Presenting"},spotlightPrompt:{startSpotlightHeading:"Spotlight for everyone?",startSpotlightText:"You'll highlight this video for everyone in the meeting.",startSpotlightOnSelfText:"You'll highlight your video for everyone in the meeting.",startSpotlightConfirmButtonLabel:"Spotlight for everyone",startSpotlightCancelButtonLabel:"Cancel",stopSpotlightHeading:"Stop spotlighting this video?",stopSpotlightOnSelfHeading:"Exit spotlight?",stopSpotlightText:"This video will no longer be highlighted for everyone in the meeting.",stopSpotlightOnSelfText:"Your video will no longer be highlighted for everyone in the meeting.",stopSpotlightConfirmButtonLabel:"Stop spotlighting",stopSpotlightOnSelfConfirmButtonLabel:"Exit spotlight",stopSpotlightCancelButtonLabel:"Cancel"},exitSpotlightButtonLabel:"Exit spotlight",exitSpotlightButtonTooltip:"Exit spotlight"};var chat$k={chatListHeader:"In this chat",uploadFile:"Upload File"};var callWithChat$k={chatButtonLabel:"Chat",chatButtonNewMessageNotificationLabel:"New Message",chatButtonTooltipClosedWithMessageCount:"Show chat ({unreadMessagesCount} unread)",chatButtonTooltipClose:"Hide chat",chatButtonTooltipOpen:"Show chat",chatPaneTitle:"Chat",copyInviteLinkButtonLabel:"Copy invite link",copyInviteLinkActionedAriaLabel:"Invite link copied",dismissSidePaneButtonLabel:"Close",moreDrawerAudioDeviceMenuTitle:"Audio Device",moreDrawerButtonLabel:"More options",moreDrawerButtonTooltip:"More options",moreDrawerMicrophoneMenuTitle:"Microphone",moreDrawerSpeakerMenuTitle:"Speaker",moreDrawerCaptionsMenuTitle:"Live captions",moreDrawerSpokenLanguageMenuTitle:"Spoken language",moreDrawerCaptionLanguageMenuTitle:"Caption language",moreDrawerGalleryOptionsMenuTitle:"Gallery options",peopleButtonLabel:"People",selectedPeopleButtonLabel:"People Button Selected",peopleButtonTooltipOpen:"Show participants",peopleButtonTooltipClose:"Hide participants",peoplePaneSubTitle:"In this call",peoplePaneTitle:"People",pictureInPictureTileAriaLabel:"Video Feeds. Click to return to call screen.",removeMenuLabel:"Remove",openDialpadButtonLabel:"Dial phone number",returnToCallButtonAriaDescription:"Return to Call",returnToCallButtonAriaLabel:"Back",peoplePaneAddPeopleButtonLabel:"Add People",dialpadStartCallButtonLabel:"Call",dialpadModalTitle:"Dial Phone Number",dialpadModalAriaLabel:"Dialpad",dialpadCloseModalButtonAriaLabel:"Close dialpad",openDtmfDialpadLabel:"Show dialpad",dtmfDialpadPlaceholderText:"Enter number"};var en_US = {call:call$k,chat:chat$k,callWithChat:callWithChat$k};
23655
+ var call$k={cameraLabel:"Camera",noCamerasLabel:"No cameras found",cameraPermissionDenied:"Your browser is blocking access to your camera",cameraTurnedOff:"Your camera is turned off",chatButtonLabel:"Chat",close:"Close",complianceBannerNowOnlyRecording:"You are now only recording this meeting.",complianceBannerNowOnlyTranscription:"You are now only transcribing this meeting.",complianceBannerRecordingAndTranscriptionSaved:"Recording and transcription are being saved.",complianceBannerRecordingAndTranscriptionStarted:"Recording and transcription have started.",complianceBannerRecordingAndTranscriptionStopped:"Recording and transcription have stopped.",complianceBannerRecordingSaving:"Recording is being saved.",complianceBannerRecordingStarted:"Recording has started.",complianceBannerRecordingStopped:"Recording has stopped.",complianceBannerTranscriptionStarted:"Transcription has started.",complianceBannerTranscriptionConsent:"By joining, you are giving consent for this meeting to be transcribed.",complianceBannerTranscriptionSaving:"Transcription is being saved.",complianceBannerTranscriptionStopped:"Transcription has stopped.",configurationPageTitle:"Start a call",copyInviteLinkButtonLabel:"Copy invite link",copyInviteLinkActionedAriaLabel:"Invite link copied",defaultPlaceHolder:"Select an option",dismissSidePaneButtonLabel:"Close",videoEffectsPaneTitle:"Effects",videoEffectsPaneBackgroundSelectionTitle:"Background",configurationPageVideoEffectsButtonLabel:"Effects",unableToStartVideoEffect:"Unable to apply video effect.",blurBackgroundEffectButtonLabel:"Blur",blurBackgroundTooltip:"Blur Background",removeBackgroundEffectButtonLabel:"None",removeBackgroundTooltip:"Remove Background",cameraOffBackgroundEffectWarningText:"Your camera is off. Turn on camera to see video effect.",failedToJoinCallDueToNoNetworkMoreDetails:"Call was disconnected due to a network issue. Check your connection and join again.",failedToJoinCallDueToNoNetworkTitle:"Call disconnected",failedToJoinTeamsMeetingReasonAccessDeniedMoreDetails:"You were not granted entry in the call. If this was a mistake, re-join the call.",failedToJoinTeamsMeetingReasonAccessDeniedTitle:"Dismissed from lobby",learnMore:"Learn more",leavingCallTitle:"Leaving...",leftCallMoreDetails:"If this was a mistake, re-join the call.",leftCallTitle:"You left the call",lobbyScreenConnectingToCallTitle:"Joining call",lobbyScreenWaitingToBeAdmittedTitle:"Waiting to be admitted",microphonePermissionDenied:"Your browser is blocking access to your microphone",microphoneToggleInLobbyNotAllowed:"Cannot mute or unmute while in lobby.",mutedMessage:"You're muted",networkReconnectMoreDetails:"Looks like something went wrong. We're trying to get back into the call.",networkReconnectTitle:"Hold on",notInvitedToRoomDetails:"You are not able to join this room because you do not have an invite.",notInvitedToRoomTitle:"Not invited to room",peopleButtonLabel:"People",selectedPeopleButtonLabel:"People Button Selected",peoplePaneTitle:"People",peoplePaneMoreButtonAriaLabel:"More",peopleButtonTooltipOpen:"Show participants",peopleButtonTooltipClose:"Hide participants",peoplePaneSubTitle:"In this call {numberOfPeople}",privacyPolicy:"Privacy policy",rejoinCallButtonLabel:"Re-join call",removedFromCallMoreDetails:"Another participant removed you from the call.",removedFromCallTitle:"You were removed",removeMenuLabel:"Remove",startSpotlightParticipantListMenuLabel:"Spotlight for everyone",addSpotlightParticipantListMenuLabel:"Add spotlight",stopSpotlightParticipantListMenuLabel:"Stop spotlighting",stopSpotlightOnSelfParticipantListMenuLabel:"Exit spotlight",spotlightLimitReachedParticipantListMenuTitle:"Spotlight limit reached",stopAllSpotlightMenuLabel:"Stop all spotlights",returnToCallButtonAriaDescription:"Return to Call",returnToCallButtonAriaLabel:"Back",roomNotFoundDetails:"The room ID provided could not be found.",roomNotFoundTitle:"Room not found",roomNotValidDetails:"This room is not valid at this current time.",roomNotValidTitle:"Room not valid",inviteToRoomRemovedDetails:"Your invite to join this room was removed.",inviteToRoomRemovedTitle:"Invite to room removed",soundLabel:"Sound",noMicrophonesLabel:"No microphones found",noSpeakersLabel:"No speakers found",startCallButtonLabel:"Start call",openDialpadButtonLabel:"Dial phone number",peoplePaneAddPeopleButtonLabel:"Add People",dialpadStartCallButtonLabel:"Call",dialpadModalTitle:"Dial Phone Number",dialpadModalAriaLabel:"Dialpad",dialpadCloseModalButtonAriaLabel:"Close dialpad",moreButtonCallingLabel:"More",resumeCallButtonLabel:"Resume",resumingCallButtonLabel:"Resuming...",resumeCallButtonAriaLabel:"Resume call",resumingCallButtonAriaLabel:"Resume call",holdScreenLabel:"You're on hold",openDtmfDialpadLabel:"Show dialpad",dtmfDialpadPlaceholderText:"Enter number",outboundCallingNoticeString:"Calling...",participantJoinedNoticeString:"{displayName} joined",twoParticipantJoinedNoticeString:"{displayName1} and {displayName2} have joined",threeParticipantJoinedNoticeString:"{displayName1}, {displayName2} and {displayName3} have joined",participantLeftNoticeString:"{displayName} left",twoParticipantLeftNoticeString:"{displayName1} and {displayName2} have left",threeParticipantLeftNoticeString:"{displayName1}, {displayName2} and {displayName3} have left",unnamedParticipantString:"unnamed participant",manyUnnamedParticipantsJoined:"unnamed participant and {numOfParticipants} other participants joined",manyUnnamedParticipantsLeft:"unnamed participant and {numOfParticipants} other participants left",manyParticipantsJoined:"{displayName1}, {displayName2}, {displayName3} and {numOfParticipants} other participants joined",manyParticipantsLeft:"{displayName1}, {displayName2}, {displayName3} and {numOfParticipants} other participants left",liveCaptionsLabel:"Live captions",captionsSettingsLabel:"Caption settings",startCaptionsButtonOnLabel:"Turn on captions",startCaptionsButtonOffLabel:"Turn off captions",startCaptionsButtonTooltipOnContent:"Turn off captions",startCaptionsButtonTooltipOffContent:"Turn on captions",captionsSettingsModalTitle:"Captions Settings",captionsSettingsSpokenLanguageDropdownLabel:"Spoken language",captionsSettingsCaptionLanguageDropdownLabel:"Captions language",captionsSettingsSpokenLanguageDropdownInfoText:"Language that everyone on this call is speaking.",captionsSettingsCaptionLanguageDropdownInfoText:"Captions will appear in this langugage.",captionsSettingsConfirmButtonLabel:"Confirm",captionsSettingsCancelButtonLabel:"Cancel",captionsSettingsModalAriaLabel:"Captions Setting Modal",captionsSettingsCloseModalButtonAriaLabel:"Close Captions Setting",captionsBannerMoreButtonCallingLabel:"More",captionsBannerMoreButtonTooltip:"More options",dismissModalAriaLabel:"Local and remote picture and picture, press enter to return to call",callRejectedTitle:"The call could not be completed",callRejectedMoreDetails:"The person you are trying to reach is unavailable. Please try again later.",callTimeoutTitle:"The call could not be completed",callTimeoutDetails:"The person you are trying to reach is unavailable. Please try again later.",callTimeoutBotTitle:"The call could not be completed",callTimeoutBotDetails:"The service that you are trying to reach is unavailable. Please try again later.",dtmfDialerButtonLabel:"Dialpad",dtmfDialerButtonTooltipOn:"Show dialpad",dtmfDialerButtonTooltipOff:"Hide dialpad",dtmfDialerMoreButtonLabelOn:"Show dialpad",dtmfDialerMoreButtonLabelOff:"Hide dialpad",spokenLanguageStrings:{"ar-ae":"Arabic - U.A.E.","ar-sa":"Arabic - Saudi Arabia","da-dk":"Danish","de-de":"German - Germany","en-au":"English - Australia","en-ca":"English - Canada","en-gb":"English - United Kingdom","en-in":"English - India","en-nz":"English - New Zealand","en-us":"English - United States","es-es":"Spanish - Spain (Modern Sort)","es-mx":"Spanish - Mexico","fi-fi":"Finnish","fr-ca":"French - Canada","fr-fr":"French - France","hi-in":"Hindi","it-it":"Italian - Italy","ja-jp":"Japanese","ko-kr":"Korean","nb-no":"Norwegian (Bokmål)","nl-be":"Dutch - Belgium","nl-nl":"Dutch - Netherlands","pl-pl":"Polish","pt-br":"Portuguese - Brazil","ru-ru":"Russian","sv-se":"Swedish","zh-cn":"Chinese - People's Republic of China","zh-hk":"Chinese - Hong Kong SAR","cs-cz":"Czech","pt-pt":"Portuguese - Portugal","tr-tr":"Turkish","vi-vn":"Vietnamese","th-th":"Thai","he-il":"Hebrew","cy-gb":"Welsh","uk-ua":"Ukrainian","el-gr":"Greek","hu-hu":"Hungarian","ro-ro":"Romanian","sk-sk":"Slovak","zh-tw":"Chinese - Taiwan"},captionLanguageStrings:{ar:"Arabic",da:"Danish",de:"German",en:"English",es:"Spanish",fi:"Finnish","fr-ca":"French - Canada",fr:"French - France",hi:"Hindi",it:"Italian",ja:"Japanese",ko:"Korean",nb:"Norwegian (Bokmål)",nl:"Dutch",pl:"Polish",pt:"Portuguese - Brazil",ru:"Russian",sv:"Swedish","zh-Hans":"Chinese (Simplified)","zh-Hant":"Chinese (Traditional)",cs:"Czech","pt-pt":"Portuguese - Portugal",tr:"Turkish",vi:"Vietnamese",th:"Thai",he:"Hebrew",cy:"Welsh",uk:"Ukrainian",el:"Greek",hu:"Hungarian",ro:"Romanian",sk:"Slovak"},captionsBannerSpinnerText:"Starting captions...",transferPageTransferorText:"Transferring...",transferPageTransferTargetText:"Connecting...",transferPageUnknownTransferorDisplayName:"Unknown",transferPageUnknownTransferTargetDisplayName:"Unknown",transferPageNoticeString:"You are being transferred",participantCouldNotBeReachedTitle:"Target participant is currently not available",participantCouldNotBeReachedMoreDetails:"Please contact participant when they are available",permissionToReachTargetParticipantNotAllowedTitle:"Permission to reach target participant is not allowed",permissionToReachTargetParticipantNotAllowedMoreDetails:"Please check that the target participant is in the same tenant",unableToResolveTenantTitle:"Unable to resolve tenant id for the target participant",unableToResolveTenantMoreDetails:"Please check the participant id is entered correctly",participantIdIsMalformedTitle:"Participant id is not in the correct format",participantIdIsMalformedMoreDetails:"Please check that the participant id is in the correct format",moreButtonGalleryControlLabel:"View",moreButtonGalleryPositionToggleLabel:"Move gallery to top",moreButtonGallerySpeakerLayoutLabel:"Speaker",moreButtonGalleryFloatingLocalLayoutLabel:"Dynamic",moreButtonGalleryDefaultLayoutLabel:"Gallery view",moreButtonGalleryFocusedContentLayoutLabel:"Focus on content",moreButtonLargeGalleryDefaultLayoutLabel:"Large Gallery",capabilityChangedNotification:{turnVideoOn:{lostDueToMeetingOption:"Your camera has been disabled. You can no longer share video.",grantedDueToMeetingOption:"Your camera has been enabled. Turn it on if you'd like to share video."},unmuteMic:{lostDueToMeetingOption:"Your mic has been disabled. You can no longer unmute.",grantedDueToMeetingOption:"Your mic has been enabled. Unmute if you'd like to speak."},shareScreen:{lostDueToRoleChangeToAttendee:"Your role has been changed. Some actions, like sharing content, won't be available to you.",grantedDueToRoleChangeToPresenter:"You're a presenter. You can share content and facilitate the meeting."}},surveyTitle:"Help us improve",starSurveyHelperText:"How was the quality of the call?",starSurveyOneStarText:"The quality was bad.",starSurveyTwoStarText:"The quality was poor.",starSurveyThreeStarText:"The quality was good.",starSurveyFourStarText:"The quality was great.",starSurveyFiveStarText:"The quality was excellent.",surveyConfirmButtonLabel:"Send Feedback",starRatingAriaLabel:"Select {0} of {1} stars",surveySkipButtonLabel:"Skip",tagsSurveyQuestion:"What could have been better?",tagsSurveyTextFieldDefaultText:"Other, please specify",tagsSurveyHelperText:"Check any issues you experienced",surveyTextboxDefaultText:"Other, please specify",endOfSurveyText:"Thank you for your feedback!",surveyIssues:{overallRating:{callCannotJoin:"I could not join call",callCannotInvite:"I could not invite others into the call",hadToRejoin:"I had to rejoin the call",callEndedUnexpectedly:"Call ended for me unexpectedly",otherIssues:"I was having other issues with the call"},audioRating:{noLocalAudio:"The other side could not hear any sound",noRemoteAudio:"I could not hear any sound",echo:"I heard echos on the call",audioNoise:"I heard noise on the call",lowVolume:"Volume was low",audioStoppedUnexpectedly:"Audio stopped unexpectedly",distortedSpeech:"Audio was distorted",audioInterruption:"Audio was interrupted",otherIssues:"I was having other audio issues in this call"},videoRating:{noVideoReceived:"I could not see any video",noVideoSent:"Others could not see me",lowQuality:"Video quality was low",freezes:"Video frozen",stoppedUnexpectedly:"Video stopped unexpectedly",darkVideoReceived:"I can only see dark screens when others turn on their camera",audioVideoOutOfSync:"Audio and Video was out of sync",otherIssues:"I was having other video issues in this call"},screenshareRating:{noContentLocal:"Other people could not see my screenshare",noContentRemote:"I could not see other people's screenshare",cannotPresent:"I could not present my screen",lowQuality:"Screen share quality was low",freezes:"Screen share frozen",stoppedUnexpectedly:"Screen share stopped unexpectedly",largeDelay:"Screen share has a large delay",otherIssues:"I was having other screen share issues in this call"}},SurveyIssuesHeadingStrings:{overallRating:"Overall",audioRating:"Audio",videoRating:"Video",screenshareRating:"Presenting"},spotlightPrompt:{startSpotlightHeading:"Spotlight for everyone?",startSpotlightText:"You'll highlight this video for everyone in the meeting.",startSpotlightOnSelfText:"You'll highlight your video for everyone in the meeting.",startSpotlightConfirmButtonLabel:"Spotlight for everyone",startSpotlightCancelButtonLabel:"Cancel",stopSpotlightHeading:"Stop spotlighting this video?",stopSpotlightOnSelfHeading:"Exit spotlight?",stopSpotlightText:"This video will no longer be highlighted for everyone in the meeting.",stopSpotlightOnSelfText:"Your video will no longer be highlighted for everyone in the meeting.",stopSpotlightConfirmButtonLabel:"Stop spotlighting",stopSpotlightOnSelfConfirmButtonLabel:"Exit spotlight",stopSpotlightCancelButtonLabel:"Cancel"},exitSpotlightButtonLabel:"Exit spotlight",exitSpotlightButtonTooltip:"Exit spotlight"};var chat$k={chatListHeader:"In this chat",uploadFile:"Upload File"};var callWithChat$k={chatButtonLabel:"Chat",chatButtonNewMessageNotificationLabel:"New Message",chatButtonTooltipClosedWithMessageCount:"Show chat ({unreadMessagesCount} unread)",chatButtonTooltipClose:"Hide chat",chatButtonTooltipOpen:"Show chat",chatPaneTitle:"Chat",copyInviteLinkButtonLabel:"Copy invite link",copyInviteLinkActionedAriaLabel:"Invite link copied",dismissSidePaneButtonLabel:"Close",moreDrawerAudioDeviceMenuTitle:"Audio Device",moreDrawerButtonLabel:"More options",moreDrawerButtonTooltip:"More options",moreDrawerMicrophoneMenuTitle:"Microphone",moreDrawerSpeakerMenuTitle:"Speaker",moreDrawerCaptionsMenuTitle:"Live captions",moreDrawerSpokenLanguageMenuTitle:"Spoken language",moreDrawerCaptionLanguageMenuTitle:"Caption language",moreDrawerGalleryOptionsMenuTitle:"Gallery options",peopleButtonLabel:"People",selectedPeopleButtonLabel:"People Button Selected",peopleButtonTooltipOpen:"Show participants",peopleButtonTooltipClose:"Hide participants",peoplePaneSubTitle:"In this call",peoplePaneTitle:"People",pictureInPictureTileAriaLabel:"Video Feeds. Click to return to call screen.",removeMenuLabel:"Remove",openDialpadButtonLabel:"Dial phone number",returnToCallButtonAriaDescription:"Return to Call",returnToCallButtonAriaLabel:"Back",peoplePaneAddPeopleButtonLabel:"Add People",dialpadStartCallButtonLabel:"Call",dialpadModalTitle:"Dial Phone Number",dialpadModalAriaLabel:"Dialpad",dialpadCloseModalButtonAriaLabel:"Close dialpad",openDtmfDialpadLabel:"Show dialpad",dtmfDialpadPlaceholderText:"Enter number"};var en_US = {call:call$k,chat:chat$k,callWithChat:callWithChat$k};
23650
23656
 
23651
23657
  // Copyright (c) Microsoft Corporation.
23652
23658
  // Licensed under the MIT License.
@@ -24129,7 +24135,7 @@ class AzureCommunicationChatAdapter {
24129
24135
  return __awaiter$n(this, void 0, void 0, function* () {
24130
24136
  return yield this.asyncTeeErrorToEventEmitter(() => __awaiter$n(this, void 0, void 0, function* () {
24131
24137
  /* @conditional-compile-remove(file-sharing) */
24132
- const updatedOptions = options ? { attachmentMetadata: options.attachmentMetadata, metadata: metadata } : {};
24138
+ const updatedOptions = { attachmentMetadata: options === null || options === void 0 ? void 0 : options.attachmentMetadata, metadata: metadata };
24133
24139
  /* @conditional-compile-remove(file-sharing) */
24134
24140
  return yield this.handlers.onUpdateMessage(messageId, content, updatedOptions);
24135
24141
  }));
@@ -25143,28 +25149,17 @@ const ChatScreen = (props) => {
25143
25149
  const errorBarProps = usePropsFor$2(ErrorBar);
25144
25150
  /* @conditional-compile-remove(image-overlay) */
25145
25151
  React.useEffect(() => {
25146
- var _a;
25147
25152
  if (overlayImageItem === undefined) {
25148
25153
  return;
25149
25154
  }
25150
- const messages = messageThreadProps.messages.filter((message) => {
25151
- return message.messageId === (overlayImageItem === null || overlayImageItem === void 0 ? void 0 : overlayImageItem.messageId);
25152
- });
25153
- if (messages.length <= 0 || messages[0].messageType !== 'chat') {
25154
- return;
25155
- }
25156
- const message = messages[0];
25157
- if (overlayImageItem.imageSrc === '' && message.inlineImages && ((_a = message.inlineImages) === null || _a === void 0 ? void 0 : _a.length) > 0) {
25158
- const inlineImages = message.inlineImages.filter((attachment) => {
25159
- return attachment.id === (overlayImageItem === null || overlayImageItem === void 0 ? void 0 : overlayImageItem.attachmentId);
25160
- });
25161
- if (inlineImages.length <= 0 ||
25162
- inlineImages[0].fullSizeImageSrc === undefined ||
25163
- inlineImages[0].fullSizeImageSrc === '' ||
25164
- overlayImageItem.imageSrc === inlineImages[0].fullSizeImageSrc) {
25155
+ const message = adapter.getState().thread.chatMessages[overlayImageItem === null || overlayImageItem === void 0 ? void 0 : overlayImageItem.messageId];
25156
+ const resourceCache = message.resourceCache;
25157
+ if (overlayImageItem.imageSrc === '' && resourceCache) {
25158
+ const fullSizeImageSrc = resourceCache[overlayImageItem.imageUrl];
25159
+ if (fullSizeImageSrc === undefined || fullSizeImageSrc === '' || overlayImageItem.imageSrc === fullSizeImageSrc) {
25165
25160
  return;
25166
25161
  }
25167
- setOverlayImageItem(Object.assign(Object.assign({}, overlayImageItem), { imageSrc: inlineImages[0].fullSizeImageSrc }));
25162
+ setOverlayImageItem(Object.assign(Object.assign({}, overlayImageItem), { imageSrc: fullSizeImageSrc }));
25168
25163
  }
25169
25164
  // Disable eslint because we are using the overlayImageItem in this effect but don't want to have it as a dependency, as it will cause an infinite loop.
25170
25165
  // eslint-disable-next-line react-hooks/exhaustive-deps
@@ -25198,44 +25193,47 @@ const ChatScreen = (props) => {
25198
25193
  /* @conditional-compile-remove(image-overlay) */
25199
25194
  const onInlineImageClicked = React.useCallback((attachmentId, messageId) => __awaiter$l(void 0, void 0, void 0, function* () {
25200
25195
  var _a, _b;
25201
- const messages = (_a = messageThreadProps.messages) === null || _a === void 0 ? void 0 : _a.filter((message) => {
25202
- return message.messageId === messageId;
25203
- });
25204
- if (!messages || messages.length <= 0) {
25205
- return;
25206
- }
25207
- const chatMessage = messages[0];
25208
- const inlinedImages = (_b = chatMessage.inlineImages) === null || _b === void 0 ? void 0 : _b.filter((attachment) => {
25209
- return attachment.id === attachmentId;
25196
+ const message = adapter.getState().thread.chatMessages[messageId];
25197
+ const inlinedImages = (_b = (_a = message.content) === null || _a === void 0 ? void 0 : _a.attachments) === null || _b === void 0 ? void 0 : _b.filter((attachment) => {
25198
+ return attachment.attachmentType === 'image' && attachment.id === attachmentId;
25210
25199
  });
25211
25200
  if (!inlinedImages || inlinedImages.length <= 0) {
25212
25201
  return;
25213
25202
  }
25214
25203
  const attachment = inlinedImages[0];
25204
+ const resourceCache = message.resourceCache;
25205
+ let imageSrc = '';
25206
+ if (attachment.url) {
25207
+ if (resourceCache && resourceCache[attachment.url]) {
25208
+ imageSrc = resourceCache[attachment.url];
25209
+ }
25210
+ else {
25211
+ adapter.downloadResourceToCache({
25212
+ threadId: adapter.getState().thread.threadId,
25213
+ messageId: messageId,
25214
+ resourceUrl: attachment.url
25215
+ });
25216
+ }
25217
+ }
25215
25218
  const titleIconRenderOptions = {
25216
- text: chatMessage.senderDisplayName,
25219
+ text: message.senderDisplayName,
25217
25220
  size: react.PersonaSize.size32,
25218
25221
  showOverflowTooltip: false,
25219
- imageAlt: chatMessage.senderDisplayName
25222
+ imageAlt: message.senderDisplayName
25220
25223
  };
25221
- const titleIcon = onRenderAvatarCallback && onRenderAvatarCallback(chatMessage.senderId, titleIconRenderOptions);
25224
+ const messageSenderId = message.sender !== undefined ? toFlatCommunicationIdentifier(message.sender) : userId;
25225
+ const titleIcon = onRenderAvatarCallback && onRenderAvatarCallback(messageSenderId, titleIconRenderOptions);
25222
25226
  const overlayImage = {
25223
- title: chatMessage.senderDisplayName || '',
25227
+ title: message.senderDisplayName || '',
25224
25228
  titleIcon: titleIcon,
25225
25229
  attachmentId: attachment.id,
25226
- imageSrc: attachment.fullSizeImageSrc || '',
25227
- messageId: messageId
25230
+ imageSrc: imageSrc,
25231
+ messageId: messageId,
25232
+ imageUrl: attachment.url || ''
25228
25233
  };
25229
25234
  setIsImageOverlayOpen(true);
25230
25235
  setOverlayImageItem(overlayImage);
25231
- if (attachment.attachmentType === 'inlineImage' && attachment.url) {
25232
- adapter.downloadResourceToCache({
25233
- threadId: adapter.getState().thread.threadId,
25234
- messageId: messageId,
25235
- resourceUrl: attachment.url
25236
- });
25237
- }
25238
- }), [adapter, messageThreadProps, onRenderAvatarCallback]);
25236
+ }), [adapter, onRenderAvatarCallback, userId]);
25239
25237
  /* @conditional-compile-remove(image-overlay) */
25240
25238
  const inlineImageOptions = {
25241
25239
  onRenderInlineImage: (inlineImage, defaultOnRender) => {
@@ -25306,6 +25304,11 @@ const ChatScreen = (props) => {
25306
25304
  overlayImageItem && (React.createElement(ImageOverlay, Object.assign({}, overlayImageItem, { isOpen: isImageOverlayOpen, onDismiss: () => {
25307
25305
  setOverlayImageItem(undefined);
25308
25306
  setIsImageOverlayOpen(false);
25307
+ adapter.removeResourceFromCache({
25308
+ threadId: adapter.getState().thread.threadId,
25309
+ messageId: overlayImageItem.messageId,
25310
+ resourceUrl: overlayImageItem.imageUrl
25311
+ });
25309
25312
  }, onDownloadButtonClicked: onDownloadButtonClicked })))));
25310
25313
  };
25311
25314
 
@@ -26139,6 +26142,10 @@ const createCompositeHandlers = memoizeOne((adapter) => {
26139
26142
  yield adapter.stopSpotlight(userIds);
26140
26143
  }),
26141
26144
  /* @conditional-compile-remove(spotlight) */
26145
+ onStopAllSpotlight: () => __awaiter$j(void 0, void 0, void 0, function* () {
26146
+ yield adapter.stopAllSpotlight();
26147
+ }),
26148
+ /* @conditional-compile-remove(spotlight) */
26142
26149
  onStartLocalSpotlight: () => __awaiter$j(void 0, void 0, void 0, function* () {
26143
26150
  yield adapter.startSpotlight();
26144
26151
  }),
@@ -27875,7 +27882,7 @@ const DtmfDialpadButton = (props) => {
27875
27882
  * @private
27876
27883
  */
27877
27884
  const ExitSpotlightButton = (props) => {
27878
- return (React.createElement(ControlBarButton, Object.assign({ "data-ui-id": 'call-composite-exit-spotlight-button', labelKey: 'exitSpotlightButtonLabelKey', showLabel: props.displayType !== 'compact', onRenderIcon: () => React.createElement(_HighContrastAwareIcon, { iconName: 'StopSpotlightContextualMenuItem' }), onClick: props.onClick }, props)));
27885
+ return (React.createElement(ControlBarButton, Object.assign({ "data-ui-id": 'call-composite-exit-spotlight-button', labelKey: 'exitSpotlightButtonLabelKey', showLabel: props.displayType !== 'compact', onRenderIcon: () => React.createElement(_HighContrastAwareIcon, { iconName: 'ControlButtonExitSpotlight' }), onClick: props.onClick }, props)));
27879
27886
  };
27880
27887
 
27881
27888
  // Copyright (c) Microsoft Corporation.
@@ -28814,7 +28821,14 @@ const mobilePaneControlBarStyle = { root: { height: '3rem' } };
28814
28821
  * @private
28815
28822
  */
28816
28823
  const mobilePaneBackButtonStyles = {
28817
- root: { border: 'none', minWidth: '2.5rem', height: '100%', background: 'none', padding: '0 1rem' },
28824
+ root: {
28825
+ border: 'none',
28826
+ minWidth: '2.5rem',
28827
+ maxWidth: '2.875rem',
28828
+ height: '100%',
28829
+ background: 'none',
28830
+ padding: '0 1rem'
28831
+ },
28818
28832
  rootChecked: { background: 'none' },
28819
28833
  rootCheckedHovered: { background: 'none' }
28820
28834
  };
@@ -28945,7 +28959,11 @@ const PeopleAndChatHeader = (props) => {
28945
28959
  React.createElement(react.Stack, { horizontal: true, styles: availableSpaceStyles },
28946
28960
  React.createElement(react.Stack.Item, { grow: true }, onChatButtonClicked && (React.createElement(react.DefaultButton, { onClick: onChatButtonClicked, styles: mobilePaneButtonStylesThemed, checked: activeTab === 'chat', "aria-selected": activeTab === 'chat', role: 'tab', disabled: props.disableChatButton }, strings.chatButtonLabel))),
28947
28961
  React.createElement(react.Stack.Item, { grow: true }, onPeopleButtonClicked && (React.createElement(react.DefaultButton, { onClick: onPeopleButtonClicked, styles: mobilePaneButtonStylesThemed, checked: activeTab === 'people', "aria-selected": activeTab === 'people', role: 'tab', disabled: props.disablePeopleButton }, strings.peopleButtonLabel)))))),
28948
- React.createElement(react.DefaultButton, { styles: mobilePaneHiddenIconStyles, onRenderIcon: () => React.createElement(CallWithChatCompositeIcon, { iconName: "ChevronLeft" }) })));
28962
+ props.onHeaderMenuClick ? (React.createElement(react.DefaultButton, { ariaLabel: strings.peoplePaneMoreButtonAriaLabel, styles: react.concatStyleSets(mobilePaneBackButtonStyles, {
28963
+ icon: { display: 'flex', alignItems: 'center' }
28964
+ }), iconProps: { iconName: 'PeoplePaneMoreButton' }, onClick: props.onHeaderMenuClick })) : (
28965
+ /* Hidden icon to take the same space as the actual back button on the left. */
28966
+ React.createElement(react.DefaultButton, { styles: mobilePaneHiddenIconStyles, onRenderIcon: () => React.createElement(CallWithChatCompositeIcon, { iconName: "ChevronLeft" }) }))));
28949
28967
  };
28950
28968
 
28951
28969
  // Copyright (c) Microsoft Corporation.
@@ -28978,13 +28996,14 @@ const SidePane = (props) => {
28978
28996
  var _a;
28979
28997
  return (React.createElement(PeopleAndChatHeader, { onClose: overrideSidePaneId === 'chat' ? (_a = props.onChatButtonClicked) !== null && _a !== void 0 ? _a : noop : closePane, activeTab: (sidePaneRenderer === null || sidePaneRenderer === void 0 ? void 0 : sidePaneRenderer.id) === 'people' ? 'people' : 'chat',
28980
28998
  // legacy arguments to be removed in breaking change:
28981
- disablePeopleButton: props.disablePeopleButton, disableChatButton: props.disableChatButton, onPeopleButtonClicked: (sidePaneRenderer === null || sidePaneRenderer === void 0 ? void 0 : sidePaneRenderer.id) === 'people' ? noop : props.onPeopleButtonClicked, onChatButtonClicked: overrideSidePaneId === 'chat' ? noop : props.onChatButtonClicked }));
28999
+ disablePeopleButton: props.disablePeopleButton, disableChatButton: props.disableChatButton, onPeopleButtonClicked: (sidePaneRenderer === null || sidePaneRenderer === void 0 ? void 0 : sidePaneRenderer.id) === 'people' ? noop : props.onPeopleButtonClicked, onChatButtonClicked: overrideSidePaneId === 'chat' ? noop : props.onChatButtonClicked, onHeaderMenuClick: props.onHeaderMenuClick }));
28982
29000
  }, [
28983
29001
  overrideSidePaneId,
28984
29002
  props.onChatButtonClicked,
28985
29003
  props.onPeopleButtonClicked,
28986
29004
  props.disablePeopleButton,
28987
29005
  props.disableChatButton,
29006
+ props.onHeaderMenuClick,
28988
29007
  sidePaneRenderer === null || sidePaneRenderer === void 0 ? void 0 : sidePaneRenderer.id,
28989
29008
  closePane
28990
29009
  ]);
@@ -29019,6 +29038,7 @@ const EmptyElement = () => React.createElement(React.Fragment, null);
29019
29038
  * @private
29020
29039
  */
29021
29040
  const SidePaneHeader = (props) => {
29041
+ var _a;
29022
29042
  const theme = useTheme();
29023
29043
  const sidePaneCloseButtonStyles = React.useMemo(() => ({
29024
29044
  root: {
@@ -29035,7 +29055,11 @@ const SidePaneHeader = (props) => {
29035
29055
  return React.createElement(SidePaneMobileHeader, Object.assign({}, props));
29036
29056
  }
29037
29057
  return (React.createElement(react.Stack, { horizontal: true, horizontalAlign: "space-between", styles: sidePaneHeaderContainerStyles, verticalAlign: "center" },
29038
- React.createElement(react.Stack.Item, { role: "heading", styles: sidePaneHeaderStyles }, props.headingText),
29058
+ React.createElement(react.Stack.Item /* @conditional-compile-remove(spotlight) */, { grow: true, role: "heading", styles: sidePaneHeaderStyles }, props.headingText),
29059
+ /* @conditional-compile-remove(spotlight) */ ((_a = props.menuProps) === null || _a === void 0 ? void 0 : _a.items) && props.menuProps.items.length > 0 && (React.createElement(react.Stack.Item, null,
29060
+ React.createElement(react.CommandBarButton, { ariaLabel: props.moreSidePaneButtonAriaLabel, styles: react.concatStyleSets(sidePaneCloseButtonStyles, {
29061
+ icon: { display: 'flex', alignItems: 'center' }
29062
+ }), iconProps: { iconName: 'PeoplePaneMoreButton' }, menuProps: props.menuProps, onRenderMenuIcon: () => null }))),
29039
29063
  React.createElement(react.Stack.Item, null,
29040
29064
  React.createElement(react.CommandBarButton, { ariaLabel: props.dismissSidePaneButtonAriaLabel, styles: sidePaneCloseButtonStyles, iconProps: { iconName: 'cancel' }, onClick: props.onClose }))));
29041
29065
  };
@@ -29528,6 +29552,8 @@ const usePeoplePane = (props) => {
29528
29552
  /* @conditional-compile-remove(spotlight) */
29529
29553
  onStopRemoteSpotlight,
29530
29554
  /* @conditional-compile-remove(spotlight) */
29555
+ onStopAllSpotlight,
29556
+ /* @conditional-compile-remove(spotlight) */
29531
29557
  maxParticipantsToSpotlight } = props;
29532
29558
  const closePane = React.useCallback(() => {
29533
29559
  var _a;
@@ -29535,7 +29561,29 @@ const usePeoplePane = (props) => {
29535
29561
  (_a = peopleButtonRef === null || peopleButtonRef === void 0 ? void 0 : peopleButtonRef.current) === null || _a === void 0 ? void 0 : _a.focus();
29536
29562
  }, [peopleButtonRef, updateSidePaneRenderer]);
29537
29563
  const localeStrings = useLocale().strings.call;
29538
- const onRenderHeader = React.useCallback(() => (React.createElement(SidePaneHeader, { onClose: closePane, headingText: localeStrings.peoplePaneTitle, dismissSidePaneButtonAriaLabel: localeStrings.dismissSidePaneButtonLabel, mobileView: mobileView !== null && mobileView !== void 0 ? mobileView : false })), [mobileView, closePane, localeStrings]);
29564
+ /* @conditional-compile-remove(spotlight) */
29565
+ const sidePaneHeaderMenuProps = React.useMemo(() => {
29566
+ const menuItems = [];
29567
+ if (onStopAllSpotlight && spotlightedParticipantUserIds && spotlightedParticipantUserIds.length > 0) {
29568
+ menuItems.push({
29569
+ key: 'stopAllSpotlightKey',
29570
+ text: localeStrings.stopAllSpotlightMenuLabel,
29571
+ iconProps: { iconName: 'StopAllSpotlightMenuButton', styles: { root: { lineHeight: 0 } } },
29572
+ onClick: () => {
29573
+ onStopAllSpotlight();
29574
+ },
29575
+ ariaLabel: localeStrings.stopAllSpotlightMenuLabel
29576
+ });
29577
+ }
29578
+ return {
29579
+ items: menuItems
29580
+ };
29581
+ }, [onStopAllSpotlight, spotlightedParticipantUserIds, localeStrings.stopAllSpotlightMenuLabel]);
29582
+ const onRenderHeader = React.useCallback(() => (React.createElement(SidePaneHeader, { onClose: closePane, headingText: localeStrings.peoplePaneTitle, dismissSidePaneButtonAriaLabel: localeStrings.dismissSidePaneButtonLabel, mobileView: mobileView !== null && mobileView !== void 0 ? mobileView : false,
29583
+ /* @conditional-compile-remove(spotlight) */
29584
+ moreSidePaneButtonAriaLabel: localeStrings.peoplePaneMoreButtonAriaLabel,
29585
+ /* @conditional-compile-remove(spotlight) */
29586
+ menuProps: sidePaneHeaderMenuProps })), [mobileView, closePane, localeStrings, /* @conditional-compile-remove(spotlight) */ sidePaneHeaderMenuProps]);
29539
29587
  /* @conditional-compile-remove(spotlight) */
29540
29588
  const onFetchParticipantMenuItemsForCallComposite = React.useCallback((participantId, myUserId, defaultMenuItems) => {
29541
29589
  const _defaultMenuItems = defaultMenuItems !== null && defaultMenuItems !== void 0 ? defaultMenuItems : [];
@@ -30455,7 +30503,7 @@ const getStopRemoteSpotlightWithPromptCallback = (onStopSpotlight, setIsPromptOp
30455
30503
  * @private
30456
30504
  */
30457
30505
  const CallArrangement = (props) => {
30458
- var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;
30506
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m;
30459
30507
  const containerClassName = React.useMemo(() => {
30460
30508
  return props.mobileView ? containerStyleMobile : containerStyleDesktop;
30461
30509
  }, [props.mobileView]);
@@ -30504,21 +30552,31 @@ const CallArrangement = (props) => {
30504
30552
  const { onStartLocalSpotlightWithPrompt, onStopLocalSpotlightWithPrompt } = useLocalSpotlightCallbacksWithPrompt(onStartLocalSpotlight, onStopLocalSpotlight, setIsPromptOpen, setPromptProps);
30505
30553
  /* @conditional-compile-remove(spotlight) */
30506
30554
  const { onStartRemoteSpotlightWithPrompt, onStopRemoteSpotlightWithPrompt } = useRemoteSpotlightCallbacksWithPrompt(onStartRemoteSpotlight, onStopRemoteSpotlight, setIsPromptOpen, setPromptProps);
30507
- const { isPeoplePaneOpen, openPeoplePane, closePeoplePane } = usePeoplePane(Object.assign(Object.assign({}, peoplePaneProps), {
30508
- /* @conditional-compile-remove(spotlight) */ spotlightedParticipantUserIds: spotlightedParticipants,
30509
- /* @conditional-compile-remove(spotlight) */ onStartLocalSpotlight: hideSpotlightButtons
30510
- ? undefined
30511
- : onStartLocalSpotlightWithPrompt,
30512
- /* @conditional-compile-remove(spotlight) */ onStopLocalSpotlight: hideSpotlightButtons
30513
- ? undefined
30514
- : onStopLocalSpotlightWithPrompt,
30515
- /* @conditional-compile-remove(spotlight) */ onStartRemoteSpotlight: hideSpotlightButtons
30516
- ? undefined
30517
- : onStartRemoteSpotlightWithPrompt,
30518
- /* @conditional-compile-remove(spotlight) */ onStopRemoteSpotlight: hideSpotlightButtons
30519
- ? undefined
30520
- : onStopRemoteSpotlightWithPrompt,
30521
- /* @conditional-compile-remove(spotlight) */ maxParticipantsToSpotlight }));
30555
+ /* @conditional-compile-remove(spotlight) */
30556
+ const canSpotlight = (_c = (_b = adapter.getState().call) === null || _b === void 0 ? void 0 : _b.capabilitiesFeature) === null || _c === void 0 ? void 0 : _c.capabilities.spotlightParticipant.isPresent;
30557
+ const spotlightPeoplePaneProps = React.useMemo(() => {
30558
+ /* @conditional-compile-remove(spotlight) */
30559
+ return {
30560
+ spotlightedParticipantUserIds: spotlightedParticipants,
30561
+ onStartLocalSpotlight: hideSpotlightButtons ? undefined : onStartLocalSpotlightWithPrompt,
30562
+ onStopLocalSpotlight: hideSpotlightButtons ? undefined : onStopLocalSpotlightWithPrompt,
30563
+ onStartRemoteSpotlight: hideSpotlightButtons ? undefined : onStartRemoteSpotlightWithPrompt,
30564
+ onStopRemoteSpotlight: hideSpotlightButtons ? undefined : onStopRemoteSpotlightWithPrompt,
30565
+ onStopAllSpotlight: hideSpotlightButtons || !canSpotlight ? undefined : () => adapter.stopAllSpotlight(),
30566
+ maxParticipantsToSpotlight
30567
+ };
30568
+ }, [
30569
+ /* @conditional-compile-remove(spotlight) */ adapter,
30570
+ /* @conditional-compile-remove(spotlight) */ hideSpotlightButtons,
30571
+ /* @conditional-compile-remove(spotlight) */ maxParticipantsToSpotlight,
30572
+ /* @conditional-compile-remove(spotlight) */ onStartLocalSpotlightWithPrompt,
30573
+ /* @conditional-compile-remove(spotlight) */ onStartRemoteSpotlightWithPrompt,
30574
+ /* @conditional-compile-remove(spotlight) */ onStopLocalSpotlightWithPrompt,
30575
+ /* @conditional-compile-remove(spotlight) */ onStopRemoteSpotlightWithPrompt,
30576
+ /* @conditional-compile-remove(spotlight) */ spotlightedParticipants,
30577
+ /* @conditional-compile-remove(spotlight) */ canSpotlight
30578
+ ]);
30579
+ const { isPeoplePaneOpen, openPeoplePane, closePeoplePane } = usePeoplePane(Object.assign(Object.assign({}, peoplePaneProps), spotlightPeoplePaneProps));
30522
30580
  const togglePeoplePane = React.useCallback(() => {
30523
30581
  if (isPeoplePaneOpen) {
30524
30582
  closePeoplePane();
@@ -30572,7 +30630,7 @@ const CallArrangement = (props) => {
30572
30630
  }, [togglePeoplePane]);
30573
30631
  const drawerContainerStylesValue = React.useMemo(() => drawerContainerStyles(DRAWER_Z_INDEX), []);
30574
30632
  /* @conditional-compile-remove(rooms) */
30575
- const role = (_b = adapter.getState().call) === null || _b === void 0 ? void 0 : _b.role;
30633
+ const role = (_d = adapter.getState().call) === null || _d === void 0 ? void 0 : _d.role;
30576
30634
  let canUnmute = true;
30577
30635
  /* @conditional-compile-remove(rooms) */
30578
30636
  canUnmute = role !== 'Consumer' ? true : false;
@@ -30602,15 +30660,51 @@ const CallArrangement = (props) => {
30602
30660
  /* @conditional-compile-remove(capabilities) */
30603
30661
  // Filter out shareScreen capability notifications if on mobile
30604
30662
  const filteredCapabilitesChangedNotifications = props.mobileView
30605
- ? (_c = props.capabilitiesChangedNotificationBarProps) === null || _c === void 0 ? void 0 : _c.capabilitiesChangedNotifications.filter((notification) => notification.capabilityName !== 'shareScreen')
30606
- : (_d = props.capabilitiesChangedNotificationBarProps) === null || _d === void 0 ? void 0 : _d.capabilitiesChangedNotifications;
30663
+ ? (_e = props.capabilitiesChangedNotificationBarProps) === null || _e === void 0 ? void 0 : _e.capabilitiesChangedNotifications.filter((notification) => notification.capabilityName !== 'shareScreen')
30664
+ : (_f = props.capabilitiesChangedNotificationBarProps) === null || _f === void 0 ? void 0 : _f.capabilitiesChangedNotifications;
30665
+ /* @conditional-compile-remove(spotlight) */
30666
+ const onHeaderMenuClick = React.useMemo(() => {
30667
+ if (!props.mobileView) {
30668
+ return undefined;
30669
+ }
30670
+ const headerMenuItems = [];
30671
+ if (isPeoplePaneOpen) {
30672
+ if (spotlightedParticipants && spotlightedParticipants.length > 0 && !hideSpotlightButtons && canSpotlight) {
30673
+ headerMenuItems.push({
30674
+ itemKey: 'stopAllSpotlightKey',
30675
+ text: locale.strings.call.stopAllSpotlightMenuLabel,
30676
+ iconProps: {
30677
+ iconName: 'StopAllSpotlightMenuButton',
30678
+ styles: { root: { lineHeight: 0 } }
30679
+ },
30680
+ onItemClick: () => {
30681
+ adapter.stopAllSpotlight();
30682
+ setDrawerMenuItems([]);
30683
+ }
30684
+ });
30685
+ }
30686
+ }
30687
+ return headerMenuItems.length > 0
30688
+ ? () => {
30689
+ setDrawerMenuItems(headerMenuItems);
30690
+ }
30691
+ : undefined;
30692
+ }, [
30693
+ props.mobileView,
30694
+ isPeoplePaneOpen,
30695
+ spotlightedParticipants,
30696
+ hideSpotlightButtons,
30697
+ canSpotlight,
30698
+ locale.strings.call.stopAllSpotlightMenuLabel,
30699
+ adapter
30700
+ ]);
30607
30701
  return (React.createElement("div", { ref: containerRef, className: react.mergeStyles(containerDivStyles), id: props.id },
30608
30702
  React.createElement(react.Stack, { verticalFill: true, horizontalAlign: "stretch", className: containerClassName, "data-ui-id": props.dataUiId },
30609
30703
  React.createElement(react.Stack, { reversed: true, horizontal: verticalControlBar, grow: true, styles: callArrangementContainerStyles(verticalControlBar) },
30610
- ((_e = props.callControlProps) === null || _e === void 0 ? void 0 : _e.options) !== false && !isMobileWithActivePane && (React.createElement(react.Stack, { verticalAlign: 'center', className: react.mergeStyles({
30704
+ ((_g = props.callControlProps) === null || _g === void 0 ? void 0 : _g.options) !== false && !isMobileWithActivePane && (React.createElement(react.Stack, { verticalAlign: 'center', className: react.mergeStyles({
30611
30705
  zIndex: CONTROL_BAR_Z_INDEX,
30612
30706
  padding: verticalControlBar ? '0.25rem' : 'unset'
30613
- }) }, isLegacyCallControlEnabled((_f = props.callControlProps) === null || _f === void 0 ? void 0 : _f.options) ? (React.createElement(CallControls, Object.assign({}, props.callControlProps, { containerWidth: containerWidth, containerHeight: containerHeight, isMobile: props.mobileView,
30707
+ }) }, isLegacyCallControlEnabled((_h = props.callControlProps) === null || _h === void 0 ? void 0 : _h.options) ? (React.createElement(CallControls, Object.assign({}, props.callControlProps, { containerWidth: containerWidth, containerHeight: containerHeight, isMobile: props.mobileView,
30614
30708
  /* @conditional-compile-remove(one-to-n-calling) */
30615
30709
  peopleButtonChecked: isPeoplePaneOpen,
30616
30710
  /* @conditional-compile-remove(one-to-n-calling) */
@@ -30635,7 +30729,7 @@ const CallArrangement = (props) => {
30635
30729
  dtmfDialerPresent: props.dtmfDialerPresent, peopleButtonRef: peopleButtonRef, cameraButtonRef: cameraButtonRef,
30636
30730
  /* @conditional-compile-remove(spotlight) */
30637
30731
  onStopLocalSpotlight: localParticipant.spotlight ? onStopLocalSpotlight : undefined }))))),
30638
- ((_g = props.callControlProps) === null || _g === void 0 ? void 0 : _g.options) !== false && showDrawer && (React.createElement(react.Stack, { styles: drawerContainerStylesValue },
30732
+ ((_j = props.callControlProps) === null || _j === void 0 ? void 0 : _j.options) !== false && showDrawer && (React.createElement(react.Stack, { styles: drawerContainerStylesValue },
30639
30733
  React.createElement(PreparedMoreDrawer, { callControls: props.callControlProps.options, onLightDismiss: closeDrawer, onPeopleButtonClicked: onMoreDrawerPeopleClicked,
30640
30734
  /* @conditional-compile-remove(PSTN-calls) */ /* @conditional-compile-remove(one-to-n-calling) */
30641
30735
  disableButtonsForHoldScreen: isInLocalHold,
@@ -30671,7 +30765,9 @@ const CallArrangement = (props) => {
30671
30765
  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)
30672
30766
  ? undefined
30673
30767
  : togglePeoplePane, disablePeopleButton: typeof props.callControlProps.options !== 'boolean' &&
30674
- isDisabled$4((_h = props.callControlProps.options) === null || _h === void 0 ? void 0 : _h.participantsButton), onChatButtonClicked: (_j = props.mobileChatTabHeader) === null || _j === void 0 ? void 0 : _j.onClick, disableChatButton: (_k = props.mobileChatTabHeader) === null || _k === void 0 ? void 0 : _k.disabled }),
30768
+ isDisabled$4((_k = props.callControlProps.options) === null || _k === void 0 ? void 0 : _k.participantsButton), onChatButtonClicked: (_l = props.mobileChatTabHeader) === null || _l === void 0 ? void 0 : _l.onClick, disableChatButton: (_m = props.mobileChatTabHeader) === null || _m === void 0 ? void 0 : _m.disabled,
30769
+ /* @conditional-compile-remove(spotlight) */
30770
+ onHeaderMenuClick: onHeaderMenuClick }),
30675
30771
  props.mobileView && (React.createElement(ModalLocalAndRemotePIP, { modalLayerHostId: props.modalLayerHostId, hidden: !isSidePaneOpen, styles: pipStyles, strings: modalStrings, minDragPosition: minMaxDragPosition.minDragPosition, maxDragPosition: minMaxDragPosition.maxDragPosition, onDismissSidePane: () => {
30676
30772
  closePeoplePane();
30677
30773
  if (props.onCloseChatPane) {
@@ -34348,6 +34444,8 @@ class AzureCommunicationCallAdapter {
34348
34444
  this.startSpotlight.bind(this);
34349
34445
  /* @conditional-compile-remove(spotlight) */
34350
34446
  this.stopSpotlight.bind(this);
34447
+ /* @conditional-compile-remove(spotlight) */
34448
+ this.stopAllSpotlight.bind(this);
34351
34449
  }
34352
34450
  dispose() {
34353
34451
  this.resetDiagnosticsForwarder();
@@ -34821,6 +34919,12 @@ class AzureCommunicationCallAdapter {
34821
34919
  this.handlers.onStopSpotlight(userIds);
34822
34920
  });
34823
34921
  }
34922
+ /* @conditional-compile-remove(spotlight) */
34923
+ stopAllSpotlight() {
34924
+ return __awaiter$5(this, void 0, void 0, function* () {
34925
+ this.handlers.onStopAllSpotlight();
34926
+ });
34927
+ }
34824
34928
  getState() {
34825
34929
  return this.context.getState();
34826
34930
  }
@@ -35585,6 +35689,12 @@ class CallWithChatBackedCallAdapter {
35585
35689
  return this.callWithChatAdapter.stopSpotlight(userIds);
35586
35690
  });
35587
35691
  }
35692
+ /* @conditional-compile-remove(spotlight) */
35693
+ stopAllSpotlight() {
35694
+ return __awaiter$4(this, void 0, void 0, function* () {
35695
+ return this.callWithChatAdapter.stopAllSpotlight();
35696
+ });
35697
+ }
35588
35698
  }
35589
35699
  function callAdapterStateFromCallWithChatAdapterState(callWithChatAdapterState) {
35590
35700
  return {
@@ -36739,6 +36849,12 @@ class AzureCommunicationCallWithChatAdapter {
36739
36849
  return this.callAdapter.stopSpotlight(userIds);
36740
36850
  });
36741
36851
  }
36852
+ /* @conditional-compile-remove(spotlight) */
36853
+ stopAllSpotlight() {
36854
+ return __awaiter$2(this, void 0, void 0, function* () {
36855
+ return this.callAdapter.stopAllSpotlight();
36856
+ });
36857
+ }
36742
36858
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
36743
36859
  on(event, listener) {
36744
36860
  switch (event) {