@azure/communication-react 1.11.0-alpha-202312130012 → 1.11.0-alpha-202312150013
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 +200 -1
- package/dist/dist-cjs/communication-react/index.js +468 -56
- package/dist/dist-cjs/communication-react/index.js.map +1 -1
- package/dist/dist-esm/acs-ui-common/src/telemetry.js +2 -2
- package/dist/dist-esm/acs-ui-common/src/telemetry.js.map +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-component-bindings/src/handlers/createCommonHandlers.d.ts +2 -0
- package/dist/dist-esm/calling-component-bindings/src/handlers/createCommonHandlers.js +39 -26
- package/dist/dist-esm/calling-component-bindings/src/handlers/createCommonHandlers.js.map +1 -1
- package/dist/dist-esm/calling-component-bindings/src/participantListSelector.js +0 -1
- package/dist/dist-esm/calling-component-bindings/src/participantListSelector.js.map +1 -1
- package/dist/dist-esm/calling-component-bindings/src/videoGallerySelector.js.map +1 -1
- package/dist/dist-esm/calling-stateful-client/src/Converter.js.map +1 -1
- package/dist/dist-esm/calling-stateful-client/src/DeviceManagerDeclarative.d.ts +2 -2
- package/dist/dist-esm/calling-stateful-client/src/DeviceManagerDeclarative.js.map +1 -1
- package/dist/dist-esm/communication-react/src/index.d.ts +2 -0
- package/dist/dist-esm/communication-react/src/index.js.map +1 -1
- package/dist/dist-esm/react-components/src/components/ChatMessage/ChatMessageComponentAsMessageBubble.js +4 -1
- package/dist/dist-esm/react-components/src/components/ChatMessage/ChatMessageComponentAsMessageBubble.js.map +1 -1
- package/dist/dist-esm/react-components/src/components/Survey/StarSurvey/StarSurvey.d.ts +64 -0
- package/dist/dist-esm/react-components/src/components/Survey/StarSurvey/StarSurvey.js +54 -0
- package/dist/dist-esm/react-components/src/components/Survey/StarSurvey/StarSurvey.js.map +1 -0
- package/dist/dist-esm/react-components/src/components/Survey/StarSurvey/StarSurvey.styles.d.ts +14 -0
- package/dist/dist-esm/react-components/src/components/Survey/StarSurvey/StarSurvey.styles.js +39 -0
- package/dist/dist-esm/react-components/src/components/Survey/StarSurvey/StarSurvey.styles.js.map +1 -0
- package/dist/dist-esm/react-components/src/components/Survey/SurveyTypes.d.ts +141 -0
- package/dist/dist-esm/react-components/src/components/Survey/SurveyTypes.js +4 -0
- package/dist/dist-esm/react-components/src/components/Survey/SurveyTypes.js.map +1 -0
- package/dist/dist-esm/react-components/src/components/Survey/TagsSurvey/TagsSurvey.d.ts +59 -0
- package/dist/dist-esm/react-components/src/components/Survey/TagsSurvey/TagsSurvey.js +81 -0
- package/dist/dist-esm/react-components/src/components/Survey/TagsSurvey/TagsSurvey.js.map +1 -0
- package/dist/dist-esm/react-components/src/components/Survey/TagsSurvey/TagsSurvey.styles.d.ts +14 -0
- package/dist/dist-esm/react-components/src/components/Survey/TagsSurvey/TagsSurvey.styles.js +30 -0
- package/dist/dist-esm/react-components/src/components/Survey/TagsSurvey/TagsSurvey.styles.js.map +1 -0
- package/dist/dist-esm/react-components/src/components/index.d.ts +5 -0
- package/dist/dist-esm/react-components/src/components/index.js +6 -0
- package/dist/dist-esm/react-components/src/components/index.js.map +1 -1
- package/dist/dist-esm/react-components/src/components/styles/MessageThread.styles.d.ts +1 -1
- package/dist/dist-esm/react-components/src/components/styles/MessageThread.styles.js +13 -9
- package/dist/dist-esm/react-components/src/components/styles/MessageThread.styles.js.map +1 -1
- package/dist/dist-esm/react-components/src/index.d.ts +2 -0
- package/dist/dist-esm/react-components/src/index.js.map +1 -1
- package/dist/dist-esm/react-components/src/theming/icons.d.ts +2 -0
- package/dist/dist-esm/react-components/src/theming/icons.js +7 -1
- package/dist/dist-esm/react-components/src/theming/icons.js.map +1 -1
- package/dist/dist-esm/react-components/src/types/SurveyIssues.d.ts +45 -0
- package/dist/dist-esm/react-components/src/types/SurveyIssues.js +4 -0
- package/dist/dist-esm/react-components/src/types/SurveyIssues.js.map +1 -0
- package/dist/dist-esm/react-components/src/types/SurveyIssuesHeadingStrings.d.ts +11 -0
- package/dist/dist-esm/react-components/src/types/SurveyIssuesHeadingStrings.js +4 -0
- package/dist/dist-esm/react-components/src/types/SurveyIssuesHeadingStrings.js.map +1 -0
- package/dist/dist-esm/react-components/src/types/index.d.ts +2 -0
- package/dist/dist-esm/react-components/src/types/index.js +2 -0
- package/dist/dist-esm/react-components/src/types/index.js.map +1 -1
- package/dist/dist-esm/react-composites/src/composites/CallComposite/CallComposite.d.ts +33 -0
- package/dist/dist-esm/react-composites/src/composites/CallComposite/CallComposite.js +17 -7
- package/dist/dist-esm/react-composites/src/composites/CallComposite/CallComposite.js.map +1 -1
- package/dist/dist-esm/react-composites/src/composites/CallComposite/Strings.d.ts +61 -0
- package/dist/dist-esm/react-composites/src/composites/CallComposite/Strings.js.map +1 -1
- package/dist/dist-esm/react-composites/src/composites/CallComposite/adapter/AzureCommunicationCallAdapter.d.ts +2 -0
- package/dist/dist-esm/react-composites/src/composites/CallComposite/adapter/AzureCommunicationCallAdapter.js +11 -3
- package/dist/dist-esm/react-composites/src/composites/CallComposite/adapter/AzureCommunicationCallAdapter.js.map +1 -1
- package/dist/dist-esm/react-composites/src/composites/CallComposite/adapter/CallAdapter.d.ts +7 -0
- package/dist/dist-esm/react-composites/src/composites/CallComposite/adapter/CallAdapter.js.map +1 -1
- package/dist/dist-esm/react-composites/src/composites/CallComposite/components/CallControls.js +12 -1
- package/dist/dist-esm/react-composites/src/composites/CallComposite/components/CallControls.js.map +1 -1
- package/dist/dist-esm/react-composites/src/composites/CallComposite/hooks/useHandlers.js +4 -0
- package/dist/dist-esm/react-composites/src/composites/CallComposite/hooks/useHandlers.js.map +1 -1
- package/dist/dist-esm/react-composites/src/composites/CallComposite/pages/NoticePage.d.ts +33 -0
- package/dist/dist-esm/react-composites/src/composites/CallComposite/pages/NoticePage.js +9 -1
- package/dist/dist-esm/react-composites/src/composites/CallComposite/pages/NoticePage.js.map +1 -1
- package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/CallWithChatComposite.d.ts +33 -0
- package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/CallWithChatComposite.js +6 -0
- package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/CallWithChatComposite.js.map +1 -1
- package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/AzureCommunicationCallWithChatAdapter.d.ts +2 -0
- package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/AzureCommunicationCallWithChatAdapter.js +6 -0
- package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/AzureCommunicationCallWithChatAdapter.js.map +1 -1
- package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/CallWithChatAdapter.d.ts +7 -0
- package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/CallWithChatAdapter.js.map +1 -1
- package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/CallWithChatBackedCallAdapter.d.ts +2 -0
- package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/CallWithChatBackedCallAdapter.js +6 -0
- package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/CallWithChatBackedCallAdapter.js.map +1 -1
- package/dist/dist-esm/react-composites/src/composites/common/ControlBar/CommonCallControlBar.js +2 -5
- package/dist/dist-esm/react-composites/src/composites/common/ControlBar/CommonCallControlBar.js.map +1 -1
- package/dist/dist-esm/react-composites/src/composites/common/StarSurvey.d.ts +6 -0
- package/dist/dist-esm/react-composites/src/composites/common/StarSurvey.js +29 -0
- package/dist/dist-esm/react-composites/src/composites/common/StarSurvey.js.map +1 -0
- package/dist/dist-esm/react-composites/src/composites/common/SurveyPane.d.ts +7 -0
- package/dist/dist-esm/react-composites/src/composites/common/SurveyPane.js +23 -0
- package/dist/dist-esm/react-composites/src/composites/common/SurveyPane.js.map +1 -0
- package/dist/dist-esm/react-composites/src/composites/common/SurveyPaneContent.d.ts +10 -0
- package/dist/dist-esm/react-composites/src/composites/common/SurveyPaneContent.js +106 -0
- package/dist/dist-esm/react-composites/src/composites/common/SurveyPaneContent.js.map +1 -0
- package/dist/dist-esm/react-composites/src/composites/common/TagsSurvey.d.ts +8 -0
- package/dist/dist-esm/react-composites/src/composites/common/TagsSurvey.js +22 -0
- package/dist/dist-esm/react-composites/src/composites/common/TagsSurvey.js.map +1 -0
- package/dist/dist-esm/react-composites/src/composites/common/icons.d.ts +2 -0
- package/dist/dist-esm/react-composites/src/composites/localization/locales/en-US/strings.json +59 -0
- package/package.json +1 -1
@@ -170,7 +170,7 @@ function getDefaultExportFromCjs (x) {
|
|
170
170
|
// Copyright (c) Microsoft Corporation.
|
171
171
|
// Licensed under the MIT License.
|
172
172
|
// GENERATED FILE. DO NOT EDIT MANUALLY.
|
173
|
-
var telemetryVersion = '1.11.0-alpha-
|
173
|
+
var telemetryVersion = '1.11.0-alpha-202312150013';
|
174
174
|
|
175
175
|
|
176
176
|
var telemetryVersion$1 = /*@__PURE__*/getDefaultExportFromCjs(telemetryVersion);
|
@@ -793,38 +793,47 @@ const createDefaultCommonCallingHandlers = memoizeOne((callClient, deviceManager
|
|
793
793
|
});
|
794
794
|
const onToggleCamera = (options) => __awaiter$L(void 0, void 0, void 0, function* () {
|
795
795
|
const previewOn = _isPreviewOn(callClient.getState().deviceManager);
|
796
|
-
|
797
|
-
|
798
|
-
|
799
|
-
|
800
|
-
|
801
|
-
|
802
|
-
|
803
|
-
|
804
|
-
|
805
|
-
|
806
|
-
|
807
|
-
|
808
|
-
|
809
|
-
|
810
|
-
|
811
|
-
|
812
|
-
|
813
|
-
|
814
|
-
// local video stream to the stateful call client and get into a clean state.
|
815
|
-
yield onDisposeLocalStreamView();
|
816
|
-
return;
|
817
|
-
}
|
796
|
+
// the disposal of the unparented views is to workaround: https://skype.visualstudio.com/SPOOL/_workitems/edit/3030558.
|
797
|
+
// The root cause of the issue is caused by never transitioning the unparented view to the
|
798
|
+
// call object when going from configuration page (disconnected call state) to connecting.
|
799
|
+
//
|
800
|
+
// Currently the only time the local video stream is moved from unparented view to the call
|
801
|
+
// object is when we transition from connecting -> call state. If the camera was on,
|
802
|
+
// inside the MediaGallery we trigger toggleCamera. This triggers onStartLocalVideo which
|
803
|
+
// destroys the unparentedView and creates a new stream in the call - so all looks well.
|
804
|
+
//
|
805
|
+
// However, if someone turns off their camera during the lobbyOrConnecting screen, the
|
806
|
+
// call.localVideoStreams will be empty (as the stream is currently stored in the unparented
|
807
|
+
// views and was never transitioned to the call object) and thus we incorrectly try to create
|
808
|
+
// a new video stream for the call object, instead of only stopping the unparented view.
|
809
|
+
//
|
810
|
+
// The correct fix for this is to ensure that callAgent.onStartCall is called with the
|
811
|
+
// localvideostream as a videoOption. That will mean call.onLocalVideoStreamsUpdated will
|
812
|
+
// be triggered when the call is in connecting state, which we can then transition the
|
813
|
+
// local video stream to the stateful call client and get into a clean state.
|
818
814
|
if (call && (_isInCall(call.state) || _isInLobbyOrConnecting(call.state))) {
|
819
815
|
const stream = call.localVideoStreams.find((stream) => stream.mediaStreamType === 'Video');
|
820
|
-
|
821
|
-
|
816
|
+
const unparentedViews = callClient.getState().deviceManager.unparentedViews;
|
817
|
+
if (stream || unparentedViews.length > 0) {
|
818
|
+
unparentedViews &&
|
819
|
+
(yield unparentedViews.forEach((view) => view.mediaStreamType === 'Video' && callClient.disposeView(undefined, undefined, view)));
|
820
|
+
stream && (yield onStopLocalVideo(stream));
|
822
821
|
}
|
823
822
|
else {
|
824
823
|
yield onStartLocalVideo();
|
825
824
|
}
|
826
825
|
}
|
827
826
|
else {
|
827
|
+
/**
|
828
|
+
* This will create a unparented view to be used on the configuration page and the connecting screen
|
829
|
+
*
|
830
|
+
* If the device that the stream will come from is not on from permissions checks, then it will take time
|
831
|
+
* to create the stream since device is off. If we are turn the camera on immedietly on the configuration page we see it is
|
832
|
+
* fast but that is because the device is already primed to return a stream.
|
833
|
+
*
|
834
|
+
* On the connecting page the device has already turned off and the connecting window is so small we do not see the resulting
|
835
|
+
* unparented view from the code below.
|
836
|
+
*/
|
828
837
|
const selectedCamera = callClient.getState().deviceManager.selectedCamera;
|
829
838
|
if (selectedCamera) {
|
830
839
|
if (previewOn) {
|
@@ -891,7 +900,7 @@ const createDefaultCommonCallingHandlers = memoizeOne((callClient, deviceManager
|
|
891
900
|
}
|
892
901
|
});
|
893
902
|
const onToggleMicrophone = () => __awaiter$L(void 0, void 0, void 0, function* () {
|
894
|
-
if (!call || !_isInCall(call.state)) {
|
903
|
+
if (!call || !(_isInCall(call.state) || _isInLobbyOrConnecting(call.state))) {
|
895
904
|
throw new Error(`Please invoke onToggleMicrophone after call is started`);
|
896
905
|
}
|
897
906
|
return call.isMuted ? yield call.unmute() : yield call.mute();
|
@@ -1088,6 +1097,8 @@ const createDefaultCommonCallingHandlers = memoizeOne((callClient, deviceManager
|
|
1088
1097
|
const captionsFeature = call === null || call === void 0 ? void 0 : call.feature(communicationCalling.Features.Captions).captions;
|
1089
1098
|
yield captionsFeature.setCaptionLanguage(language);
|
1090
1099
|
});
|
1100
|
+
/* @conditional-compile-remove(end-of-call-survey) */
|
1101
|
+
const onSubmitSurvey = (survey) => __awaiter$L(void 0, void 0, void 0, function* () { return yield (call === null || call === void 0 ? void 0 : call.feature(communicationCalling.Features.CallSurvey).submitSurvey(survey, options)); });
|
1091
1102
|
return {
|
1092
1103
|
onHangUp,
|
1093
1104
|
/* @conditional-compile-remove(PSTN-calls) */
|
@@ -1133,7 +1144,9 @@ const createDefaultCommonCallingHandlers = memoizeOne((callClient, deviceManager
|
|
1133
1144
|
/* @conditional-compile-remove(close-captions) */
|
1134
1145
|
onSetCaptionLanguage,
|
1135
1146
|
/* @conditional-compile-remove(close-captions) */
|
1136
|
-
onSetSpokenLanguage
|
1147
|
+
onSetSpokenLanguage,
|
1148
|
+
/* @conditional-compile-remove(end-of-call-survey) */
|
1149
|
+
onSubmitSurvey
|
1137
1150
|
};
|
1138
1151
|
});
|
1139
1152
|
|
@@ -6283,7 +6296,11 @@ const DEFAULT_COMPONENT_ICONS = {
|
|
6283
6296
|
ChangeCaptionLanguageIcon: React.createElement(reactIcons.Translate20Regular, null),
|
6284
6297
|
ContextMenuCameraIcon: React.createElement(reactIcons.Video20Regular, null),
|
6285
6298
|
ContextMenuMicIcon: React.createElement(reactIcons.Mic20Regular, null),
|
6286
|
-
ContextMenuSpeakerIcon: React.createElement(reactIcons.Speaker220Regular, null)
|
6299
|
+
ContextMenuSpeakerIcon: React.createElement(reactIcons.Speaker220Regular, null),
|
6300
|
+
/* @conditional-compile-remove(end-of-call-survey) */
|
6301
|
+
SurveyStarIcon: React.createElement(reactIcons.Star28Regular, null),
|
6302
|
+
/* @conditional-compile-remove(end-of-call-survey) */
|
6303
|
+
SurveyStarIconFilled: React.createElement(reactIcons.Star28Filled, null)
|
6287
6304
|
};
|
6288
6305
|
|
6289
6306
|
// Copyright (c) Microsoft Corporation.
|
@@ -9012,11 +9029,20 @@ const useChatMessageStyles = reactComponents.makeStyles({
|
|
9012
9029
|
}, '& msft-mention': {
|
9013
9030
|
color: reactComponents.tokens.colorStatusWarningBackground3,
|
9014
9031
|
fontWeight: reactComponents.tokens.fontWeightSemibold
|
9015
|
-
}, '& img
|
9032
|
+
}, '& img': {
|
9033
|
+
maxWidth: '100% !important', // Add !important to make sure it won't be overridden by style defined in element
|
9034
|
+
height: 'auto !important'
|
9035
|
+
}, '& video': {
|
9036
|
+
maxWidth: '100% !important', // Add !important to make sure it won't be overridden by style defined in element
|
9037
|
+
height: 'auto !important'
|
9038
|
+
}, '& p': Object.assign({}, reactComponents.shorthands.marginBlock('0.125rem')), '& blockquote': Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({ backgroundColor: reactComponents.tokens.colorBrandBackgroundInverted, clear: 'left', minHeight: '2.25rem', width: 'fit-content', marginTop: '7px', marginRight: '0px', marginLeft: '0px', marginBottom: '7px', paddingTop: '7px', paddingRight: '15px', paddingLeft: '15px', paddingBottom: '7px' }, reactComponents.shorthands.border('solid')), reactComponents.shorthands.borderRadius('4px')), reactComponents.shorthands.borderWidth('1px')), reactComponents.shorthands.borderColor(reactComponents.tokens.colorNeutralStroke1Selected)), { borderLeftWidth: '4px' }), '& table': Object.assign(Object.assign({ backgroundColor: reactComponents.tokens.colorBrandBackgroundInverted }, reactComponents.shorthands.borderColor(reactComponents.tokens.colorNeutralStroke1Selected)), { borderCollapse: 'collapse', tableLayout: 'auto', width: '100%', '& tr': Object.assign(Object.assign({}, reactComponents.shorthands.border('1px', 'solid', `${reactComponents.tokens.colorNeutralStroke1Selected}`)), { '& td': Object.assign(Object.assign({}, reactComponents.shorthands.border('1px', 'solid', `${reactComponents.tokens.colorNeutralStroke1Selected}`)), { wordBreak: 'normal', paddingTop: '0px', paddingRight: '5px' }) }) }) }),
|
9039
|
+
bodyWithPlaceholderImage: {
|
9040
|
+
'& img[src=""]': {
|
9016
9041
|
display: 'block',
|
9017
9042
|
position: 'relative',
|
9018
9043
|
marginBottom: '5px'
|
9019
|
-
},
|
9044
|
+
},
|
9045
|
+
'& img[src=""]:after': {
|
9020
9046
|
backgroundColor: reactComponents.tokens.colorNeutralBackground1Selected,
|
9021
9047
|
content: `url("")`,
|
9022
9048
|
backgroundSize: 'center',
|
@@ -9026,13 +9052,8 @@ const useChatMessageStyles = reactComponents.makeStyles({
|
|
9026
9052
|
top: '0',
|
9027
9053
|
left: '0',
|
9028
9054
|
display: 'block'
|
9029
|
-
}
|
9030
|
-
|
9031
|
-
height: 'auto !important'
|
9032
|
-
}, '& video': {
|
9033
|
-
maxWidth: '100% !important', // Add !important to make sure it won't be overridden by style defined in element
|
9034
|
-
height: 'auto !important'
|
9035
|
-
}, '& p': Object.assign({}, reactComponents.shorthands.marginBlock('0.125rem')), '& blockquote': Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({ backgroundColor: reactComponents.tokens.colorBrandBackgroundInverted, clear: 'left', minHeight: '2.25rem', width: 'fit-content', marginTop: '7px', marginRight: '0px', marginLeft: '0px', marginBottom: '7px', paddingTop: '7px', paddingRight: '15px', paddingLeft: '15px', paddingBottom: '7px' }, reactComponents.shorthands.border('solid')), reactComponents.shorthands.borderRadius('4px')), reactComponents.shorthands.borderWidth('1px')), reactComponents.shorthands.borderColor(reactComponents.tokens.colorNeutralStroke1Selected)), { borderLeftWidth: '4px' }), '& table': Object.assign(Object.assign({ backgroundColor: reactComponents.tokens.colorBrandBackgroundInverted }, reactComponents.shorthands.borderColor(reactComponents.tokens.colorNeutralStroke1Selected)), { borderCollapse: 'collapse', tableLayout: 'auto', width: '100%', '& tr': Object.assign(Object.assign({}, reactComponents.shorthands.border('1px', 'solid', `${reactComponents.tokens.colorNeutralStroke1Selected}`)), { '& td': Object.assign(Object.assign({}, reactComponents.shorthands.border('1px', 'solid', `${reactComponents.tokens.colorNeutralStroke1Selected}`)), { wordBreak: 'normal', paddingTop: '0px', paddingRight: '5px' }) }) }) }),
|
9055
|
+
}
|
9056
|
+
},
|
9036
9057
|
bodyWithoutAvatar: {
|
9037
9058
|
marginTop: '0.125rem'
|
9038
9059
|
},
|
@@ -10630,7 +10651,10 @@ const MessageBubble = (props) => {
|
|
10630
10651
|
const chatMessageStyles = useChatMessageStyles();
|
10631
10652
|
const chatItemMessageContainerClassName = reactComponents.mergeClasses(
|
10632
10653
|
// messageContainerStyle used in className and style prop as style prop can't handle CSS selectors
|
10633
|
-
chatMessageStyles.body,
|
10654
|
+
chatMessageStyles.body,
|
10655
|
+
// disable placeholder functionality for GA releases as it might confuse users
|
10656
|
+
/* @conditional-compile-remove(teams-inline-images-and-file-sharing) */
|
10657
|
+
chatMessageStyles.bodyWithPlaceholderImage, isBlockedMessage
|
10634
10658
|
? chatMessageCommonStyles.blocked
|
10635
10659
|
: props.message.status === 'failed'
|
10636
10660
|
? chatMessageCommonStyles.failed
|
@@ -17797,6 +17821,197 @@ const sanitizeInput = (input) => {
|
|
17797
17821
|
return input.replace(/[^\d*#+]/g, '');
|
17798
17822
|
};
|
17799
17823
|
|
17824
|
+
// Copyright (c) Microsoft Corporation.
|
17825
|
+
// Licensed under the MIT License.
|
17826
|
+
/**
|
17827
|
+
* @private
|
17828
|
+
*/
|
17829
|
+
const helperTextStyle$1 = (theme) => react.mergeStyles({
|
17830
|
+
fontWeight: 600,
|
17831
|
+
fontSize: _pxToRem(14),
|
17832
|
+
lineHeight: _pxToRem(20),
|
17833
|
+
color: theme.palette.neutralPrimary,
|
17834
|
+
paddingTop: _pxToRem(20)
|
17835
|
+
});
|
17836
|
+
/**
|
17837
|
+
* @private
|
17838
|
+
*/
|
17839
|
+
const ratingStyles = (theme) => {
|
17840
|
+
return {
|
17841
|
+
root: {
|
17842
|
+
marginBottom: _pxToRem(24),
|
17843
|
+
textAlign: 'center'
|
17844
|
+
},
|
17845
|
+
ratingStar: {
|
17846
|
+
fontSize: _pxToRem(35),
|
17847
|
+
margin: _pxToRem(5)
|
17848
|
+
},
|
17849
|
+
ratingStarFront: {
|
17850
|
+
color: theme.palette.themePrimary
|
17851
|
+
}
|
17852
|
+
};
|
17853
|
+
};
|
17854
|
+
/**
|
17855
|
+
* @private
|
17856
|
+
*/
|
17857
|
+
const titleContainerClassName$1 = react.mergeStyles({
|
17858
|
+
paddingBottom: _pxToRem(6)
|
17859
|
+
});
|
17860
|
+
|
17861
|
+
// Copyright (c) Microsoft Corporation.
|
17862
|
+
// Licensed under the MIT License.
|
17863
|
+
/**
|
17864
|
+
* A component to allow users to send numerical ratings regarding call quality
|
17865
|
+
*
|
17866
|
+
* @internal
|
17867
|
+
*/
|
17868
|
+
const _StarSurvey = (props) => {
|
17869
|
+
const { onStarRatingSelected, selectedIcon, unselectedIcon, strings } = props;
|
17870
|
+
const [rating, setRating] = React.useState(0);
|
17871
|
+
const [helperText, setHelperText] = React.useState(strings === null || strings === void 0 ? void 0 : strings.starSurveyHelperText);
|
17872
|
+
const theme = react.useTheme();
|
17873
|
+
const onRatingChange = React.useCallback((ev, rating) => {
|
17874
|
+
if (rating) {
|
17875
|
+
setRating(rating);
|
17876
|
+
switch (rating) {
|
17877
|
+
case 1:
|
17878
|
+
setHelperText(strings === null || strings === void 0 ? void 0 : strings.starSurveyOneStarText);
|
17879
|
+
break;
|
17880
|
+
case 2:
|
17881
|
+
setHelperText(strings === null || strings === void 0 ? void 0 : strings.starSurveyTwoStarText);
|
17882
|
+
break;
|
17883
|
+
case 3:
|
17884
|
+
setHelperText(strings === null || strings === void 0 ? void 0 : strings.starSurveyThreeStarText);
|
17885
|
+
break;
|
17886
|
+
case 4:
|
17887
|
+
setHelperText(strings === null || strings === void 0 ? void 0 : strings.starSurveyFourStarText);
|
17888
|
+
break;
|
17889
|
+
case 5:
|
17890
|
+
setHelperText(strings === null || strings === void 0 ? void 0 : strings.starSurveyFiveStarText);
|
17891
|
+
break;
|
17892
|
+
}
|
17893
|
+
onStarRatingSelected === null || onStarRatingSelected === void 0 ? void 0 : onStarRatingSelected(rating);
|
17894
|
+
}
|
17895
|
+
}, [
|
17896
|
+
strings === null || strings === void 0 ? void 0 : strings.starSurveyOneStarText,
|
17897
|
+
strings === null || strings === void 0 ? void 0 : strings.starSurveyTwoStarText,
|
17898
|
+
strings === null || strings === void 0 ? void 0 : strings.starSurveyThreeStarText,
|
17899
|
+
strings === null || strings === void 0 ? void 0 : strings.starSurveyFourStarText,
|
17900
|
+
strings === null || strings === void 0 ? void 0 : strings.starSurveyFiveStarText,
|
17901
|
+
onStarRatingSelected
|
17902
|
+
]);
|
17903
|
+
return (React.createElement(react.Stack, { verticalAlign: "center" },
|
17904
|
+
React.createElement(react.Stack, { className: titleContainerClassName$1 },
|
17905
|
+
React.createElement(react.Text, { className: helperTextStyle$1(theme) }, helperText)),
|
17906
|
+
React.createElement(react.Rating, { max: 5, size: react.RatingSize.Large, defaultRating: 0, allowZeroStars: true, rating: rating, onChange: onRatingChange, styles: ratingStyles(theme), icon: selectedIcon !== null && selectedIcon !== void 0 ? selectedIcon : 'SurveyStarIconFilled', unselectedIcon: unselectedIcon !== null && unselectedIcon !== void 0 ? unselectedIcon : 'SurveyStarIcon', ariaLabelFormat: strings === null || strings === void 0 ? void 0 : strings.starRatingAriaLabel })));
|
17907
|
+
};
|
17908
|
+
|
17909
|
+
// Copyright (c) Microsoft Corporation.
|
17910
|
+
// Licensed under the MIT License.
|
17911
|
+
/**
|
17912
|
+
* @private
|
17913
|
+
*/
|
17914
|
+
const questionTextStyle = (theme) => react.mergeStyles({
|
17915
|
+
fontWeight: 600,
|
17916
|
+
fontSize: _pxToRem(14),
|
17917
|
+
lineHeight: _pxToRem(20),
|
17918
|
+
color: theme.palette.neutralPrimary,
|
17919
|
+
paddingTop: _pxToRem(20)
|
17920
|
+
});
|
17921
|
+
/**
|
17922
|
+
* @private
|
17923
|
+
*/
|
17924
|
+
const helperTextStyle = (theme) => react.mergeStyles({
|
17925
|
+
fontWeight: 400,
|
17926
|
+
fontSize: _pxToRem(12),
|
17927
|
+
lineHeight: _pxToRem(16),
|
17928
|
+
color: theme.palette.neutralPrimary
|
17929
|
+
});
|
17930
|
+
/**
|
17931
|
+
* @private
|
17932
|
+
*/
|
17933
|
+
const checkboxClassName = react.mergeStyles({
|
17934
|
+
padding: _pxToRem(8)
|
17935
|
+
});
|
17936
|
+
|
17937
|
+
// Copyright (c) Microsoft Corporation.
|
17938
|
+
// Licensed under the MIT License.
|
17939
|
+
/**
|
17940
|
+
* A component to allow users to send numerical ratings regarding call quality
|
17941
|
+
*
|
17942
|
+
* @internal
|
17943
|
+
*/
|
17944
|
+
const _TagsSurvey = (props) => {
|
17945
|
+
const { issues, callIssuesToTag, categoryHeadings, onConfirm, strings } = props;
|
17946
|
+
const [selectedTags, setSelectedTags] = React.useState({});
|
17947
|
+
const tags = React.useMemo(() => {
|
17948
|
+
const tags = [];
|
17949
|
+
issues.forEach((issue) => {
|
17950
|
+
const issueCamelCase = (issue === null || issue === void 0 ? void 0 : issue.charAt(0).toLowerCase()) + (issue === null || issue === void 0 ? void 0 : issue.slice(1));
|
17951
|
+
const issueCategory = Object.keys(callIssuesToTag).find((key) => callIssuesToTag[key][issueCamelCase] !== undefined);
|
17952
|
+
if (issueCategory) {
|
17953
|
+
if (tags[issueCategory]) {
|
17954
|
+
tags[issueCategory].push({
|
17955
|
+
message: callIssuesToTag[issueCategory][issueCamelCase],
|
17956
|
+
issue: issue
|
17957
|
+
});
|
17958
|
+
}
|
17959
|
+
else {
|
17960
|
+
tags[issueCategory] = [
|
17961
|
+
{
|
17962
|
+
message: callIssuesToTag[issueCategory][issueCamelCase],
|
17963
|
+
issue: issue
|
17964
|
+
}
|
17965
|
+
];
|
17966
|
+
}
|
17967
|
+
}
|
17968
|
+
});
|
17969
|
+
return tags;
|
17970
|
+
}, [issues, callIssuesToTag]);
|
17971
|
+
const onChange = React.useCallback((issue, issueCategory, checked) => {
|
17972
|
+
if (checked) {
|
17973
|
+
setSelectedTags((prevState) => {
|
17974
|
+
if (prevState[issueCategory]) {
|
17975
|
+
prevState[issueCategory].issues.push(issue);
|
17976
|
+
}
|
17977
|
+
else {
|
17978
|
+
prevState[issueCategory] = { score: 1, issues: [issue] };
|
17979
|
+
}
|
17980
|
+
return prevState;
|
17981
|
+
});
|
17982
|
+
}
|
17983
|
+
else {
|
17984
|
+
setSelectedTags((prevState) => {
|
17985
|
+
if (prevState[issueCategory]) {
|
17986
|
+
prevState[issueCategory].issues = prevState[issueCategory].issues.filter(function (value) {
|
17987
|
+
return value !== issue;
|
17988
|
+
});
|
17989
|
+
if (prevState[issueCategory].issues.length === 0) {
|
17990
|
+
delete prevState[issueCategory];
|
17991
|
+
}
|
17992
|
+
}
|
17993
|
+
return prevState;
|
17994
|
+
});
|
17995
|
+
}
|
17996
|
+
if (onConfirm) {
|
17997
|
+
onConfirm(selectedTags);
|
17998
|
+
}
|
17999
|
+
}, [onConfirm, selectedTags]);
|
18000
|
+
const theme = react.useTheme();
|
18001
|
+
return (React.createElement(React.Fragment, null,
|
18002
|
+
React.createElement(react.Stack, { verticalAlign: "center" },
|
18003
|
+
React.createElement(react.Text, { className: questionTextStyle(theme) }, strings === null || strings === void 0 ? void 0 : strings.tagsSurveyQuestion),
|
18004
|
+
React.createElement(react.Text, { className: helperTextStyle(theme) }, strings === null || strings === void 0 ? void 0 : strings.tagsSurveyHelperText)),
|
18005
|
+
React.createElement(react.Pivot, null, Object.keys(tags).map((key, i) => {
|
18006
|
+
return (React.createElement(react.PivotItem, { key: `key-${i}`, headerText: categoryHeadings[key], headerButtonProps: {
|
18007
|
+
'data-order': i,
|
18008
|
+
'data-title': key
|
18009
|
+
}, alwaysRender: true }, tags[key].map((t, i) => {
|
18010
|
+
return (React.createElement(react.Checkbox, { className: checkboxClassName, key: `checkBox_${i}`, label: t.message, onChange: (ev, checked) => onChange(t.issue, key, checked !== null && checked !== void 0 ? checked : false) }));
|
18011
|
+
})));
|
18012
|
+
}))));
|
18013
|
+
};
|
18014
|
+
|
17800
18015
|
// Copyright (c) Microsoft Corporation.
|
17801
18016
|
// Licensed under the MIT License.
|
17802
18017
|
/**
|
@@ -19159,7 +19374,6 @@ const convertRemoteParticipantToParticipantListParticipantBeta = (userId, displa
|
|
19159
19374
|
// Copyright (c) Microsoft Corporation.
|
19160
19375
|
// Licensed under the MIT License.
|
19161
19376
|
const convertRemoteParticipantsToParticipantListParticipants = (remoteParticipants, localUserCanRemoveOthers, isHideAttendeeNamesEnabled, localUserRole) => {
|
19162
|
-
/* eslint-disable @typescript-eslint/explicit-function-return-type */
|
19163
19377
|
const conversionCallback = (memoizeFn) => {
|
19164
19378
|
return (remoteParticipants
|
19165
19379
|
// Filter out MicrosoftBot participants
|
@@ -21690,7 +21904,7 @@ const CallCompositeIcon = (props) => (React.createElement(react.FontIcon, Object
|
|
21690
21904
|
*/
|
21691
21905
|
const CallWithChatCompositeIcon = (props) => (React.createElement(react.FontIcon, Object.assign({}, props)));
|
21692
21906
|
|
21693
|
-
var call$k={cameraLabel:"Camera",noCamerasLabel:"No cameras found",cameraPermissionDenied:"Your browser is blocking access to your camera",cameraTurnedOff:"Your camera is turned off",chatButtonLabel:"Chat",close:"Close",complianceBannerNowOnlyRecording:"You are now only recording this meeting.",complianceBannerNowOnlyTranscription:"You are now only transcribing this meeting.",complianceBannerRecordingAndTranscriptionSaved:"Recording and transcription are being saved.",complianceBannerRecordingAndTranscriptionStarted:"Recording and transcription have started.",complianceBannerRecordingAndTranscriptionStopped:"Recording and transcription have stopped.",complianceBannerRecordingSaving:"Recording is being saved.",complianceBannerRecordingStarted:"Recording has started.",complianceBannerRecordingStopped:"Recording has stopped.",complianceBannerTranscriptionStarted:"Transcription has started.",complianceBannerTranscriptionConsent:"By joining, you are giving consent for this meeting to be transcribed.",complianceBannerTranscriptionSaving:"Transcription is being saved.",complianceBannerTranscriptionStopped:"Transcription has stopped.",configurationPageTitle:"Start a call",copyInviteLinkButtonLabel:"Copy invite link",copyInviteLinkActionedAriaLabel:"Invite link copied",defaultPlaceHolder:"Select an option",dismissSidePaneButtonLabel:"Close",videoEffectsPaneTitle:"Effects",videoEffectsPaneBackgroundSelectionTitle:"Background",configurationPageVideoEffectsButtonLabel:"Effects",unableToStartVideoEffect:"Unable to apply video effect.",blurBackgroundEffectButtonLabel:"Blur",blurBackgroundTooltip:"Blur Background",removeBackgroundEffectButtonLabel:"None",removeBackgroundTooltip:"Remove Background",cameraOffBackgroundEffectWarningText:"Your camera is off. Turn on camera to see video effect.",failedToJoinCallDueToNoNetworkMoreDetails:"Call was disconnected due to a network issue. Check your connection and join again.",failedToJoinCallDueToNoNetworkTitle:"Call disconnected",failedToJoinTeamsMeetingReasonAccessDeniedMoreDetails:"You were not granted entry in the call. If this was a mistake, re-join the call.",failedToJoinTeamsMeetingReasonAccessDeniedTitle:"Dismissed from lobby",learnMore:"Learn more",leavingCallTitle:"Leaving...",leftCallMoreDetails:"If this was a mistake, re-join the call.",leftCallTitle:"You left the call",lobbyScreenConnectingToCallTitle:"Joining call",lobbyScreenWaitingToBeAdmittedTitle:"Waiting to be admitted",microphonePermissionDenied:"Your browser is blocking access to your microphone",microphoneToggleInLobbyNotAllowed:"Cannot mute or unmute while in lobby.",mutedMessage:"You're muted",networkReconnectMoreDetails:"Looks like something went wrong. We're trying to get back into the call.",networkReconnectTitle:"Hold on",notInvitedToRoomDetails:"You are not able to join this room because you do not have an invite.",notInvitedToRoomTitle:"Not invited to room",peopleButtonLabel:"People",selectedPeopleButtonLabel:"People Button Selected",peoplePaneTitle:"People",peopleButtonTooltipOpen:"Show participants",peopleButtonTooltipClose:"Hide participants",peoplePaneSubTitle:"In this call {numberOfPeople}",privacyPolicy:"Privacy policy",rejoinCallButtonLabel:"Re-join call",removedFromCallMoreDetails:"Another participant removed you from the call.",removedFromCallTitle:"You were removed",removeMenuLabel:"Remove",returnToCallButtonAriaDescription:"Return to Call",returnToCallButtonAriaLabel:"Back",roomNotFoundDetails:"The room ID provided could not be found.",roomNotFoundTitle:"Room not found",roomNotValidDetails:"This room is not valid at this current time.",roomNotValidTitle:"Room not valid",inviteToRoomRemovedDetails:"Your invite to join this room was removed.",inviteToRoomRemovedTitle:"Invite to room removed",soundLabel:"Sound",noMicrophonesLabel:"No microphones found",noSpeakersLabel:"No speakers found",startCallButtonLabel:"Start call",openDialpadButtonLabel:"Dial phone number",peoplePaneAddPeopleButtonLabel:"Add People",dialpadStartCallButtonLabel:"Call",dialpadModalTitle:"Dial Phone Number",dialpadModalAriaLabel:"Dialpad",dialpadCloseModalButtonAriaLabel:"Close dialpad",moreButtonCallingLabel:"More",resumeCallButtonLabel:"Resume",resumingCallButtonLabel:"Resuming...",resumeCallButtonAriaLabel:"Resume call",resumingCallButtonAriaLabel:"Resume call",holdScreenLabel:"You're on hold",openDtmfDialpadLabel:"Show dialpad",dtmfDialpadPlaceholderText:"Enter number",outboundCallingNoticeString:"Calling...",participantJoinedNoticeString:"{displayName} joined",twoParticipantJoinedNoticeString:"{displayName1} and {displayName2} have joined",threeParticipantJoinedNoticeString:"{displayName1}, {displayName2} and {displayName3} have joined",participantLeftNoticeString:"{displayName} left",twoParticipantLeftNoticeString:"{displayName1} and {displayName2} have left",threeParticipantLeftNoticeString:"{displayName1}, {displayName2} and {displayName3} have left",unnamedParticipantString:"unnamed participant",manyUnnamedParticipantsJoined:"unnamed participant and {numOfParticipants} other participants joined",manyUnnamedParticipantsLeft:"unnamed participant and {numOfParticipants} other participants left",manyParticipantsJoined:"{displayName1}, {displayName2}, {displayName3} and {numOfParticipants} other participants joined",manyParticipantsLeft:"{displayName1}, {displayName2}, {displayName3} and {numOfParticipants} other participants left",liveCaptionsLabel:"Live captions",captionsSettingsLabel:"Caption settings",startCaptionsButtonOnLabel:"Turn on captions",startCaptionsButtonOffLabel:"Turn off captions",startCaptionsButtonTooltipOnContent:"Turn off captions",startCaptionsButtonTooltipOffContent:"Turn on captions",captionsSettingsModalTitle:"Captions Settings",captionsSettingsSpokenLanguageDropdownLabel:"Spoken language",captionsSettingsCaptionLanguageDropdownLabel:"Captions language",captionsSettingsSpokenLanguageDropdownInfoText:"Language that everyone on this call is speaking.",captionsSettingsCaptionLanguageDropdownInfoText:"Captions will appear in this langugage.",captionsSettingsConfirmButtonLabel:"Confirm",captionsSettingsCancelButtonLabel:"Cancel",captionsSettingsModalAriaLabel:"Captions Setting Modal",captionsSettingsCloseModalButtonAriaLabel:"Close Captions Setting",captionsBannerMoreButtonCallingLabel:"More",captionsBannerMoreButtonTooltip:"More options",dismissModalAriaLabel:"Local and remote picture and picture, press enter to return to call",callRejectedTitle:"The call could not be completed",callRejectedMoreDetails:"The person you are trying to reach is unavailable. Please try again later.",spokenLanguageStrings:{"ar-ae":"Arabic - U.A.E.","ar-sa":"Arabic - Saudi Arabia","da-dk":"Danish","de-de":"German - Germany","en-au":"English - Australia","en-ca":"English - Canada","en-gb":"English - United Kingdom","en-in":"English - India","en-nz":"English - New Zealand","en-us":"English - United States","es-es":"Spanish - Spain (Modern Sort)","es-mx":"Spanish - Mexico","fi-fi":"Finnish","fr-ca":"French - Canada","fr-fr":"French - France","hi-in":"Hindi","it-it":"Italian - Italy","ja-jp":"Japanese","ko-kr":"Korean","nb-no":"Norwegian (Bokmål)","nl-be":"Dutch - Belgium","nl-nl":"Dutch - Netherlands","pl-pl":"Polish","pt-br":"Portuguese - Brazil","ru-ru":"Russian","sv-se":"Swedish","zh-cn":"Chinese - People's Republic of China","zh-hk":"Chinese - Hong Kong SAR","cs-cz":"Czech","pt-pt":"Portuguese - Portugal","tr-tr":"Turkish","vi-vn":"Vietnamese","th-th":"Thai","he-il":"Hebrew","cy-gb":"Welsh","uk-ua":"Ukrainian","el-gr":"Greek","hu-hu":"Hungarian","ro-ro":"Romanian","sk-sk":"Slovak","zh-tw":"Chinese - Taiwan"},captionLanguageStrings:{ar:"Arabic",da:"Danish",de:"German",en:"English",es:"Spanish",fi:"Finnish","fr-ca":"French - Canada",fr:"French - France",hi:"Hindi",it:"Italian",ja:"Japanese",ko:"Korean",nb:"Norwegian (Bokmål)",nl:"Dutch",pl:"Polish",pt:"Portuguese - Brazil",ru:"Russian",sv:"Swedish","zh-Hans":"Chinese (Simplified)","zh-Hant":"Chinese (Traditional)",cs:"Czech","pt-pt":"Portuguese - Portugal",tr:"Turkish",vi:"Vietnamese",th:"Thai",he:"Hebrew",cy:"Welsh",uk:"Ukrainian",el:"Greek",hu:"Hungarian",ro:"Romanian",sk:"Slovak"},captionsBannerSpinnerText:"Starting captions...",transferPageTransferorText:"Transferring...",transferPageTransferTargetText:"Connecting...",transferPageUnknownTransferorDisplayName:"Unknown",transferPageUnknownTransferTargetDisplayName:"Unknown",transferPageNoticeString:"You are being transferred",participantCouldNotBeReachedTitle:"Target participant is currently not available",participantCouldNotBeReachedMoreDetails:"Please contact participant when they are available",permissionToReachTargetParticipantNotAllowedTitle:"Permission to reach target participant is not allowed",permissionToReachTargetParticipantNotAllowedMoreDetails:"Please check that the target participant is in the same tenant",unableToResolveTenantTitle:"Unable to resolve tenant id for the target participant",unableToResolveTenantMoreDetails:"Please check the participant id is entered correctly",participantIdIsMalformedTitle:"Participant id is not in the correct format",participantIdIsMalformedMoreDetails:"Please check that the participant id is in the correct format",moreButtonGalleryControlLabel:"View",moreButtonGalleryPositionToggleLabel:"Move gallery to top",moreButtonGallerySpeakerLayoutLabel:"Speaker",moreButtonGalleryFloatingLocalLayoutLabel:"Dynamic",moreButtonGalleryDefaultLayoutLabel:"Gallery view",moreButtonGalleryFocusedContentLayoutLabel:"Focus on content",moreButtonLargeGalleryDefaultLayoutLabel:"Large Gallery",capabilityChangedNotification:{turnVideoOn:{lostDueToMeetingOption:"Your camera has been disabled. You can no longer share video.",grantedDueToMeetingOption:"Your camera has been enabled. Turn it on if you'd like to share video."},unmuteMic:{lostDueToMeetingOption:"Your mic has been disabled. You can no longer unmute.",grantedDueToMeetingOption:"Your mic has been enabled. Unmute if you'd like to speak."},shareScreen:{lostDueToRoleChangeToAttendee:"Your role has been changed. Some actions, like sharing content, won't be available to you.",grantedDueToRoleChangeToPresenter:"You're a presenter. You can share content and facilitate the meeting."}}};var chat$k={chatListHeader:"In this chat",uploadFile:"Upload File"};var callWithChat$k={chatButtonLabel:"Chat",chatButtonNewMessageNotificationLabel:"New Message",chatButtonTooltipClosedWithMessageCount:"Show chat ({unreadMessagesCount} unread)",chatButtonTooltipClose:"Hide chat",chatButtonTooltipOpen:"Show chat",chatPaneTitle:"Chat",copyInviteLinkButtonLabel:"Copy invite link",copyInviteLinkActionedAriaLabel:"Invite link copied",dismissSidePaneButtonLabel:"Close",moreDrawerAudioDeviceMenuTitle:"Audio Device",moreDrawerButtonLabel:"More options",moreDrawerButtonTooltip:"More options",moreDrawerMicrophoneMenuTitle:"Microphone",moreDrawerSpeakerMenuTitle:"Speaker",moreDrawerCaptionsMenuTitle:"Live captions",moreDrawerSpokenLanguageMenuTitle:"Spoken language",moreDrawerCaptionLanguageMenuTitle:"Caption language",moreDrawerGalleryOptionsMenuTitle:"Gallery options",peopleButtonLabel:"People",selectedPeopleButtonLabel:"People Button Selected",peopleButtonTooltipOpen:"Show participants",peopleButtonTooltipClose:"Hide participants",peoplePaneSubTitle:"In this call",peoplePaneTitle:"People",pictureInPictureTileAriaLabel:"Video Feeds. Click to return to call screen.",removeMenuLabel:"Remove",openDialpadButtonLabel:"Dial phone number",returnToCallButtonAriaDescription:"Return to Call",returnToCallButtonAriaLabel:"Back",peoplePaneAddPeopleButtonLabel:"Add People",dialpadStartCallButtonLabel:"Call",dialpadModalTitle:"Dial Phone Number",dialpadModalAriaLabel:"Dialpad",dialpadCloseModalButtonAriaLabel:"Close dialpad",openDtmfDialpadLabel:"Show dialpad",dtmfDialpadPlaceholderText:"Enter number"};var en_US = {call:call$k,chat:chat$k,callWithChat:callWithChat$k};
|
21907
|
+
var call$k={cameraLabel:"Camera",noCamerasLabel:"No cameras found",cameraPermissionDenied:"Your browser is blocking access to your camera",cameraTurnedOff:"Your camera is turned off",chatButtonLabel:"Chat",close:"Close",complianceBannerNowOnlyRecording:"You are now only recording this meeting.",complianceBannerNowOnlyTranscription:"You are now only transcribing this meeting.",complianceBannerRecordingAndTranscriptionSaved:"Recording and transcription are being saved.",complianceBannerRecordingAndTranscriptionStarted:"Recording and transcription have started.",complianceBannerRecordingAndTranscriptionStopped:"Recording and transcription have stopped.",complianceBannerRecordingSaving:"Recording is being saved.",complianceBannerRecordingStarted:"Recording has started.",complianceBannerRecordingStopped:"Recording has stopped.",complianceBannerTranscriptionStarted:"Transcription has started.",complianceBannerTranscriptionConsent:"By joining, you are giving consent for this meeting to be transcribed.",complianceBannerTranscriptionSaving:"Transcription is being saved.",complianceBannerTranscriptionStopped:"Transcription has stopped.",configurationPageTitle:"Start a call",copyInviteLinkButtonLabel:"Copy invite link",copyInviteLinkActionedAriaLabel:"Invite link copied",defaultPlaceHolder:"Select an option",dismissSidePaneButtonLabel:"Close",videoEffectsPaneTitle:"Effects",videoEffectsPaneBackgroundSelectionTitle:"Background",configurationPageVideoEffectsButtonLabel:"Effects",unableToStartVideoEffect:"Unable to apply video effect.",blurBackgroundEffectButtonLabel:"Blur",blurBackgroundTooltip:"Blur Background",removeBackgroundEffectButtonLabel:"None",removeBackgroundTooltip:"Remove Background",cameraOffBackgroundEffectWarningText:"Your camera is off. Turn on camera to see video effect.",failedToJoinCallDueToNoNetworkMoreDetails:"Call was disconnected due to a network issue. Check your connection and join again.",failedToJoinCallDueToNoNetworkTitle:"Call disconnected",failedToJoinTeamsMeetingReasonAccessDeniedMoreDetails:"You were not granted entry in the call. If this was a mistake, re-join the call.",failedToJoinTeamsMeetingReasonAccessDeniedTitle:"Dismissed from lobby",learnMore:"Learn more",leavingCallTitle:"Leaving...",leftCallMoreDetails:"If this was a mistake, re-join the call.",leftCallTitle:"You left the call",lobbyScreenConnectingToCallTitle:"Joining call",lobbyScreenWaitingToBeAdmittedTitle:"Waiting to be admitted",microphonePermissionDenied:"Your browser is blocking access to your microphone",microphoneToggleInLobbyNotAllowed:"Cannot mute or unmute while in lobby.",mutedMessage:"You're muted",networkReconnectMoreDetails:"Looks like something went wrong. We're trying to get back into the call.",networkReconnectTitle:"Hold on",notInvitedToRoomDetails:"You are not able to join this room because you do not have an invite.",notInvitedToRoomTitle:"Not invited to room",peopleButtonLabel:"People",selectedPeopleButtonLabel:"People Button Selected",peoplePaneTitle:"People",peopleButtonTooltipOpen:"Show participants",peopleButtonTooltipClose:"Hide participants",peoplePaneSubTitle:"In this call {numberOfPeople}",privacyPolicy:"Privacy policy",rejoinCallButtonLabel:"Re-join call",removedFromCallMoreDetails:"Another participant removed you from the call.",removedFromCallTitle:"You were removed",removeMenuLabel:"Remove",returnToCallButtonAriaDescription:"Return to Call",returnToCallButtonAriaLabel:"Back",roomNotFoundDetails:"The room ID provided could not be found.",roomNotFoundTitle:"Room not found",roomNotValidDetails:"This room is not valid at this current time.",roomNotValidTitle:"Room not valid",inviteToRoomRemovedDetails:"Your invite to join this room was removed.",inviteToRoomRemovedTitle:"Invite to room removed",soundLabel:"Sound",noMicrophonesLabel:"No microphones found",noSpeakersLabel:"No speakers found",startCallButtonLabel:"Start call",openDialpadButtonLabel:"Dial phone number",peoplePaneAddPeopleButtonLabel:"Add People",dialpadStartCallButtonLabel:"Call",dialpadModalTitle:"Dial Phone Number",dialpadModalAriaLabel:"Dialpad",dialpadCloseModalButtonAriaLabel:"Close dialpad",moreButtonCallingLabel:"More",resumeCallButtonLabel:"Resume",resumingCallButtonLabel:"Resuming...",resumeCallButtonAriaLabel:"Resume call",resumingCallButtonAriaLabel:"Resume call",holdScreenLabel:"You're on hold",openDtmfDialpadLabel:"Show dialpad",dtmfDialpadPlaceholderText:"Enter number",outboundCallingNoticeString:"Calling...",participantJoinedNoticeString:"{displayName} joined",twoParticipantJoinedNoticeString:"{displayName1} and {displayName2} have joined",threeParticipantJoinedNoticeString:"{displayName1}, {displayName2} and {displayName3} have joined",participantLeftNoticeString:"{displayName} left",twoParticipantLeftNoticeString:"{displayName1} and {displayName2} have left",threeParticipantLeftNoticeString:"{displayName1}, {displayName2} and {displayName3} have left",unnamedParticipantString:"unnamed participant",manyUnnamedParticipantsJoined:"unnamed participant and {numOfParticipants} other participants joined",manyUnnamedParticipantsLeft:"unnamed participant and {numOfParticipants} other participants left",manyParticipantsJoined:"{displayName1}, {displayName2}, {displayName3} and {numOfParticipants} other participants joined",manyParticipantsLeft:"{displayName1}, {displayName2}, {displayName3} and {numOfParticipants} other participants left",liveCaptionsLabel:"Live captions",captionsSettingsLabel:"Caption settings",startCaptionsButtonOnLabel:"Turn on captions",startCaptionsButtonOffLabel:"Turn off captions",startCaptionsButtonTooltipOnContent:"Turn off captions",startCaptionsButtonTooltipOffContent:"Turn on captions",captionsSettingsModalTitle:"Captions Settings",captionsSettingsSpokenLanguageDropdownLabel:"Spoken language",captionsSettingsCaptionLanguageDropdownLabel:"Captions language",captionsSettingsSpokenLanguageDropdownInfoText:"Language that everyone on this call is speaking.",captionsSettingsCaptionLanguageDropdownInfoText:"Captions will appear in this langugage.",captionsSettingsConfirmButtonLabel:"Confirm",captionsSettingsCancelButtonLabel:"Cancel",captionsSettingsModalAriaLabel:"Captions Setting Modal",captionsSettingsCloseModalButtonAriaLabel:"Close Captions Setting",captionsBannerMoreButtonCallingLabel:"More",captionsBannerMoreButtonTooltip:"More options",dismissModalAriaLabel:"Local and remote picture and picture, press enter to return to call",callRejectedTitle:"The call could not be completed",callRejectedMoreDetails:"The person you are trying to reach is unavailable. Please try again later.",spokenLanguageStrings:{"ar-ae":"Arabic - U.A.E.","ar-sa":"Arabic - Saudi Arabia","da-dk":"Danish","de-de":"German - Germany","en-au":"English - Australia","en-ca":"English - Canada","en-gb":"English - United Kingdom","en-in":"English - India","en-nz":"English - New Zealand","en-us":"English - United States","es-es":"Spanish - Spain (Modern Sort)","es-mx":"Spanish - Mexico","fi-fi":"Finnish","fr-ca":"French - Canada","fr-fr":"French - France","hi-in":"Hindi","it-it":"Italian - Italy","ja-jp":"Japanese","ko-kr":"Korean","nb-no":"Norwegian (Bokmål)","nl-be":"Dutch - Belgium","nl-nl":"Dutch - Netherlands","pl-pl":"Polish","pt-br":"Portuguese - Brazil","ru-ru":"Russian","sv-se":"Swedish","zh-cn":"Chinese - People's Republic of China","zh-hk":"Chinese - Hong Kong SAR","cs-cz":"Czech","pt-pt":"Portuguese - Portugal","tr-tr":"Turkish","vi-vn":"Vietnamese","th-th":"Thai","he-il":"Hebrew","cy-gb":"Welsh","uk-ua":"Ukrainian","el-gr":"Greek","hu-hu":"Hungarian","ro-ro":"Romanian","sk-sk":"Slovak","zh-tw":"Chinese - Taiwan"},captionLanguageStrings:{ar:"Arabic",da:"Danish",de:"German",en:"English",es:"Spanish",fi:"Finnish","fr-ca":"French - Canada",fr:"French - France",hi:"Hindi",it:"Italian",ja:"Japanese",ko:"Korean",nb:"Norwegian (Bokmål)",nl:"Dutch",pl:"Polish",pt:"Portuguese - Brazil",ru:"Russian",sv:"Swedish","zh-Hans":"Chinese (Simplified)","zh-Hant":"Chinese (Traditional)",cs:"Czech","pt-pt":"Portuguese - Portugal",tr:"Turkish",vi:"Vietnamese",th:"Thai",he:"Hebrew",cy:"Welsh",uk:"Ukrainian",el:"Greek",hu:"Hungarian",ro:"Romanian",sk:"Slovak"},captionsBannerSpinnerText:"Starting captions...",transferPageTransferorText:"Transferring...",transferPageTransferTargetText:"Connecting...",transferPageUnknownTransferorDisplayName:"Unknown",transferPageUnknownTransferTargetDisplayName:"Unknown",transferPageNoticeString:"You are being transferred",participantCouldNotBeReachedTitle:"Target participant is currently not available",participantCouldNotBeReachedMoreDetails:"Please contact participant when they are available",permissionToReachTargetParticipantNotAllowedTitle:"Permission to reach target participant is not allowed",permissionToReachTargetParticipantNotAllowedMoreDetails:"Please check that the target participant is in the same tenant",unableToResolveTenantTitle:"Unable to resolve tenant id for the target participant",unableToResolveTenantMoreDetails:"Please check the participant id is entered correctly",participantIdIsMalformedTitle:"Participant id is not in the correct format",participantIdIsMalformedMoreDetails:"Please check that the participant id is in the correct format",moreButtonGalleryControlLabel:"View",moreButtonGalleryPositionToggleLabel:"Move gallery to top",moreButtonGallerySpeakerLayoutLabel:"Speaker",moreButtonGalleryFloatingLocalLayoutLabel:"Dynamic",moreButtonGalleryDefaultLayoutLabel:"Gallery view",moreButtonGalleryFocusedContentLayoutLabel:"Focus on content",moreButtonLargeGalleryDefaultLayoutLabel:"Large Gallery",capabilityChangedNotification:{turnVideoOn:{lostDueToMeetingOption:"Your camera has been disabled. You can no longer share video.",grantedDueToMeetingOption:"Your camera has been enabled. Turn it on if you'd like to share video."},unmuteMic:{lostDueToMeetingOption:"Your mic has been disabled. You can no longer unmute.",grantedDueToMeetingOption:"Your mic has been enabled. Unmute if you'd like to speak."},shareScreen:{lostDueToRoleChangeToAttendee:"Your role has been changed. Some actions, like sharing content, won't be available to you.",grantedDueToRoleChangeToPresenter:"You're a presenter. You can share content and facilitate the meeting."}},surveyQuestion:"How was your call today?",starSurveyHelperText:"How was the quality of the call?",starSurveyOneStarText:"The quality was bad.",starSurveyTwoStarText:"The quality was poor.",starSurveyThreeStarText:"The quality was good.",starSurveyFourStarText:"The quality was great.",starSurveyFiveStarText:"The quality was excellent.",surveyConfirmButtonLabel:"Send Feedback",starRatingAriaLabel:"Select {0} of {1} stars",surveyCancelButtonAriaLabel:"Cancel",tagsSurveyQuestion:"What could have been better?",tagsSurveyHelperText:"Check any issues you experienced",surveyTextboxDefaultText:"Other,please specify",surveyIssues:{overallRating:{callCannotJoin:"I could not join call",callCannotInvite:"I could not invite others into the call",hadToRejoin:"I had to rejoin the call",callEndedUnexpectedly:"Call ended for me unexpectedly",otherIssues:"I was having other issues with the call"},audioRating:{noLocalAudio:"The other side could not hear any sound",noRemoteAudio:"I could not hear any sound",echo:"I heard echos on the call",audioNoise:"I heard noise on the call",lowVolume:"Volume was low",audioStoppedUnexpectedly:"Audio stopped unexpectedly",distortedSpeech:"Audio was distorted",audioInterruption:"Audio was interrupted",otherIssues:"I was having other audio issues in this call"},videoRating:{noVideoReceived:"I could not see any video",noVideoSent:"Others could not see me",lowQuality:"Video quality was low",freezes:"Video frozen",stoppedUnexpectedly:"Video stopped unexpectedly",darkVideoReceived:"I can only see dark screens when others turn on their camera",audioVideoOutOfSync:"Audio and Video was out of sync",otherIssues:"I was having other video issues in this call"},screenshareRating:{noContentLocal:"Other people could not see my screenshare",noContentRemote:"I could not see other people's screenshare",cannotPresent:"I could not present my screen",lowQuality:"Screen share quality was low",freezes:"Screen share frozen",stoppedUnexpectedly:"Screen share stopped unexpectedly",largeDelay:"Screen share has a large delay",otherIssues:"I was having other screen share issues in this call"}},SurveyIssuesHeadingStrings:{overallRating:"Overall",audioRating:"Audio",videoRating:"Video",screenshareRating:"Presenting"}};var chat$k={chatListHeader:"In this chat",uploadFile:"Upload File"};var callWithChat$k={chatButtonLabel:"Chat",chatButtonNewMessageNotificationLabel:"New Message",chatButtonTooltipClosedWithMessageCount:"Show chat ({unreadMessagesCount} unread)",chatButtonTooltipClose:"Hide chat",chatButtonTooltipOpen:"Show chat",chatPaneTitle:"Chat",copyInviteLinkButtonLabel:"Copy invite link",copyInviteLinkActionedAriaLabel:"Invite link copied",dismissSidePaneButtonLabel:"Close",moreDrawerAudioDeviceMenuTitle:"Audio Device",moreDrawerButtonLabel:"More options",moreDrawerButtonTooltip:"More options",moreDrawerMicrophoneMenuTitle:"Microphone",moreDrawerSpeakerMenuTitle:"Speaker",moreDrawerCaptionsMenuTitle:"Live captions",moreDrawerSpokenLanguageMenuTitle:"Spoken language",moreDrawerCaptionLanguageMenuTitle:"Caption language",moreDrawerGalleryOptionsMenuTitle:"Gallery options",peopleButtonLabel:"People",selectedPeopleButtonLabel:"People Button Selected",peopleButtonTooltipOpen:"Show participants",peopleButtonTooltipClose:"Hide participants",peoplePaneSubTitle:"In this call",peoplePaneTitle:"People",pictureInPictureTileAriaLabel:"Video Feeds. Click to return to call screen.",removeMenuLabel:"Remove",openDialpadButtonLabel:"Dial phone number",returnToCallButtonAriaDescription:"Return to Call",returnToCallButtonAriaLabel:"Back",peoplePaneAddPeopleButtonLabel:"Add People",dialpadStartCallButtonLabel:"Call",dialpadModalTitle:"Dial Phone Number",dialpadModalAriaLabel:"Dialpad",dialpadCloseModalButtonAriaLabel:"Close dialpad",openDtmfDialpadLabel:"Show dialpad",dtmfDialpadPlaceholderText:"Enter number"};var en_US = {call:call$k,chat:chat$k,callWithChat:callWithChat$k};
|
21694
21908
|
|
21695
21909
|
// Copyright (c) Microsoft Corporation.
|
21696
21910
|
// Licensed under the MIT License.
|
@@ -24082,6 +24296,10 @@ const createCompositeHandlers = memoizeOne((adapter) => ({
|
|
24082
24296
|
/* @conditional-compile-remove(close-captions) */
|
24083
24297
|
onSetCaptionLanguage: (language) => __awaiter$g(void 0, void 0, void 0, function* () {
|
24084
24298
|
yield adapter.setCaptionLanguage(language);
|
24299
|
+
}),
|
24300
|
+
/* @conditional-compile-remove(end-of-call-survey) */
|
24301
|
+
onSubmitSurvey: (survey) => __awaiter$g(void 0, void 0, void 0, function* () {
|
24302
|
+
return yield adapter.submitSurvey(survey);
|
24085
24303
|
})
|
24086
24304
|
}));
|
24087
24305
|
|
@@ -25023,12 +25241,23 @@ const onFetchCustomButtonPropsTrampoline = (options) => {
|
|
25023
25241
|
// Licensed under the MIT License.
|
25024
25242
|
// Enforce a background color on control bar to ensure it matches the composite background color.
|
25025
25243
|
const controlBarStyles = react.memoizeFunction((background) => ({ root: { background: background } }));
|
25244
|
+
const inferCallControlOptions = (mobileView, callControlOptions) => {
|
25245
|
+
if (callControlOptions === false) {
|
25246
|
+
return {};
|
25247
|
+
}
|
25248
|
+
const options = callControlOptions === true || callControlOptions === undefined ? {} : callControlOptions;
|
25249
|
+
if (mobileView) {
|
25250
|
+
// Set options to always not show screen share button for mobile
|
25251
|
+
options.screenShareButton = false;
|
25252
|
+
}
|
25253
|
+
return options;
|
25254
|
+
};
|
25026
25255
|
/**
|
25027
25256
|
* @private
|
25028
25257
|
*/
|
25029
25258
|
const CallControls = (props) => {
|
25030
25259
|
var _a, _b;
|
25031
|
-
const options = React.useMemo(() => (
|
25260
|
+
const options = React.useMemo(() => inferCallControlOptions(!!props.isMobile, props.options), [props.isMobile, props.options]);
|
25032
25261
|
/* @conditional-compile-remove(PSTN-calls) */ /* @conditional-compile-remove(rooms) */
|
25033
25262
|
const adapter = useAdapter();
|
25034
25263
|
/* @conditional-compile-remove(PSTN-calls) */ /* @conditional-compile-remove(one-to-n-calling) */ /* @conditional-compile-remove(close-captions) */ /* @conditional-compile-remove(raise-hand) */
|
@@ -25675,11 +25904,8 @@ const inferCommonCallControlOptions = (mobileView, commonCallControlOptions) =>
|
|
25675
25904
|
if (mobileView) {
|
25676
25905
|
// Set to compressed mode when composite is optimized for mobile
|
25677
25906
|
options.displayType = 'compact';
|
25678
|
-
//
|
25679
|
-
|
25680
|
-
if (options.screenShareButton !== true) {
|
25681
|
-
options.screenShareButton = false;
|
25682
|
-
}
|
25907
|
+
// Set options to always not show screen share button for mobile
|
25908
|
+
options.screenShareButton = false;
|
25683
25909
|
}
|
25684
25910
|
return options;
|
25685
25911
|
};
|
@@ -29891,6 +30117,152 @@ const moreDetailsStyles = {
|
|
29891
30117
|
fontSize: '1rem'
|
29892
30118
|
};
|
29893
30119
|
|
30120
|
+
// Copyright (c) Microsoft Corporation.
|
30121
|
+
// Licensed under the MIT License.
|
30122
|
+
/** @private */
|
30123
|
+
const StarSurvey = (
|
30124
|
+
/* @conditional-compile-remove(end-of-call-survey) */ props) => {
|
30125
|
+
/* @conditional-compile-remove(end-of-call-survey) */
|
30126
|
+
const { onStarRatingSelected } = props;
|
30127
|
+
/* @conditional-compile-remove(end-of-call-survey) */
|
30128
|
+
const strings = useLocale().strings.call;
|
30129
|
+
/* @conditional-compile-remove(end-of-call-survey) */
|
30130
|
+
const StarSurveyStrings = {
|
30131
|
+
starSurveyHelperText: strings.starSurveyHelperText,
|
30132
|
+
starSurveyOneStarText: strings.starSurveyOneStarText,
|
30133
|
+
starSurveyTwoStarText: strings.starSurveyTwoStarText,
|
30134
|
+
starSurveyThreeStarText: strings.starSurveyThreeStarText,
|
30135
|
+
starSurveyFourStarText: strings.starSurveyFourStarText,
|
30136
|
+
starSurveyFiveStarText: strings.starSurveyFiveStarText,
|
30137
|
+
starRatingAriaLabel: strings.starRatingAriaLabel
|
30138
|
+
};
|
30139
|
+
/* @conditional-compile-remove(end-of-call-survey) */
|
30140
|
+
return React.createElement(_StarSurvey, { strings: StarSurveyStrings, onStarRatingSelected: onStarRatingSelected });
|
30141
|
+
};
|
30142
|
+
|
30143
|
+
// Copyright (c) Microsoft Corporation.
|
30144
|
+
// Licensed under the MIT License.
|
30145
|
+
/** @private */
|
30146
|
+
const TagsSurvey = (
|
30147
|
+
/* @conditional-compile-remove(end-of-call-survey) */ props) => {
|
30148
|
+
/* @conditional-compile-remove(end-of-call-survey) */
|
30149
|
+
const strings = useLocale().strings.call;
|
30150
|
+
/* @conditional-compile-remove(end-of-call-survey) */
|
30151
|
+
const tagsSurveyStrings = {
|
30152
|
+
tagsSurveyQuestion: strings.tagsSurveyQuestion,
|
30153
|
+
tagsSurveyHelperText: strings.tagsSurveyHelperText
|
30154
|
+
};
|
30155
|
+
/* @conditional-compile-remove(end-of-call-survey) */
|
30156
|
+
return (React.createElement(_TagsSurvey, { callIssuesToTag: strings.surveyIssues, categoryHeadings: strings.SurveyIssuesHeadingStrings, issues: props.issues, onConfirm: props.onConfirm, strings: tagsSurveyStrings }));
|
30157
|
+
};
|
30158
|
+
|
30159
|
+
// Copyright (c) Microsoft Corporation.
|
30160
|
+
// Licensed under the MIT License.
|
30161
|
+
/**
|
30162
|
+
* @private
|
30163
|
+
*/
|
30164
|
+
const SurveyPaneContent = (
|
30165
|
+
/* @conditional-compile-remove(end-of-call-survey) */ props) => {
|
30166
|
+
/* @conditional-compile-remove(end-of-call-survey) */
|
30167
|
+
const [showTagsSurvey, setShowTagsSurvey] = React.useState(false);
|
30168
|
+
/* @conditional-compile-remove(end-of-call-survey) */
|
30169
|
+
const [ratings, setRatings] = React.useState(0);
|
30170
|
+
/* @conditional-compile-remove(end-of-call-survey) */
|
30171
|
+
const [issuesSelected, setIssuesSelected] = React.useState();
|
30172
|
+
/* @conditional-compile-remove(end-of-call-survey) */
|
30173
|
+
const [showSubmitFeedbackButton, setShowSubmitFeedbackButton] = React.useState(false);
|
30174
|
+
/* @conditional-compile-remove(end-of-call-survey) */
|
30175
|
+
const strings = useLocale().strings.call;
|
30176
|
+
/* @conditional-compile-remove(end-of-call-survey) */
|
30177
|
+
const onStarRatingSelected = (ratings) => {
|
30178
|
+
if (ratings <= 3) {
|
30179
|
+
setShowTagsSurvey(true);
|
30180
|
+
}
|
30181
|
+
else {
|
30182
|
+
setShowSubmitFeedbackButton(true);
|
30183
|
+
}
|
30184
|
+
setRatings(ratings);
|
30185
|
+
};
|
30186
|
+
/* @conditional-compile-remove(end-of-call-survey) */
|
30187
|
+
const onIssuesSelected = (selectedTags) => {
|
30188
|
+
setIssuesSelected(selectedTags);
|
30189
|
+
setShowSubmitFeedbackButton(true);
|
30190
|
+
};
|
30191
|
+
/* @conditional-compile-remove(end-of-call-survey) */
|
30192
|
+
const issues = [
|
30193
|
+
'NoLocalAudio',
|
30194
|
+
'NoRemoteAudio',
|
30195
|
+
'Echo',
|
30196
|
+
'AudioNoise',
|
30197
|
+
'LowVolume',
|
30198
|
+
'AudioStoppedUnexpectedly',
|
30199
|
+
'DistortedSpeech',
|
30200
|
+
'AudioInterruption',
|
30201
|
+
'OtherIssues',
|
30202
|
+
'NoContentLocal',
|
30203
|
+
'NoContentRemote',
|
30204
|
+
'CannotPresent',
|
30205
|
+
'LowQuality',
|
30206
|
+
'Freezes',
|
30207
|
+
'StoppedUnexpectedly',
|
30208
|
+
'LargeDelay',
|
30209
|
+
'NoVideoReceived',
|
30210
|
+
'NoVideoSent',
|
30211
|
+
'LowQuality',
|
30212
|
+
'Freezes',
|
30213
|
+
'StoppedUnexpectedly',
|
30214
|
+
'DarkVideoReceived',
|
30215
|
+
'AudioVideoOutOfSync',
|
30216
|
+
'CallCannotJoin',
|
30217
|
+
'CallCannotInvite',
|
30218
|
+
'HadToRejoin',
|
30219
|
+
'CallEndedUnexpectedly'
|
30220
|
+
];
|
30221
|
+
/* @conditional-compile-remove(end-of-call-survey) */
|
30222
|
+
return (React.createElement(react.Stack, { verticalAlign: "space-between" },
|
30223
|
+
React.createElement(react.Stack, null,
|
30224
|
+
React.createElement(StarSurvey, { onStarRatingSelected: onStarRatingSelected }),
|
30225
|
+
showTagsSurvey && React.createElement(TagsSurvey, { issues: issues, onConfirm: onIssuesSelected })),
|
30226
|
+
showSubmitFeedbackButton && (React.createElement(react.Stack, { style: { borderTop: 'solid', borderTopColor: 'lightgrey' }, horizontalAlign: "end" },
|
30227
|
+
React.createElement(react.PrimaryButton, { style: { marginTop: '2rem' }, onClick: () => {
|
30228
|
+
const surveyResults = { overallRating: { score: ratings } };
|
30229
|
+
if (issuesSelected === null || issuesSelected === void 0 ? void 0 : issuesSelected.overallRating) {
|
30230
|
+
surveyResults.overallRating = { score: ratings, issues: issuesSelected.overallRating.issues };
|
30231
|
+
}
|
30232
|
+
if (issuesSelected === null || issuesSelected === void 0 ? void 0 : issuesSelected.audioRating) {
|
30233
|
+
surveyResults.audioRating = { score: ratings, issues: issuesSelected.audioRating.issues };
|
30234
|
+
}
|
30235
|
+
if (issuesSelected === null || issuesSelected === void 0 ? void 0 : issuesSelected.screenshareRating) {
|
30236
|
+
surveyResults.screenshareRating = { score: ratings, issues: issuesSelected.screenshareRating.issues };
|
30237
|
+
}
|
30238
|
+
if (issuesSelected === null || issuesSelected === void 0 ? void 0 : issuesSelected.videoRating) {
|
30239
|
+
surveyResults.videoRating = { score: ratings, issues: issuesSelected.videoRating.issues };
|
30240
|
+
}
|
30241
|
+
if (props.onSubmitSurvey) {
|
30242
|
+
props
|
30243
|
+
.onSubmitSurvey(surveyResults)
|
30244
|
+
.then(() => console.log('survey submitted successfully', surveyResults))
|
30245
|
+
.catch((e) => console.log('error when submitting survey: ' + e));
|
30246
|
+
}
|
30247
|
+
if (props.onDismissSidePane) {
|
30248
|
+
props.onDismissSidePane();
|
30249
|
+
}
|
30250
|
+
} }, strings.surveyConfirmButtonLabel)))));
|
30251
|
+
};
|
30252
|
+
|
30253
|
+
// Copyright (c) Microsoft Corporation.
|
30254
|
+
// Licensed under the MIT License.
|
30255
|
+
/** @private */
|
30256
|
+
const SurveyPane = (props) => {
|
30257
|
+
/* @conditional-compile-remove(end-of-call-survey) */
|
30258
|
+
const strings = useLocale().strings.call;
|
30259
|
+
/* @conditional-compile-remove(end-of-call-survey) */
|
30260
|
+
const [isOpen, setIsOpen] = React.useState(true);
|
30261
|
+
/* @conditional-compile-remove(end-of-call-survey) */
|
30262
|
+
return (React.createElement(react.Panel, { headerText: strings.surveyQuestion, isOpen: isOpen, onDismiss: () => setIsOpen(false), closeButtonAriaLabel: strings.surveyCancelButtonAriaLabel, type: react.PanelType.custom, customWidth: "32rem" },
|
30263
|
+
React.createElement(SurveyPaneContent, { onSubmitSurvey: props.onSubmitSurvey, onDismissSidePane: () => setIsOpen(false) })));
|
30264
|
+
};
|
30265
|
+
|
29894
30266
|
// Copyright (c) Microsoft Corporation.
|
29895
30267
|
// Licensed under the MIT License.
|
29896
30268
|
/**
|
@@ -29899,14 +30271,18 @@ const moreDetailsStyles = {
|
|
29899
30271
|
* @private
|
29900
30272
|
*/
|
29901
30273
|
function NoticePage(props) {
|
30274
|
+
var _a;
|
29902
30275
|
const adapter = useAdapter();
|
30276
|
+
/* @conditional-compile-remove(end-of-call-survey) */
|
30277
|
+
const handlers = useHandlers();
|
29903
30278
|
return (React.createElement(react.Stack, { className: react.mergeStyles(props.pageStyle), verticalFill: true, verticalAlign: "center", horizontalAlign: "center", "data-ui-id": props.dataUiId, "aria-atomic": true },
|
29904
30279
|
React.createElement(react.Stack, { className: react.mergeStyles(containerStyle), tokens: containerItemGap },
|
29905
30280
|
props.iconName && React.createElement(CallCompositeIcon, { iconName: props.iconName }),
|
29906
30281
|
React.createElement(react.Text, { className: react.mergeStyles(titleStyles), "aria-live": "assertive" }, props.title),
|
29907
30282
|
React.createElement(react.Text, { className: react.mergeStyles(moreDetailsStyles), "aria-live": "assertive" }, props.moreDetails),
|
29908
30283
|
!props.disableStartCallButton && (React.createElement(react.Stack, { styles: rejoinCallButtonContainerStyles },
|
29909
|
-
React.createElement(StartCallButton, { onClick: () => adapter.joinCall(), disabled: false, rejoinCall: true, autoFocus: true }))))
|
30284
|
+
React.createElement(StartCallButton, { onClick: () => adapter.joinCall(), disabled: false, rejoinCall: true, autoFocus: true })))),
|
30285
|
+
/* @conditional-compile-remove(end-of-call-survey) */ !((_a = props.surveyOptions) === null || _a === void 0 ? void 0 : _a.hideSurvey) && (React.createElement(SurveyPane, Object.assign({}, handlers)))));
|
29910
30286
|
}
|
29911
30287
|
|
29912
30288
|
// Copyright (c) Microsoft Corporation.
|
@@ -30583,7 +30959,7 @@ const isShowing = (overrideSidePane) => {
|
|
30583
30959
|
return !!(overrideSidePane === null || overrideSidePane === void 0 ? void 0 : overrideSidePane.isActive);
|
30584
30960
|
};
|
30585
30961
|
const MainScreen = (props) => {
|
30586
|
-
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m;
|
30962
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o;
|
30587
30963
|
const adapter = useAdapter();
|
30588
30964
|
const { camerasCount, microphonesCount } = useSelector$1(deviceCountSelector);
|
30589
30965
|
const hasCameras = camerasCount > 0;
|
@@ -30671,20 +31047,30 @@ const MainScreen = (props) => {
|
|
30671
31047
|
backgroundImage: (_k = (_j = props.options) === null || _j === void 0 ? void 0 : _j.branding) === null || _k === void 0 ? void 0 : _k.backgroundImage }));
|
30672
31048
|
break;
|
30673
31049
|
case 'accessDeniedTeamsMeeting':
|
30674
|
-
pageElement = (React.createElement(NoticePage, { iconName: "NoticePageAccessDeniedTeamsMeeting", title: locale.strings.call.failedToJoinTeamsMeetingReasonAccessDeniedTitle, moreDetails: locale.strings.call.failedToJoinTeamsMeetingReasonAccessDeniedMoreDetails, dataUiId: 'access-denied-teams-meeting-page'
|
31050
|
+
pageElement = (React.createElement(NoticePage, { iconName: "NoticePageAccessDeniedTeamsMeeting", title: locale.strings.call.failedToJoinTeamsMeetingReasonAccessDeniedTitle, moreDetails: locale.strings.call.failedToJoinTeamsMeetingReasonAccessDeniedMoreDetails, dataUiId: 'access-denied-teams-meeting-page',
|
31051
|
+
/* @conditional-compile-remove(end-of-call-survey) */
|
31052
|
+
surveyOptions: { hideSurvey: true } }));
|
30675
31053
|
break;
|
30676
31054
|
case 'removedFromCall':
|
30677
|
-
pageElement = (React.createElement(NoticePage, { iconName: "NoticePageRemovedFromCall", title: locale.strings.call.removedFromCallTitle, moreDetails: locale.strings.call.removedFromCallMoreDetails, dataUiId: 'removed-from-call-page'
|
31055
|
+
pageElement = (React.createElement(NoticePage, { iconName: "NoticePageRemovedFromCall", title: locale.strings.call.removedFromCallTitle, moreDetails: locale.strings.call.removedFromCallMoreDetails, dataUiId: 'removed-from-call-page',
|
31056
|
+
/* @conditional-compile-remove(end-of-call-survey) */
|
31057
|
+
surveyOptions: { hideSurvey: true } }));
|
30678
31058
|
break;
|
30679
31059
|
case 'joinCallFailedDueToNoNetwork':
|
30680
|
-
pageElement = (React.createElement(NoticePage, { iconName: "NoticePageJoinCallFailedDueToNoNetwork", title: locale.strings.call.failedToJoinCallDueToNoNetworkTitle, moreDetails: locale.strings.call.failedToJoinCallDueToNoNetworkMoreDetails, dataUiId: 'join-call-failed-due-to-no-network-page'
|
31060
|
+
pageElement = (React.createElement(NoticePage, { iconName: "NoticePageJoinCallFailedDueToNoNetwork", title: locale.strings.call.failedToJoinCallDueToNoNetworkTitle, moreDetails: locale.strings.call.failedToJoinCallDueToNoNetworkMoreDetails, dataUiId: 'join-call-failed-due-to-no-network-page',
|
31061
|
+
/* @conditional-compile-remove(end-of-call-survey) */
|
31062
|
+
surveyOptions: { hideSurvey: true } }));
|
30681
31063
|
break;
|
30682
31064
|
case 'leaving':
|
30683
|
-
pageElement = (React.createElement(NoticePage, { title: (_l = locale.strings.call.leavingCallTitle) !== null && _l !== void 0 ? _l : 'Leaving...', dataUiId: 'leaving-page', pageStyle: leavePageStyle, disableStartCallButton: true
|
31065
|
+
pageElement = (React.createElement(NoticePage, { title: (_l = locale.strings.call.leavingCallTitle) !== null && _l !== void 0 ? _l : 'Leaving...', dataUiId: 'leaving-page', pageStyle: leavePageStyle, disableStartCallButton: true,
|
31066
|
+
/* @conditional-compile-remove(end-of-call-survey) */
|
31067
|
+
surveyOptions: { hideSurvey: true } }));
|
30684
31068
|
break;
|
30685
31069
|
case 'leftCall': {
|
30686
31070
|
const { title, moreDetails, disableStartCallButton, iconName } = getEndedCallPageProps(locale, endedCall);
|
30687
|
-
pageElement = (React.createElement(NoticePage, { iconName: iconName, title: title, moreDetails: moreDetails, dataUiId: 'left-call-page', disableStartCallButton: disableStartCallButton
|
31071
|
+
pageElement = (React.createElement(NoticePage, { iconName: iconName, title: title, moreDetails: moreDetails, dataUiId: 'left-call-page', disableStartCallButton: disableStartCallButton,
|
31072
|
+
/* @conditional-compile-remove(end-of-call-survey) */
|
31073
|
+
surveyOptions: (_m = props.options) === null || _m === void 0 ? void 0 : _m.surveyOptions }));
|
30688
31074
|
break;
|
30689
31075
|
}
|
30690
31076
|
case 'lobby':
|
@@ -30724,7 +31110,7 @@ const MainScreen = (props) => {
|
|
30724
31110
|
case 'unsupportedEnvironment':
|
30725
31111
|
pageElement = (React.createElement(React.Fragment, null,
|
30726
31112
|
/* @conditional-compile-remove(unsupported-browser) */
|
30727
|
-
React.createElement(UnsupportedBrowserPage, { onTroubleshootingClick: (
|
31113
|
+
React.createElement(UnsupportedBrowserPage, { onTroubleshootingClick: (_o = props.options) === null || _o === void 0 ? void 0 : _o.onEnvironmentInfoTroubleshootingClick, environmentInfo: adapter.getState().environmentInfo })));
|
30728
31114
|
break;
|
30729
31115
|
}
|
30730
31116
|
if (!pageElement) {
|
@@ -31378,6 +31764,8 @@ class AzureCommunicationCallAdapter {
|
|
31378
31764
|
this.stopVideoBackgroundEffects.bind(this);
|
31379
31765
|
/* @conditional-compile-remove(video-background-effects) */
|
31380
31766
|
this.updateBackgroundPickerImages.bind(this);
|
31767
|
+
/* @conditional-compile-remove(end-of-call-survey) */
|
31768
|
+
this.submitSurvey.bind(this);
|
31381
31769
|
}
|
31382
31770
|
dispose() {
|
31383
31771
|
this.resetDiagnosticsForwarder();
|
@@ -31622,9 +32010,9 @@ class AzureCommunicationCallAdapter {
|
|
31622
32010
|
unmute() {
|
31623
32011
|
return __awaiter$5(this, void 0, void 0, function* () {
|
31624
32012
|
return yield this.asyncTeeErrorToEventEmitter(() => __awaiter$5(this, void 0, void 0, function* () {
|
31625
|
-
var _a, _b;
|
32013
|
+
var _a, _b, _c;
|
31626
32014
|
this.context.setIsLocalMicrophoneEnabled(true);
|
31627
|
-
if (_isInCall((_a = this.call) === null || _a === void 0 ? void 0 : _a.state)
|
32015
|
+
if ((_isInCall((_a = this.call) === null || _a === void 0 ? void 0 : _a.state) || _isInLobbyOrConnecting((_b = this.call) === null || _b === void 0 ? void 0 : _b.state)) && ((_c = this.call) === null || _c === void 0 ? void 0 : _c.isMuted)) {
|
31628
32016
|
yield this.handlers.onToggleMicrophone();
|
31629
32017
|
}
|
31630
32018
|
}));
|
@@ -31816,6 +32204,12 @@ class AzureCommunicationCallAdapter {
|
|
31816
32204
|
this.handlers.onSetSpokenLanguage(language);
|
31817
32205
|
});
|
31818
32206
|
}
|
32207
|
+
/* @conditional-compile-remove(end-of-call-survey) */
|
32208
|
+
submitSurvey(survey) {
|
32209
|
+
return __awaiter$5(this, void 0, void 0, function* () {
|
32210
|
+
return this.handlers.onSubmitSurvey(survey);
|
32211
|
+
});
|
32212
|
+
}
|
31819
32213
|
getState() {
|
31820
32214
|
return this.context.getState();
|
31821
32215
|
}
|
@@ -32529,6 +32923,12 @@ class CallWithChatBackedCallAdapter {
|
|
32529
32923
|
updateSelectedVideoBackgroundEffect(selectedVideoBackground) {
|
32530
32924
|
return this.callWithChatAdapter.updateSelectedVideoBackgroundEffect(selectedVideoBackground);
|
32531
32925
|
}
|
32926
|
+
/* @conditional-compile-remove(end-of-call-survey) */
|
32927
|
+
submitSurvey(survey) {
|
32928
|
+
return __awaiter$4(this, void 0, void 0, function* () {
|
32929
|
+
return this.callWithChatAdapter.submitSurvey(survey);
|
32930
|
+
});
|
32931
|
+
}
|
32532
32932
|
}
|
32533
32933
|
function callAdapterStateFromCallWithChatAdapterState(callWithChatAdapterState) {
|
32534
32934
|
return {
|
@@ -32818,6 +33218,8 @@ const validNewChatMessage = (message) => !!message.senderDisplayName && (message
|
|
32818
33218
|
// Licensed under the MIT License.
|
32819
33219
|
const CallWithChatScreen = (props) => {
|
32820
33220
|
const { callWithChatAdapter, fluentTheme, formFactor = 'desktop' } = props;
|
33221
|
+
/* @conditional-compile-remove(end-of-call-survey) */
|
33222
|
+
const { surveyOptions } = props;
|
32821
33223
|
const mobileView = formFactor === 'mobile';
|
32822
33224
|
if (!callWithChatAdapter) {
|
32823
33225
|
throw new Error('CallWithChatAdapter is undefined');
|
@@ -32934,6 +33336,8 @@ const CallWithChatScreen = (props) => {
|
|
32934
33336
|
galleryOptions: props.galleryOptions,
|
32935
33337
|
/* @conditional-compile-remove(click-to-call) */
|
32936
33338
|
localVideoTile: props.localVideoTile,
|
33339
|
+
/* @conditional-compile-remove(end-of-call-survey) */
|
33340
|
+
surveyOptions: surveyOptions,
|
32937
33341
|
/* @conditional-compile-remove(custom-branding) */
|
32938
33342
|
branding: {
|
32939
33343
|
logo: props.logo,
|
@@ -32959,6 +33363,8 @@ const CallWithChatScreen = (props) => {
|
|
32959
33363
|
props.localVideoTile,
|
32960
33364
|
/* @conditional-compile-remove(pinned-participants) */
|
32961
33365
|
props.remoteVideoTileMenuOptions,
|
33366
|
+
/* @conditional-compile-remove(end-of-call-survey) */
|
33367
|
+
surveyOptions,
|
32962
33368
|
/* @conditional-compile-remove(custom-branding) */
|
32963
33369
|
props.logo,
|
32964
33370
|
/* @conditional-compile-remove(custom-branding) */
|
@@ -33613,6 +34019,12 @@ class AzureCommunicationCallWithChatAdapter {
|
|
33613
34019
|
updateSelectedVideoBackgroundEffect(selectedVideoBackground) {
|
33614
34020
|
return this.callAdapter.updateSelectedVideoBackgroundEffect(selectedVideoBackground);
|
33615
34021
|
}
|
34022
|
+
/* @conditional-compile-remove(end-of-call-survey) */
|
34023
|
+
submitSurvey(survey) {
|
34024
|
+
return __awaiter$2(this, void 0, void 0, function* () {
|
34025
|
+
return this.callAdapter.submitSurvey(survey);
|
34026
|
+
});
|
34027
|
+
}
|
33616
34028
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
33617
34029
|
on(event, listener) {
|
33618
34030
|
switch (event) {
|