@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.
- package/dist/communication-react.d.ts +1 -1
- package/dist/dist-cjs/communication-react/{RichTextSendBoxWrapper-D1KqCTKr.js → RichTextSendBoxWrapper-UUKnVH43.js} +2 -2
- package/dist/dist-cjs/communication-react/{RichTextSendBoxWrapper-D1KqCTKr.js.map → RichTextSendBoxWrapper-UUKnVH43.js.map} +1 -1
- package/dist/dist-cjs/communication-react/{index-DikMcJD4.js → index-Db9LOYoW.js} +425 -158
- package/dist/dist-cjs/communication-react/index-Db9LOYoW.js.map +1 -0
- package/dist/dist-cjs/communication-react/index.js +1 -1
- package/dist/dist-esm/acs-ui-common/src/telemetryVersion.js +1 -1
- package/dist/dist-esm/acs-ui-common/src/telemetryVersion.js.map +1 -1
- package/dist/dist-esm/calling-stateful-client/src/CallContext.d.ts +3 -1
- package/dist/dist-esm/calling-stateful-client/src/CallContext.js +13 -2
- package/dist/dist-esm/calling-stateful-client/src/CallContext.js.map +1 -1
- package/dist/dist-esm/calling-stateful-client/src/CallDeclarativeCommon.js +46 -1
- package/dist/dist-esm/calling-stateful-client/src/CallDeclarativeCommon.js.map +1 -1
- package/dist/dist-esm/calling-stateful-client/src/CallSubscriber.d.ts +2 -1
- package/dist/dist-esm/calling-stateful-client/src/CallSubscriber.js +18 -8
- package/dist/dist-esm/calling-stateful-client/src/CallSubscriber.js.map +1 -1
- package/dist/dist-esm/calling-stateful-client/src/CaptionsSubscriber.d.ts +16 -1
- package/dist/dist-esm/calling-stateful-client/src/CaptionsSubscriber.js +38 -2
- package/dist/dist-esm/calling-stateful-client/src/CaptionsSubscriber.js.map +1 -1
- package/dist/dist-esm/calling-stateful-client/src/Converter.d.ts +6 -1
- package/dist/dist-esm/calling-stateful-client/src/Converter.js +8 -1
- package/dist/dist-esm/calling-stateful-client/src/Converter.js.map +1 -1
- package/dist/dist-esm/chat-component-bindings/src/messageThreadSelector.js +1 -1
- package/dist/dist-esm/chat-component-bindings/src/messageThreadSelector.js.map +1 -1
- package/dist/dist-esm/chat-stateful-client/src/ChatContext.js +6 -2
- package/dist/dist-esm/chat-stateful-client/src/ChatContext.js.map +1 -1
- package/dist/dist-esm/chat-stateful-client/src/types/ChatMessageWithStatus.d.ts +1 -1
- package/dist/dist-esm/chat-stateful-client/src/types/ChatMessageWithStatus.js.map +1 -1
- package/dist/dist-esm/react-components/src/components/CaptionsSettingsModal.js +5 -2
- package/dist/dist-esm/react-components/src/components/CaptionsSettingsModal.js.map +1 -1
- package/dist/dist-esm/react-components/src/components/Drawer/DrawerMenu.js +19 -8
- package/dist/dist-esm/react-components/src/components/Drawer/DrawerMenu.js.map +1 -1
- package/dist/dist-esm/react-components/src/components/Drawer/DrawerMenuItem.d.ts +4 -0
- package/dist/dist-esm/react-components/src/components/Drawer/DrawerMenuItem.js.map +1 -1
- package/dist/dist-esm/react-components/src/components/Drawer/ReactionDrawerMenuItem.d.ts +29 -0
- package/dist/dist-esm/react-components/src/components/Drawer/ReactionDrawerMenuItem.js +60 -0
- package/dist/dist-esm/react-components/src/components/Drawer/ReactionDrawerMenuItem.js.map +1 -0
- package/dist/dist-esm/react-components/src/components/Drawer/index.d.ts +2 -0
- package/dist/dist-esm/react-components/src/components/Drawer/index.js +2 -0
- package/dist/dist-esm/react-components/src/components/Drawer/index.js.map +1 -1
- package/dist/dist-esm/react-components/src/components/ImageOverlay.js +16 -8
- package/dist/dist-esm/react-components/src/components/ImageOverlay.js.map +1 -1
- package/dist/dist-esm/react-components/src/components/styles/ReactionButton.styles.d.ts +12 -0
- package/dist/dist-esm/react-components/src/components/styles/ReactionButton.styles.js +47 -3
- package/dist/dist-esm/react-components/src/components/styles/ReactionButton.styles.js.map +1 -1
- package/dist/dist-esm/react-components/src/theming/themes.js +1 -1
- package/dist/dist-esm/react-components/src/theming/themes.js.map +1 -1
- package/dist/dist-esm/react-composites/src/composites/CallComposite/adapter/AzureCommunicationCallAdapter.d.ts +1 -0
- package/dist/dist-esm/react-composites/src/composites/CallComposite/adapter/AzureCommunicationCallAdapter.js +43 -15
- package/dist/dist-esm/react-composites/src/composites/CallComposite/adapter/AzureCommunicationCallAdapter.js.map +1 -1
- package/dist/dist-esm/react-composites/src/composites/CallComposite/components/CallArrangement.js +11 -3
- package/dist/dist-esm/react-composites/src/composites/CallComposite/components/CallArrangement.js.map +1 -1
- package/dist/dist-esm/react-composites/src/composites/ChatComposite/ChatScreen.js +1 -1
- package/dist/dist-esm/react-composites/src/composites/ChatComposite/ChatScreen.js.map +1 -1
- package/dist/dist-esm/react-composites/src/composites/common/CaptionsBanner.d.ts +1 -0
- package/dist/dist-esm/react-composites/src/composites/common/CaptionsBanner.js +1 -1
- package/dist/dist-esm/react-composites/src/composites/common/CaptionsBanner.js.map +1 -1
- package/dist/dist-esm/react-composites/src/composites/common/ControlBar/CommonCallControlBar.d.ts +1 -0
- package/dist/dist-esm/react-composites/src/composites/common/ControlBar/CommonCallControlBar.js +1 -1
- package/dist/dist-esm/react-composites/src/composites/common/ControlBar/CommonCallControlBar.js.map +1 -1
- package/dist/dist-esm/react-composites/src/composites/common/Drawer/MoreDrawer.d.ts +4 -0
- package/dist/dist-esm/react-composites/src/composites/common/Drawer/MoreDrawer.js +32 -21
- package/dist/dist-esm/react-composites/src/composites/common/Drawer/MoreDrawer.js.map +1 -1
- package/dist/dist-esm/react-composites/src/composites/common/Drawer/PreparedMoreDrawer.d.ts +3 -0
- package/dist/dist-esm/react-composites/src/composites/common/Drawer/PreparedMoreDrawer.js.map +1 -1
- package/package.json +1 -1
- 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-
|
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
|
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
|
-
|
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,
|
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
|
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.
|
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.
|
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
|
-
(
|
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
|
-
(
|
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' &&
|
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.
|
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
|
-
|
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
|
-
|
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(
|
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(
|
9172
|
-
React.createElement(react.IconButton, { iconProps: cancelIcon, className: react.mergeStyles(closeButtonStyles(
|
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(
|
9184
|
-
React.createElement(FluentThemeProvider, { fluentTheme:
|
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) =>
|
13486
|
-
|
13487
|
-
} }
|
13488
|
-
|
13489
|
-
|
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
|
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
|
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
|
-
|
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
|
-
|
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
|
-
|
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-
|
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:
|
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
|
-
|
29062
|
-
|
29063
|
-
|
29064
|
-
|
29065
|
-
|
29066
|
-
|
29067
|
-
|
29068
|
-
|
29069
|
-
|
29070
|
-
|
29071
|
-
|
29072
|
-
|
29073
|
-
|
29074
|
-
|
29075
|
-
|
29076
|
-
|
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:
|
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:
|
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'
|
35267
|
-
|
35268
|
-
|
35269
|
-
|
35270
|
-
|
35271
|
-
|
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'
|
35278
|
-
|
35279
|
-
|
35280
|
-
|
35281
|
-
|
35282
|
-
|
35283
|
-
|
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-
|
38322
|
+
//# sourceMappingURL=index-Db9LOYoW.js.map
|