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

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 (67) hide show
  1. package/dist/communication-react.d.ts +1 -1
  2. package/dist/dist-cjs/communication-react/{RichTextSendBoxWrapper-D1KqCTKr.js → RichTextSendBoxWrapper-UUKnVH43.js} +2 -2
  3. package/dist/dist-cjs/communication-react/{RichTextSendBoxWrapper-D1KqCTKr.js.map → RichTextSendBoxWrapper-UUKnVH43.js.map} +1 -1
  4. package/dist/dist-cjs/communication-react/{index-DikMcJD4.js → index-Db9LOYoW.js} +425 -158
  5. package/dist/dist-cjs/communication-react/index-Db9LOYoW.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-stateful-client/src/CallContext.d.ts +3 -1
  10. package/dist/dist-esm/calling-stateful-client/src/CallContext.js +13 -2
  11. package/dist/dist-esm/calling-stateful-client/src/CallContext.js.map +1 -1
  12. package/dist/dist-esm/calling-stateful-client/src/CallDeclarativeCommon.js +46 -1
  13. package/dist/dist-esm/calling-stateful-client/src/CallDeclarativeCommon.js.map +1 -1
  14. package/dist/dist-esm/calling-stateful-client/src/CallSubscriber.d.ts +2 -1
  15. package/dist/dist-esm/calling-stateful-client/src/CallSubscriber.js +18 -8
  16. package/dist/dist-esm/calling-stateful-client/src/CallSubscriber.js.map +1 -1
  17. package/dist/dist-esm/calling-stateful-client/src/CaptionsSubscriber.d.ts +16 -1
  18. package/dist/dist-esm/calling-stateful-client/src/CaptionsSubscriber.js +38 -2
  19. package/dist/dist-esm/calling-stateful-client/src/CaptionsSubscriber.js.map +1 -1
  20. package/dist/dist-esm/calling-stateful-client/src/Converter.d.ts +6 -1
  21. package/dist/dist-esm/calling-stateful-client/src/Converter.js +8 -1
  22. package/dist/dist-esm/calling-stateful-client/src/Converter.js.map +1 -1
  23. package/dist/dist-esm/chat-component-bindings/src/messageThreadSelector.js +1 -1
  24. package/dist/dist-esm/chat-component-bindings/src/messageThreadSelector.js.map +1 -1
  25. package/dist/dist-esm/chat-stateful-client/src/ChatContext.js +6 -2
  26. package/dist/dist-esm/chat-stateful-client/src/ChatContext.js.map +1 -1
  27. package/dist/dist-esm/chat-stateful-client/src/types/ChatMessageWithStatus.d.ts +1 -1
  28. package/dist/dist-esm/chat-stateful-client/src/types/ChatMessageWithStatus.js.map +1 -1
  29. package/dist/dist-esm/react-components/src/components/CaptionsSettingsModal.js +5 -2
  30. package/dist/dist-esm/react-components/src/components/CaptionsSettingsModal.js.map +1 -1
  31. package/dist/dist-esm/react-components/src/components/Drawer/DrawerMenu.js +19 -8
  32. package/dist/dist-esm/react-components/src/components/Drawer/DrawerMenu.js.map +1 -1
  33. package/dist/dist-esm/react-components/src/components/Drawer/DrawerMenuItem.d.ts +4 -0
  34. package/dist/dist-esm/react-components/src/components/Drawer/DrawerMenuItem.js.map +1 -1
  35. package/dist/dist-esm/react-components/src/components/Drawer/ReactionDrawerMenuItem.d.ts +29 -0
  36. package/dist/dist-esm/react-components/src/components/Drawer/ReactionDrawerMenuItem.js +60 -0
  37. package/dist/dist-esm/react-components/src/components/Drawer/ReactionDrawerMenuItem.js.map +1 -0
  38. package/dist/dist-esm/react-components/src/components/Drawer/index.d.ts +2 -0
  39. package/dist/dist-esm/react-components/src/components/Drawer/index.js +2 -0
  40. package/dist/dist-esm/react-components/src/components/Drawer/index.js.map +1 -1
  41. package/dist/dist-esm/react-components/src/components/ImageOverlay.js +16 -8
  42. package/dist/dist-esm/react-components/src/components/ImageOverlay.js.map +1 -1
  43. package/dist/dist-esm/react-components/src/components/styles/ReactionButton.styles.d.ts +12 -0
  44. package/dist/dist-esm/react-components/src/components/styles/ReactionButton.styles.js +47 -3
  45. package/dist/dist-esm/react-components/src/components/styles/ReactionButton.styles.js.map +1 -1
  46. package/dist/dist-esm/react-components/src/theming/themes.js +1 -1
  47. package/dist/dist-esm/react-components/src/theming/themes.js.map +1 -1
  48. package/dist/dist-esm/react-composites/src/composites/CallComposite/adapter/AzureCommunicationCallAdapter.d.ts +1 -0
  49. package/dist/dist-esm/react-composites/src/composites/CallComposite/adapter/AzureCommunicationCallAdapter.js +43 -15
  50. package/dist/dist-esm/react-composites/src/composites/CallComposite/adapter/AzureCommunicationCallAdapter.js.map +1 -1
  51. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/CallArrangement.js +11 -3
  52. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/CallArrangement.js.map +1 -1
  53. package/dist/dist-esm/react-composites/src/composites/ChatComposite/ChatScreen.js +1 -1
  54. package/dist/dist-esm/react-composites/src/composites/ChatComposite/ChatScreen.js.map +1 -1
  55. package/dist/dist-esm/react-composites/src/composites/common/CaptionsBanner.d.ts +1 -0
  56. package/dist/dist-esm/react-composites/src/composites/common/CaptionsBanner.js +1 -1
  57. package/dist/dist-esm/react-composites/src/composites/common/CaptionsBanner.js.map +1 -1
  58. package/dist/dist-esm/react-composites/src/composites/common/ControlBar/CommonCallControlBar.d.ts +1 -0
  59. package/dist/dist-esm/react-composites/src/composites/common/ControlBar/CommonCallControlBar.js +1 -1
  60. package/dist/dist-esm/react-composites/src/composites/common/ControlBar/CommonCallControlBar.js.map +1 -1
  61. package/dist/dist-esm/react-composites/src/composites/common/Drawer/MoreDrawer.d.ts +4 -0
  62. package/dist/dist-esm/react-composites/src/composites/common/Drawer/MoreDrawer.js +32 -21
  63. package/dist/dist-esm/react-composites/src/composites/common/Drawer/MoreDrawer.js.map +1 -1
  64. package/dist/dist-esm/react-composites/src/composites/common/Drawer/PreparedMoreDrawer.d.ts +3 -0
  65. package/dist/dist-esm/react-composites/src/composites/common/Drawer/PreparedMoreDrawer.js.map +1 -1
  66. package/package.json +1 -1
  67. 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-202403150012';
177
177
 
178
178
 
179
179
  var telemetryVersion$1 = /*@__PURE__*/getDefaultExportFromCjs(telemetryVersion);
@@ -1886,9 +1886,16 @@ function convertFromSDKToDeclarativeVideoStreamRendererView(view) {
1886
1886
  /**
1887
1887
  * @private
1888
1888
  */
1889
- function convertFromSDKToCaptionInfoState(caption) {
1889
+ function convertFromTeamsSDKToCaptionInfoState(caption) {
1890
1890
  return Object.assign({}, caption);
1891
1891
  }
1892
+ /* @conditional-compile-remove(acs-close-captions) */
1893
+ /**
1894
+ * @private
1895
+ */
1896
+ function convertFromSDKToCaptionInfoState(caption) {
1897
+ return Object.assign({ captionText: caption.spokenText }, caption);
1898
+ }
1892
1899
  /* @conditional-compile-remove(video-background-effects) */
1893
1900
  /** @private */
1894
1901
  function convertFromSDKToDeclarativeVideoStreamVideoEffects(videoEffects) {
@@ -2683,7 +2690,7 @@ let CallContext$2 = class CallContext {
2683
2690
  }
2684
2691
  }
2685
2692
  /* @conditional-compile-remove(close-captions) */
2686
- addCaption(callId, caption) {
2693
+ addTeamsCaption(callId, caption) {
2687
2694
  this.modifyState((draft) => {
2688
2695
  const call = draft.calls[this._callIdHistory.latestCallId(callId)];
2689
2696
  if (call) {
@@ -2691,11 +2698,20 @@ let CallContext$2 = class CallContext {
2691
2698
  if (caption.captionLanguage.toUpperCase() === currentCaptionLanguage.toUpperCase() ||
2692
2699
  currentCaptionLanguage === '' ||
2693
2700
  currentCaptionLanguage === undefined) {
2694
- this.processNewCaption(call.captionsFeature.captions, convertFromSDKToCaptionInfoState(caption));
2701
+ this.processNewCaption(call.captionsFeature.captions, convertFromTeamsSDKToCaptionInfoState(caption));
2695
2702
  }
2696
2703
  }
2697
2704
  });
2698
2705
  }
2706
+ /* @conditional-compile-remove(acs-close-captions) */
2707
+ addCaption(callId, caption) {
2708
+ this.modifyState((draft) => {
2709
+ const call = draft.calls[this._callIdHistory.latestCallId(callId)];
2710
+ if (call) {
2711
+ this.processNewCaption(call.captionsFeature.captions, convertFromSDKToCaptionInfoState(caption));
2712
+ }
2713
+ });
2714
+ }
2699
2715
  /* @conditional-compile-remove(close-captions) */
2700
2716
  clearCaptions(callId) {
2701
2717
  this.modifyState((draft) => {
@@ -2849,7 +2865,7 @@ function clearParticipantReactionState(callContext, callId, participantKey) {
2849
2865
  /**
2850
2866
  * @private
2851
2867
  */
2852
- class CaptionsSubscriber {
2868
+ class TeamsCaptionsSubscriber {
2853
2869
  constructor(callIdRef, context, captions) {
2854
2870
  this.subscribe = () => {
2855
2871
  this._captions.on('CaptionsActiveChanged', this.isCaptionsActiveChanged);
@@ -2864,7 +2880,7 @@ class CaptionsSubscriber {
2864
2880
  this._captions.off('SpokenLanguageChanged', this.isSpokenLanguageChanged);
2865
2881
  };
2866
2882
  this.onCaptionsReceived = (caption) => {
2867
- this._context.addCaption(this._callIdRef.callId, caption);
2883
+ this._context.addTeamsCaption(this._callIdRef.callId, caption);
2868
2884
  };
2869
2885
  this.isCaptionsActiveChanged = () => {
2870
2886
  this._context.setIsCaptionActive(this._callIdRef.callId, this._captions.isCaptionsFeatureActive);
@@ -2890,6 +2906,42 @@ class CaptionsSubscriber {
2890
2906
  this.subscribe();
2891
2907
  }
2892
2908
  }
2909
+ /* @conditional-compile-remove(acs-close-captions) */
2910
+ /**
2911
+ * @private
2912
+ */
2913
+ class CaptionsSubscriber {
2914
+ constructor(callIdRef, context, captions) {
2915
+ this.subscribe = () => {
2916
+ this._captions.on('CaptionsActiveChanged', this.isCaptionsActiveChanged);
2917
+ this._captions.on('SpokenLanguageChanged', this.isSpokenLanguageChanged);
2918
+ this._captions.on('CaptionsReceived', this.onCaptionsReceived);
2919
+ };
2920
+ this.unsubscribe = () => {
2921
+ this._captions.off('CaptionsActiveChanged', this.isCaptionsActiveChanged);
2922
+ this._captions.off('SpokenLanguageChanged', this.isSpokenLanguageChanged);
2923
+ this._captions.off('CaptionsReceived', this.onCaptionsReceived);
2924
+ };
2925
+ this.onCaptionsReceived = (caption) => {
2926
+ this._context.addCaption(this._callIdRef.callId, caption);
2927
+ };
2928
+ this.isCaptionsActiveChanged = () => {
2929
+ this._context.setIsCaptionActive(this._callIdRef.callId, this._captions.isCaptionsFeatureActive);
2930
+ };
2931
+ this.isSpokenLanguageChanged = () => {
2932
+ this._context.setSelectedSpokenLanguage(this._callIdRef.callId, this._captions.activeSpokenLanguage);
2933
+ };
2934
+ this._callIdRef = callIdRef;
2935
+ this._context = context;
2936
+ this._captions = captions;
2937
+ if (this._captions.isCaptionsFeatureActive) {
2938
+ this._context.setIsCaptionActive(this._callIdRef.callId, this._captions.isCaptionsFeatureActive);
2939
+ }
2940
+ this._context.setAvailableSpokenLanguages(this._callIdRef.callId, this._captions.supportedSpokenLanguages);
2941
+ this._context.setSelectedSpokenLanguage(this._callIdRef.callId, this._captions.activeSpokenLanguage);
2942
+ this.subscribe();
2943
+ }
2944
+ }
2893
2945
 
2894
2946
  // Copyright (c) Microsoft Corporation.
2895
2947
  // Licensed under the MIT License.
@@ -4035,7 +4087,7 @@ class CallSubscriber {
4035
4087
  }
4036
4088
  };
4037
4089
  this.unsubscribe = () => {
4038
- var _a, _b, _c;
4090
+ var _a, _b, _c, _d;
4039
4091
  this._call.off('stateChanged', this.stateChanged);
4040
4092
  /* @conditional-compile-remove(close-captions) */
4041
4093
  this._call.off('stateChanged', this.initCaptionSubscriber);
@@ -4067,13 +4119,15 @@ class CallSubscriber {
4067
4119
  /* @conditional-compile-remove(ppt-live) */
4068
4120
  this._pptLiveSubscriber.unsubscribe();
4069
4121
  /* @conditional-compile-remove(close-captions) */
4070
- (_a = this._captionsSubscriber) === null || _a === void 0 ? void 0 : _a.unsubscribe();
4122
+ (_a = this._TeamsCaptionsSubscriber) === null || _a === void 0 ? void 0 : _a.unsubscribe();
4123
+ /* @conditional-compile-remove(acs-close-captions) */
4124
+ (_b = this._CaptionsSubscriber) === null || _b === void 0 ? void 0 : _b.unsubscribe();
4071
4125
  /* @conditional-compile-remove(raise-hand) */
4072
- (_b = this._raiseHandSubscriber) === null || _b === void 0 ? void 0 : _b.unsubscribe();
4126
+ (_c = this._raiseHandSubscriber) === null || _c === void 0 ? void 0 : _c.unsubscribe();
4073
4127
  /* @conditional-compile-remove(capabilities) */
4074
4128
  this._capabilitiesSubscriber.unsubscribe();
4075
4129
  /* @conditional-compile-remove(reaction) */
4076
- (_c = this._reactionSubscriber) === null || _c === void 0 ? void 0 : _c.unsubscribe();
4130
+ (_d = this._reactionSubscriber) === null || _d === void 0 ? void 0 : _d.unsubscribe();
4077
4131
  /* @conditional-compile-remove(spotlight) */
4078
4132
  this._spotlightSubscriber.unsubscribe();
4079
4133
  };
@@ -4083,11 +4137,17 @@ class CallSubscriber {
4083
4137
  /* @conditional-compile-remove(close-captions) */
4084
4138
  this.initCaptionSubscriber = () => {
4085
4139
  // subscribe to captions here so that we don't call captions when call is not initialized
4086
- if (this._call.state === 'Connected' && !this._captionsSubscriber) {
4140
+ if (this._call.state === 'Connected' &&
4141
+ !this._TeamsCaptionsSubscriber &&
4142
+ /* @conditional-compile-remove(acs-close-captions) */ !this._CaptionsSubscriber) {
4087
4143
  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);
4144
+ this._TeamsCaptionsSubscriber = new TeamsCaptionsSubscriber(this._callIdRef, this._context, this._call.feature(communicationCalling.Features.Captions).captions);
4090
4145
  }
4146
+ else {
4147
+ /* @conditional-compile-remove(acs-close-captions) */
4148
+ this._CaptionsSubscriber = new CaptionsSubscriber(this._callIdRef, this._context, this._call.feature(communicationCalling.Features.Captions).captions);
4149
+ }
4150
+ this._call.off('stateChanged', this.initCaptionSubscriber);
4091
4151
  }
4092
4152
  };
4093
4153
  this.idChanged = () => {
@@ -4554,7 +4614,13 @@ class ProxyCallCommon {
4554
4614
  /* @conditional-compile-remove(close-captions) */
4555
4615
  if (args[0] === communicationCalling.Features.Captions) {
4556
4616
  const captionsFeature = target.feature(communicationCalling.Features.Captions).captions;
4557
- const proxyFeature = new ProxyTeamsCaptions(this._context, target);
4617
+ let proxyFeature;
4618
+ /* @conditional-compile-remove(acs-close-captions) */
4619
+ if (captionsFeature.kind === 'Captions') {
4620
+ proxyFeature = new ProxyCaptions(this._context, target);
4621
+ return { captions: new Proxy(captionsFeature, proxyFeature) };
4622
+ }
4623
+ proxyFeature = new ProxyTeamsCaptions(this._context, target);
4558
4624
  return { captions: new Proxy(captionsFeature, proxyFeature) };
4559
4625
  }
4560
4626
  /* @conditional-compile-remove(call-transfer) */
@@ -4621,6 +4687,44 @@ class ProxyTeamsCaptions {
4621
4687
  }
4622
4688
  }
4623
4689
  }
4690
+ /* @conditional-compile-remove(acs-close-captions) */
4691
+ /**
4692
+ * @private
4693
+ */
4694
+ class ProxyCaptions {
4695
+ constructor(context, call) {
4696
+ this._context = context;
4697
+ this._call = call;
4698
+ }
4699
+ get(target, prop) {
4700
+ switch (prop) {
4701
+ case 'startCaptions':
4702
+ return this._context.withAsyncErrorTeedToState((...args) => __awaiter$I(this, void 0, void 0, function* () {
4703
+ var _a, _b;
4704
+ this._context.setStartCaptionsInProgress(this._call.id, true);
4705
+ const ret = yield target.startCaptions(...args);
4706
+ 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');
4707
+ return ret;
4708
+ }), 'Call.feature');
4709
+ case 'stopCaptions':
4710
+ return this._context.withAsyncErrorTeedToState((...args) => __awaiter$I(this, void 0, void 0, function* () {
4711
+ const ret = yield target.stopCaptions(...args);
4712
+ this._context.setIsCaptionActive(this._call.id, false);
4713
+ this._context.setStartCaptionsInProgress(this._call.id, false);
4714
+ this._context.clearCaptions(this._call.id);
4715
+ return ret;
4716
+ }), 'Call.feature');
4717
+ case 'setSpokenLanguage':
4718
+ return this._context.withAsyncErrorTeedToState((...args) => __awaiter$I(this, void 0, void 0, function* () {
4719
+ const ret = yield target.setSpokenLanguage(...args);
4720
+ this._context.setSelectedSpokenLanguage(this._call.id, args[0]);
4721
+ return ret;
4722
+ }), 'Call.feature');
4723
+ default:
4724
+ return Reflect.get(target, prop);
4725
+ }
4726
+ }
4727
+ }
4624
4728
  /* @conditional-compile-remove(spotlight) */
4625
4729
  /**
4626
4730
  * @private
@@ -6363,7 +6467,7 @@ const darkTheme = {
6363
6467
  errorText: '#f1707b'
6364
6468
  }
6365
6469
  };
6366
- /* @conditional-compile-remove(image-overlay) */
6470
+ /* @conditional-compile-remove(image-overlay-theme) */
6367
6471
  /**
6368
6472
  * Preset dark theme for the ImageOverlay component.
6369
6473
  *
@@ -9158,18 +9262,23 @@ const ImageOverlay = (props) => {
9158
9262
  /* @conditional-compile-remove(image-overlay) */
9159
9263
  const localeStrings = useLocale$1().strings.imageOverlay;
9160
9264
  const [isImageLoaded, setIsImageLoaded] = React.useState(true);
9161
- const imageStyle = isImageLoaded ? normalImageStyle : brokenImageStyle(imageOverlayTheme);
9265
+ /* @conditional-compile-remove(image-overlay) */
9266
+ const overlayTheme = React.useMemo(() => {
9267
+ /* @conditional-compile-remove(image-overlay-theme) */
9268
+ return imageOverlayTheme;
9269
+ }, []);
9270
+ const imageStyle = isImageLoaded ? normalImageStyle : brokenImageStyle(overlayTheme);
9162
9271
  const renderHeaderBar = () => {
9163
9272
  return (React.createElement(react.Stack, { className: react.mergeStyles(headerStyle) },
9164
9273
  React.createElement(react.Stack, { className: react.mergeStyles(titleBarContainerStyle) },
9165
9274
  titleIcon,
9166
- React.createElement(react.Stack.Item, { className: react.mergeStyles(titleStyle$2(imageOverlayTheme)), "aria-label": title || 'Image' }, title)),
9275
+ React.createElement(react.Stack.Item, { className: react.mergeStyles(titleStyle$2(overlayTheme)), "aria-label": title || 'Image' }, title)),
9167
9276
  React.createElement(react.Stack, { className: react.mergeStyles(controlBarContainerStyle) },
9168
9277
  onDownloadButtonClicked && (React.createElement(react.DefaultButton, { className: react.mergeStyles(downloadButtonStyle),
9169
9278
  /* @conditional-compile-remove(image-overlay) */
9170
9279
  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,
9280
+ 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 === '' })),
9281
+ React.createElement(react.IconButton, { iconProps: cancelIcon, className: react.mergeStyles(closeButtonStyles(overlayTheme)), onClick: onDismiss,
9173
9282
  /* @conditional-compile-remove(image-overlay) */
9174
9283
  ariaLabel: localeStrings.dismissButtonAriaLabel, "aria-live": 'polite' }))));
9175
9284
  };
@@ -9180,8 +9289,8 @@ const ImageOverlay = (props) => {
9180
9289
  event.persist();
9181
9290
  } }))));
9182
9291
  };
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 },
9292
+ return (React.createElement(react.Modal, { titleAriaId: title, isOpen: isOpen, onDismiss: onDismiss, overlay: { styles: Object.assign({}, overlayStyles(overlayTheme)) }, styles: { main: focusTrapZoneStyle, scrollableContent: scrollableContentStyle }, isDarkOverlay: true },
9293
+ React.createElement(FluentThemeProvider, { fluentTheme: overlayTheme, rootStyle: themeProviderRootStyle },
9185
9294
  renderHeaderBar(),
9186
9295
  renderBodyWithLightDismiss())));
9187
9296
  };
@@ -13299,7 +13408,7 @@ const DrawerMenuItem = (props) => {
13299
13408
  const onKeyPress = (ev) => onClick && submitWithKeyboard(ev, onClick);
13300
13409
  const secondaryIcon = props.secondaryIconProps ? (React.createElement(MenuItemIcon, Object.assign({}, props.secondaryIconProps))) : props.subMenuProps ? (React.createElement(MenuItemIcon, { iconName: "ChevronRight" })) : undefined;
13301
13410
  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 },
13411
+ 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
13412
  props.iconProps && (React.createElement(react.Stack.Item, { role: "presentation", styles: props.disabled ? { root: { color: theme.palette.neutralTertiaryAlt } } : undefined },
13304
13413
  React.createElement(MenuItemIcon, Object.assign({}, props.iconProps)))),
13305
13414
  React.createElement(react.Stack.Item, { styles: drawerMenuItemTextStyles, grow: true },
@@ -13313,10 +13422,10 @@ const DrawerMenuItem = (props) => {
13313
13422
  };
13314
13423
  const MenuItemIcon = (props) => (React.createElement(react.FontIcon, Object.assign({ className: react.mergeStyles(iconStyles$1) }, props)));
13315
13424
  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': {
13425
+ const drawerMenuItemRootStyles$1 = (hoverBackground, fontSize) => (Object.assign(Object.assign({}, fontSize), { height: '3rem', lineHeight: '3rem', padding: '0rem 0.75rem', cursor: 'pointer', ':hover, :focus': {
13317
13426
  background: hoverBackground
13318
13427
  } }));
13319
- const disabledDrawerMenuItemRootStyles = (background) => ({
13428
+ const disabledDrawerMenuItemRootStyles$1 = (background) => ({
13320
13429
  pointerEvents: 'none',
13321
13430
  background: background,
13322
13431
  ':hover, :focus': {
@@ -13442,6 +13551,9 @@ const drawerContentContainerStyles = {
13442
13551
 
13443
13552
  // Copyright (c) Microsoft Corporation.
13444
13553
  // Licensed under the MIT License.
13554
+ const isDrawerMenuItem = (item) => {
13555
+ return item.onRendererContent === undefined;
13556
+ };
13445
13557
  /**
13446
13558
  * Takes a set of menu items and returns a created menu inside a {@link _DrawerSurface}.
13447
13559
  *
@@ -13458,7 +13570,7 @@ const _DrawerMenu = (props) => {
13458
13570
  var _a;
13459
13571
  let items = props.items;
13460
13572
  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;
13573
+ 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
13574
  }
13463
13575
  return items;
13464
13576
  }, [props.items, selectedKeyPath]);
@@ -13473,7 +13585,7 @@ const _DrawerMenu = (props) => {
13473
13585
  }, [selectedKeyPath]);
13474
13586
  // Ensure the first item has a border radius that matches the DrawerSurface
13475
13587
  const borderRadius = useTheme().effects.roundedCorner4;
13476
- const firstItemStyle = menuItemsToRender && ((_a = menuItemsToRender[0]) === null || _a === void 0 ? void 0 : _a.styles);
13588
+ const firstItemStyle = (menuItemsToRender === null || menuItemsToRender === void 0 ? void 0 : menuItemsToRender[0]) && ((_a = menuItemsToRender[0]) === null || _a === void 0 ? void 0 : _a.styles);
13477
13589
  const modifiedFirstItemStyle = React.useMemo(() => react.merge(firstItemStyle !== null && firstItemStyle !== void 0 ? firstItemStyle : {}, {
13478
13590
  root: {
13479
13591
  borderTopRightRadius: borderRadius,
@@ -13482,14 +13594,192 @@ const _DrawerMenu = (props) => {
13482
13594
  }), [firstItemStyle, borderRadius]);
13483
13595
  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
13596
  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
- } })))))));
13597
+ menuItemsToRender.slice(0, 1).map((item) => {
13598
+ var _a;
13599
+ 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'
13600
+ ? undefined
13601
+ : (ev, itemKey) => {
13602
+ onItemClick(item, ev, itemKey);
13603
+ } }))) : ((_a = item.onRendererContent) === null || _a === void 0 ? void 0 : _a.call(item));
13604
+ }), menuItemsToRender === null || menuItemsToRender === void 0 ? void 0 :
13605
+ menuItemsToRender.slice(1).map((item, i) => {
13606
+ var _a;
13607
+ return isDrawerMenuItem(item) ? (React.createElement(DrawerMenuItem, Object.assign({}, item, { key: `${item.itemKey}` + `${i + 1}`, onItemClick: (ev, itemKey) => {
13608
+ onItemClick(item, ev, itemKey);
13609
+ } }))) : ((_a = item.onRendererContent) === null || _a === void 0 ? void 0 : _a.call(item));
13610
+ }))));
13611
+ };
13612
+
13613
+ // Copyright (c) Microsoft Corporation.
13614
+ // Licensed under the MIT License.
13615
+ /* @conditional-compile-remove(reaction) */
13616
+ /* @conditional-compile-remove(reaction) */
13617
+ /**
13618
+ * @private
13619
+ */
13620
+ const playFrames$1 = react.memoizeFunction(() => react.keyframes({
13621
+ from: {
13622
+ backgroundPosition: '0px 8568px'
13623
+ },
13624
+ to: {
13625
+ backgroundPosition: '0px 0px'
13626
+ }
13627
+ }));
13628
+ /* @conditional-compile-remove(reaction) */
13629
+ /**
13630
+ * @param backgroundImage - the uri for the reaction emoji resource
13631
+ * @param animationPlayState - the value is either 'running' or 'paused' based on the mouse hover event
13632
+ *
13633
+ * @private
13634
+ */
13635
+ const emojiStyles = (backgroundImage, animationPlayState) => {
13636
+ const imageResourceUrl = `url(${backgroundImage})`;
13637
+ return {
13638
+ display: 'flex',
13639
+ flexDirection: 'column',
13640
+ height: '100%',
13641
+ width: '100%',
13642
+ backgroundImage: imageResourceUrl,
13643
+ animationName: playFrames$1(),
13644
+ animationDuration: '8.12s',
13645
+ animationTimingFunction: `steps(102)`,
13646
+ animationPlayState: animationPlayState,
13647
+ animationIterationCount: 'infinite',
13648
+ justifyContent: 'center',
13649
+ alignItems: 'center',
13650
+ backgroundPosition: 'center',
13651
+ backgroundSize: `2.75rem 133.875rem`,
13652
+ transition: 'opacity 2s',
13653
+ backgroundColor: 'transparent',
13654
+ transform: `${animationPlayState === 'running' ? 'scale(0.8)' : 'scale(0.6)'}`
13655
+ };
13656
+ };
13657
+ /* @conditional-compile-remove(reaction) */
13658
+ /**
13659
+ *
13660
+ * @private
13661
+ */
13662
+ const reactionEmojiMenuStyles = () => {
13663
+ return {
13664
+ display: 'flex',
13665
+ justifyContent: 'center',
13666
+ alignItems: 'center',
13667
+ flexDirection: 'row',
13668
+ width: '13.75rem',
13669
+ height: '2.625rem'
13670
+ };
13671
+ };
13672
+ /* @conditional-compile-remove(reaction) */
13673
+ /**
13674
+ *
13675
+ * @private
13676
+ */
13677
+ const reactionToolTipHostStyle = () => {
13678
+ return {
13679
+ root: {
13680
+ display: 'flex',
13681
+ flexDirection: 'column',
13682
+ height: '100%',
13683
+ width: '100%'
13684
+ }
13685
+ };
13686
+ };
13687
+ /* @conditional-compile-remove(reaction) */
13688
+ /**
13689
+ *
13690
+ * @private
13691
+ */
13692
+ const mobileViewMenuItemStyle = () => {
13693
+ return {
13694
+ display: 'flex',
13695
+ justifyContent: 'space-between',
13696
+ alignItems: 'center',
13697
+ flexDirection: 'row',
13698
+ width: '100%',
13699
+ height: '2.625rem'
13700
+ };
13701
+ };
13702
+ /* @conditional-compile-remove(reaction) */
13703
+ /**
13704
+ * @param backgroundImage - the uri for the reaction emoji resource
13705
+ * @param animationPlayState - the value is either 'running' or 'paused' based on the mouse hover event
13706
+ *
13707
+ * @private
13708
+ */
13709
+ const mobileViewEmojiStyles = (backgroundImage, animationPlayState) => {
13710
+ const imageResourceUrl = `url(${backgroundImage})`;
13711
+ return {
13712
+ display: 'flex',
13713
+ flexDirection: 'column',
13714
+ height: '100%',
13715
+ width: '2.75rem',
13716
+ backgroundImage: imageResourceUrl,
13717
+ animationName: playFrames$1(),
13718
+ animationDuration: '8.12s',
13719
+ animationTimingFunction: `steps(102)`,
13720
+ animationPlayState: animationPlayState,
13721
+ animationIterationCount: 'infinite',
13722
+ justifyContent: 'center',
13723
+ alignItems: 'center',
13724
+ backgroundPosition: 'center',
13725
+ backgroundSize: `2.75rem 133.875rem`,
13726
+ transition: 'opacity 2s',
13727
+ backgroundColor: 'transparent',
13728
+ transform: `${animationPlayState === 'running' ? 'scale(0.8)' : 'scale(0.6)'}`
13729
+ };
13491
13730
  };
13492
13731
 
13732
+ // Copyright (c) Microsoft Corporation.
13733
+ // Licensed under the MIT License.
13734
+ /* @conditional-compile-remove(reaction) */
13735
+ /* @conditional-compile-remove(reaction) */
13736
+ /**
13737
+ * Maps the individual item in menuProps.items passed in the {@link DrawerMenu} into a UI component.
13738
+ *
13739
+ * @internal
13740
+ */
13741
+ const _ReactionDrawerMenuItem = (props) => {
13742
+ var _a, _b, _c, _d, _e;
13743
+ const theme = useTheme();
13744
+ const resources = props.reactionResources;
13745
+ const emojiResource = new Map([
13746
+ ['like', (_a = resources === null || resources === void 0 ? void 0 : resources.likeReaction) === null || _a === void 0 ? void 0 : _a.url],
13747
+ ['heart', (_b = resources === null || resources === void 0 ? void 0 : resources.heartReaction) === null || _b === void 0 ? void 0 : _b.url],
13748
+ ['laugh', (_c = resources === null || resources === void 0 ? void 0 : resources.laughReaction) === null || _c === void 0 ? void 0 : _c.url],
13749
+ ['applause', (_d = resources === null || resources === void 0 ? void 0 : resources.applauseReaction) === null || _d === void 0 ? void 0 : _d.url],
13750
+ ['surprised', (_e = resources === null || resources === void 0 ? void 0 : resources.surprisedReaction) === null || _e === void 0 ? void 0 : _e.url]
13751
+ ]);
13752
+ const emojis = ['like', 'heart', 'laugh', 'applause', 'surprised'];
13753
+ const borderRadius = useTheme().effects.roundedCorner4;
13754
+ const modifiedFirstItemStyle = {
13755
+ root: {
13756
+ borderTopRightRadius: borderRadius,
13757
+ borderTopLeftRadius: borderRadius,
13758
+ marginTop: '12px'
13759
+ }
13760
+ };
13761
+ 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) },
13762
+ React.createElement("div", { style: mobileViewMenuItemStyle() }, emojis.map((emoji, index) => {
13763
+ const resourceUrl = emojiResource.get(emoji.toString());
13764
+ return (React.createElement(react.IconButton, { key: index, onClick: () => {
13765
+ var _a;
13766
+ (_a = props.onReactionClick) === null || _a === void 0 ? void 0 : _a.call(props, emoji);
13767
+ }, style: mobileViewEmojiStyles(resourceUrl ? resourceUrl : '', 'running') }));
13768
+ }))));
13769
+ };
13770
+ /* @conditional-compile-remove(reaction) */
13771
+ const drawerMenuItemRootStyles = (hoverBackground, fontSize) => (Object.assign(Object.assign({}, fontSize), { height: '3rem', lineHeight: '3rem', padding: '0rem 0.75rem', cursor: 'pointer', ':hover, :focus': {
13772
+ background: hoverBackground
13773
+ } }));
13774
+ /* @conditional-compile-remove(reaction) */
13775
+ const disabledDrawerMenuItemRootStyles = (background) => ({
13776
+ pointerEvents: 'none',
13777
+ background: background,
13778
+ ':hover, :focus': {
13779
+ background: background
13780
+ }
13781
+ });
13782
+
13493
13783
  // Copyright (c) Microsoft Corporation.
13494
13784
  // Licensed under the MIT License.
13495
13785
  /** @private */
@@ -13933,7 +14223,7 @@ const raiseHandLimitedSpaceStyles = {
13933
14223
  /**
13934
14224
  * @private
13935
14225
  */
13936
- const playFrames$1 = react.memoizeFunction(() => react.keyframes({
14226
+ const playFrames = react.memoizeFunction(() => react.keyframes({
13937
14227
  from: {
13938
14228
  backgroundPosition: '0px 8568px'
13939
14229
  },
@@ -13951,7 +14241,7 @@ const reactionRenderingStyle = (args) => {
13951
14241
  height: '100%',
13952
14242
  width: '100%',
13953
14243
  overflow: 'hidden',
13954
- animationName: playFrames$1(),
14244
+ animationName: playFrames(),
13955
14245
  backgroundImage: imageUrl,
13956
14246
  animationDuration: '5.12s',
13957
14247
  animationTimingFunction: `steps(102)`,
@@ -18548,81 +18838,6 @@ const raiseHandButtonStyles = (theme) => ({
18548
18838
  labelChecked: { color: react.DefaultPalette.white }
18549
18839
  });
18550
18840
 
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
18841
  // Copyright (c) Microsoft Corporation.
18627
18842
  // Licensed under the MIT License.
18628
18843
  /* @conditional-compile-remove(reaction) */
@@ -20488,7 +20703,9 @@ const _CaptionsSettingsModal = (props) => {
20488
20703
  const captionLanguageCode = selectedCaptionLanguage.key;
20489
20704
  if (isCaptionsFeatureActive) {
20490
20705
  onSetSpokenLanguage(spokenLanguageCode);
20491
- onSetCaptionLanguage(captionLanguageCode);
20706
+ if (changeCaptionLanguage) {
20707
+ onSetCaptionLanguage(captionLanguageCode);
20708
+ }
20492
20709
  }
20493
20710
  else {
20494
20711
  yield onStartCaptions({ spokenLanguage: spokenLanguageCode });
@@ -20501,7 +20718,8 @@ const _CaptionsSettingsModal = (props) => {
20501
20718
  onSetCaptionLanguage,
20502
20719
  onStartCaptions,
20503
20720
  selectedSpokenLanguage.key,
20504
- selectedCaptionLanguage.key
20721
+ selectedCaptionLanguage.key,
20722
+ changeCaptionLanguage
20505
20723
  ]);
20506
20724
  const spokenLanguageDropdownOptions = React.useMemo(() => {
20507
20725
  return supportedSpokenLanguages.map((languageCode) => {
@@ -22140,7 +22358,7 @@ const generateImageAttachmentImgHtml = (message, attachment) => {
22140
22358
  const getResourceSourceUrl = (result) => {
22141
22359
  let src = '';
22142
22360
  if (result) {
22143
- if (result.error) {
22361
+ if (result.error || !result.sourceUrl) {
22144
22362
  // In case of an error we set src to some invalid value to show broken image
22145
22363
  src = 'blob://';
22146
22364
  }
@@ -22836,7 +23054,9 @@ let ChatContext$1 = class ChatContext {
22836
23054
  if (cache) {
22837
23055
  Object.keys(cache).forEach((resourceUrl) => {
22838
23056
  const resource = cache[resourceUrl];
22839
- URL.revokeObjectURL(resource.sourceUrl);
23057
+ if (resource.sourceUrl) {
23058
+ URL.revokeObjectURL(resource.sourceUrl);
23059
+ }
22840
23060
  });
22841
23061
  }
22842
23062
  thread.chatMessages[messageId].resourceCache = undefined;
@@ -22877,7 +23097,9 @@ let ChatContext$1 = class ChatContext {
22877
23097
  }
22878
23098
  if (message && message.resourceCache && message.resourceCache[resourceUrl]) {
22879
23099
  const resource = message.resourceCache[resourceUrl];
22880
- URL.revokeObjectURL(resource.sourceUrl);
23100
+ if (resource.sourceUrl) {
23101
+ URL.revokeObjectURL(resource.sourceUrl);
23102
+ }
22881
23103
  delete message.resourceCache[resourceUrl];
22882
23104
  }
22883
23105
  });
@@ -25473,7 +25695,7 @@ const useSelector$2 = (selector, selectorProps) => {
25473
25695
  // Copyright (c) Microsoft Corporation.
25474
25696
  // Licensed under the MIT License.
25475
25697
  /* @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 })));
25698
+ const RichTextSendBoxWrapper = React.lazy(() => Promise.resolve().then(function () { return require('./RichTextSendBoxWrapper-UUKnVH43.js'); }).then((module) => ({ default: module.RichTextSendBoxWrapper })));
25477
25699
  /**
25478
25700
  * @private
25479
25701
  */
@@ -25567,7 +25789,7 @@ const ChatScreen = (props) => {
25567
25789
  }, [messageThreadProps.messages]);
25568
25790
  const getResourceSourceUrl = (result) => {
25569
25791
  let src = '';
25570
- if (result.error) {
25792
+ if (result.error || !result.sourceUrl) {
25571
25793
  src = 'blob://';
25572
25794
  }
25573
25795
  else {
@@ -26857,7 +27079,7 @@ const CaptionsBanner = (props) => {
26857
27079
  /* @conditional-compile-remove(close-captions) */
26858
27080
  const desktopViewBannerWidth = windowWidth > 620 ? '35rem' : '80%';
26859
27081
  return (React.createElement(React.Fragment, null,
26860
- /* @conditional-compile-remove(close-captions) */ isCaptionsSettingsOpen && (React.createElement(CaptionsSettingsModal, { showCaptionsSettingsModal: isCaptionsSettingsOpen, onDismissCaptionsSettings: onDismissCaptionsSettings, changeCaptionLanguage: true })),
27082
+ /* @conditional-compile-remove(close-captions) */ isCaptionsSettingsOpen && (React.createElement(CaptionsSettingsModal, { showCaptionsSettingsModal: isCaptionsSettingsOpen, onDismissCaptionsSettings: onDismissCaptionsSettings, changeCaptionLanguage: props.isTeamsCall })),
26861
27083
  /* @conditional-compile-remove(close-captions) */ React.createElement("div", { className: containerClassName },
26862
27084
  React.createElement(react.Stack, { horizontalAlign: "center" },
26863
27085
  React.createElement(react.Stack.Item, { style: { width: props.isMobile ? mobileViewBannerWidth : desktopViewBannerWidth } },
@@ -28412,7 +28634,7 @@ const CommonCallControlBar = (props) => {
28412
28634
  const reactionResources = props.callAdapter.getState().reactions;
28413
28635
  return (React.createElement("div", { ref: controlBarSizeRef },
28414
28636
  React.createElement(CallAdapterProvider, { adapter: props.callAdapter },
28415
- /* @conditional-compile-remove(close-captions) */ showCaptionsSettingsModal && (React.createElement(CaptionsSettingsModal, { showCaptionsSettingsModal: showCaptionsSettingsModal, onDismissCaptionsSettings: onDismissCaptionsSettings, changeCaptionLanguage: props.isCaptionsOn }))),
28637
+ /* @conditional-compile-remove(close-captions) */ showCaptionsSettingsModal && (React.createElement(CaptionsSettingsModal, { showCaptionsSettingsModal: showCaptionsSettingsModal, onDismissCaptionsSettings: onDismissCaptionsSettings, changeCaptionLanguage: props.isCaptionsOn && props.isTeamsCall }))),
28416
28638
  React.createElement(react.Stack, { horizontal: true, reversed: !props.mobileView && !isOutOfSpace, horizontalAlign: "space-between", className: react.mergeStyles(callControlsContainerStyles, controlBarContainerStyles, controlBarDesktopContainerStyles) },
28417
28639
  React.createElement(react.Stack.Item, { grow: true, className: react.mergeStyles(controlBarWrapperDesktopStyles) },
28418
28640
  React.createElement(CallAdapterProvider, { adapter: props.callAdapter },
@@ -28796,6 +29018,13 @@ const MoreDrawer = (props) => {
28796
29018
  onLightDismiss();
28797
29019
  }, [speakers, onSelectSpeaker, onLightDismiss]);
28798
29020
  const drawerSelectionOptions = inferCallWithChatControlOptions(props.callControls);
29021
+ /* @conditional-compile-remove(reaction) */
29022
+ if (props.reactionResources !== undefined) {
29023
+ drawerMenuItems.push({
29024
+ itemKey: 'reactions',
29025
+ onRendererContent: () => (React.createElement(_ReactionDrawerMenuItem, { onReactionClick: props.onReactionClick, reactionResources: props.reactionResources }))
29026
+ });
29027
+ }
28799
29028
  if (props.speakers && props.speakers.length > 0) {
28800
29029
  drawerMenuItems.push({
28801
29030
  itemKey: 'speakers',
@@ -29015,9 +29244,6 @@ const MoreDrawer = (props) => {
29015
29244
  const spokenLanguageString = supportedSpokenLanguageStrings
29016
29245
  ? supportedSpokenLanguageStrings[currentSpokenLanguage]
29017
29246
  : currentSpokenLanguage;
29018
- const captionLanguageString = supportedCaptionLanguageStrings
29019
- ? supportedCaptionLanguageStrings[currentCaptionLanguage]
29020
- : currentCaptionLanguage;
29021
29247
  drawerMenuItems.push({
29022
29248
  itemKey: 'captions',
29023
29249
  id: 'common-call-composite-captions-button',
@@ -29058,24 +29284,29 @@ const MoreDrawer = (props) => {
29058
29284
  styles: { root: { lineHeight: 0 } }
29059
29285
  }
29060
29286
  });
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
- });
29287
+ if (props.isTeamsCall) {
29288
+ const captionLanguageString = supportedCaptionLanguageStrings
29289
+ ? supportedCaptionLanguageStrings[currentCaptionLanguage]
29290
+ : currentCaptionLanguage;
29291
+ captionsDrawerItems.push({
29292
+ itemKey: 'ChangeCaptionLanguage',
29293
+ text: props.strings.captionLanguageMenuTitle,
29294
+ id: 'common-call-composite-captions-subtitle-settings-button',
29295
+ secondaryText: captionLanguageString,
29296
+ iconProps: {
29297
+ iconName: 'ChangeCaptionLanguageIcon',
29298
+ styles: { root: { lineHeight: 0 } }
29299
+ },
29300
+ disabled: props.disableButtonsForHoldScreen || !captionSettingsProp.isCaptionsFeatureActive,
29301
+ onItemClick: () => {
29302
+ setIsCaptionLanguageDrawerOpen(true);
29303
+ },
29304
+ secondaryIconProps: {
29305
+ iconName: 'ChevronRight',
29306
+ styles: { root: { lineHeight: 0 } }
29307
+ }
29308
+ });
29309
+ }
29079
29310
  }
29080
29311
  /* @conditional-compile-remove(control-bar-button-injection) */
29081
29312
  const customDrawerButtons = React.useMemo(() => generateCustomCallDrawerButtons(onFetchCustomButtonPropsTrampoline(drawerSelectionOptions !== false ? drawerSelectionOptions : undefined), drawerSelectionOptions !== false ? drawerSelectionOptions === null || drawerSelectionOptions === void 0 ? void 0 : drawerSelectionOptions.displayType : undefined), [drawerSelectionOptions]);
@@ -31089,7 +31320,9 @@ const CallArrangement = (props) => {
31089
31320
  /* @conditional-compile-remove(PSTN-calls) */ /* @conditional-compile-remove(one-to-n-calling) */
31090
31321
  disableButtonsForHoldScreen: isInLocalHold, peopleButtonChecked: isPeoplePaneOpen, onPeopleButtonClicked: togglePeoplePane, onMoreButtonClicked: onMoreButtonClicked,
31091
31322
  /* @conditional-compile-remove(close-captions) */
31092
- isCaptionsSupported: isTeamsCall && hasJoinedCall,
31323
+ isCaptionsSupported: hasJoinedCall,
31324
+ /* @conditional-compile-remove(close-captions) */
31325
+ isTeamsCall: isTeamsCall,
31093
31326
  /* @conditional-compile-remove(close-captions) */
31094
31327
  isCaptionsOn: isCaptionsOn,
31095
31328
  /* @conditional-compile-remove(video-background-effects) */
@@ -31101,7 +31334,11 @@ const CallArrangement = (props) => {
31101
31334
  /* @conditional-compile-remove(PSTN-calls) */ /* @conditional-compile-remove(one-to-n-calling) */
31102
31335
  disableButtonsForHoldScreen: isInLocalHold,
31103
31336
  /* @conditional-compile-remove(close-captions) */
31104
- isCaptionsSupported: isTeamsCall && hasJoinedCall, onUserSetGalleryLayout: props.onUserSetGalleryLayoutChange, userSetGalleryLayout: props.userSetGalleryLayout, onSetDialpadPage: props.onSetDialpadPage, dtmfDialerPresent: props.dtmfDialerPresent }))),
31337
+ isCaptionsSupported: hasJoinedCall,
31338
+ /* @conditional-compile-remove(close-captions) */
31339
+ isTeamsCall: isTeamsCall, onUserSetGalleryLayout: props.onUserSetGalleryLayoutChange, userSetGalleryLayout: props.userSetGalleryLayout, onSetDialpadPage: props.onSetDialpadPage, dtmfDialerPresent: props.dtmfDialerPresent,
31340
+ /* @conditional-compile-remove(reaction) */
31341
+ reactionResources: adapter.getState().reactions }))),
31105
31342
  React.createElement(react.Stack, { horizontal: true, grow: true },
31106
31343
  React.createElement(react.Stack.Item, { style: callCompositeContainerCSS },
31107
31344
  React.createElement(react.Stack.Item, { styles: callGalleryStyles, grow: true },
@@ -31118,7 +31355,9 @@ const CallArrangement = (props) => {
31118
31355
  canUnmute && !!props.mutedNotificationProps && (React.createElement(MutedNotification, Object.assign({}, props.mutedNotificationProps)))),
31119
31356
  renderGallery && props.onRenderGalleryContent && props.onRenderGalleryContent(),
31120
31357
  /* @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 }))))),
31358
+ /* @conditional-compile-remove(PSTN-calls) */ /* @conditional-compile-remove(one-to-n-calling) */ !isInLocalHold && (React.createElement(CaptionsBanner, { isMobile: props.mobileView, onFetchAvatarPersonaData: props.onFetchAvatarPersonaData,
31359
+ /* @conditional-compile-remove(close-captions) */
31360
+ isTeamsCall: isTeamsCall }))))),
31122
31361
  React.createElement(SidePane, { mobileView: props.mobileView,
31123
31362
  /* @conditional-compile-remove(video-background-effects) */
31124
31363
  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)
@@ -35262,25 +35501,49 @@ class AzureCommunicationCallAdapter {
35262
35501
  }
35263
35502
  /* @conditional-compile-remove(close-captions) */
35264
35503
  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));
35504
+ var _a, _b;
35505
+ if (this.call && this.call.state === 'Connected') {
35506
+ if (this.context.getState().isTeamsCall) {
35507
+ const captionsFeature = (_a = this.call) === null || _a === void 0 ? void 0 : _a.feature(communicationCalling.Features.Captions).captions;
35508
+ captionsFeature.on('CaptionsReceived', this.teamsCaptionsReceived.bind(this));
35509
+ captionsFeature.on('CaptionsActiveChanged', this.isCaptionsActiveChanged.bind(this));
35510
+ captionsFeature.on('CaptionLanguageChanged', this.isCaptionLanguageChanged.bind(this));
35511
+ captionsFeature.on('SpokenLanguageChanged', this.isSpokenLanguageChanged.bind(this));
35512
+ }
35513
+ else {
35514
+ /* @conditional-compile-remove(acs-close-captions) */
35515
+ const captionsFeature = (_b = this.call) === null || _b === void 0 ? void 0 : _b.feature(communicationCalling.Features.Captions).captions;
35516
+ /* @conditional-compile-remove(acs-close-captions) */
35517
+ captionsFeature.on('CaptionsReceived', this.captionsReceived.bind(this));
35518
+ /* @conditional-compile-remove(acs-close-captions) */
35519
+ captionsFeature.on('CaptionsActiveChanged', this.isCaptionsActiveChanged.bind(this));
35520
+ /* @conditional-compile-remove(acs-close-captions) */
35521
+ captionsFeature.on('SpokenLanguageChanged', this.isSpokenLanguageChanged.bind(this));
35522
+ }
35272
35523
  }
35273
35524
  }
35274
35525
  /* @conditional-compile-remove(close-captions) */
35275
35526
  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));
35527
+ var _a, _b, _c;
35528
+ if (this.call && this.call.state === 'Connected') {
35529
+ if (this.context.getState().isTeamsCall) {
35530
+ const captionsFeature = (_a = this.call) === null || _a === void 0 ? void 0 : _a.feature(communicationCalling.Features.Captions).captions;
35531
+ captionsFeature.off('CaptionsReceived', this.teamsCaptionsReceived.bind(this));
35532
+ captionsFeature.off('CaptionsActiveChanged', this.isCaptionsActiveChanged.bind(this));
35533
+ captionsFeature.off('CaptionLanguageChanged', this.isCaptionLanguageChanged.bind(this));
35534
+ captionsFeature.off('SpokenLanguageChanged', this.isSpokenLanguageChanged.bind(this));
35535
+ }
35536
+ else {
35537
+ /* @conditional-compile-remove(acs-close-captions) */
35538
+ const captionsFeature = (_b = this.call) === null || _b === void 0 ? void 0 : _b.feature(communicationCalling.Features.Captions).captions;
35539
+ /* @conditional-compile-remove(acs-close-captions) */
35540
+ captionsFeature.off('CaptionsReceived', this.captionsReceived.bind(this));
35541
+ /* @conditional-compile-remove(acs-close-captions) */
35542
+ captionsFeature.off('CaptionsActiveChanged', this.isCaptionsActiveChanged.bind(this));
35543
+ /* @conditional-compile-remove(acs-close-captions) */
35544
+ captionsFeature.off('SpokenLanguageChanged', this.isSpokenLanguageChanged.bind(this));
35545
+ }
35546
+ (_c = this.call) === null || _c === void 0 ? void 0 : _c.off('stateChanged', this.subscribeToCaptionEvents.bind(this));
35284
35547
  }
35285
35548
  }
35286
35549
  subscribeCallEvents() {
@@ -35344,6 +35607,10 @@ class AzureCommunicationCallAdapter {
35344
35607
  this.emitter.emit('isLocalScreenSharingActiveChanged', { isScreenSharingOn: (_a = this.call) === null || _a === void 0 ? void 0 : _a.isScreenSharingOn });
35345
35608
  }
35346
35609
  /* @conditional-compile-remove(close-captions) */
35610
+ teamsCaptionsReceived(captionsInfo) {
35611
+ this.emitter.emit('captionsReceived', { captionsInfo });
35612
+ }
35613
+ /* @conditional-compile-remove(acs-close-captions) */
35347
35614
  captionsReceived(captionsInfo) {
35348
35615
  this.emitter.emit('captionsReceived', { captionsInfo });
35349
35616
  }
@@ -38052,4 +38319,4 @@ exports.useTeamsCall = useTeamsCall;
38052
38319
  exports.useTeamsCallAdapter = useTeamsCallAdapter;
38053
38320
  exports.useTeamsCallAgent = useTeamsCallAgent;
38054
38321
  exports.useTheme = useTheme;
38055
- //# sourceMappingURL=index-DikMcJD4.js.map
38322
+ //# sourceMappingURL=index-Db9LOYoW.js.map