@azure/communication-react 1.14.0-alpha-202403010014 → 1.14.0-alpha-202403030013

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (70) hide show
  1. package/dist/communication-react.d.ts +30 -1
  2. package/dist/dist-cjs/communication-react/index.js +240 -139
  3. package/dist/dist-cjs/communication-react/index.js.map +1 -1
  4. package/dist/dist-esm/acs-ui-common/src/telemetryVersion.js +1 -1
  5. package/dist/dist-esm/acs-ui-common/src/telemetryVersion.js.map +1 -1
  6. package/dist/dist-esm/calling-component-bindings/src/handlers/createCommonHandlers.d.ts +1 -0
  7. package/dist/dist-esm/calling-component-bindings/src/handlers/createCommonHandlers.js +6 -0
  8. package/dist/dist-esm/calling-component-bindings/src/handlers/createCommonHandlers.js.map +1 -1
  9. package/dist/dist-esm/calling-component-bindings/src/utils/videoGalleryUtils.d.ts +1 -1
  10. package/dist/dist-esm/calling-component-bindings/src/utils/videoGalleryUtils.js +25 -6
  11. package/dist/dist-esm/calling-component-bindings/src/utils/videoGalleryUtils.js.map +1 -1
  12. package/dist/dist-esm/calling-component-bindings/src/videoGallerySelector.d.ts +1 -1
  13. package/dist/dist-esm/calling-component-bindings/src/videoGallerySelector.js.map +1 -1
  14. package/dist/dist-esm/calling-stateful-client/src/CallClientState.d.ts +6 -0
  15. package/dist/dist-esm/calling-stateful-client/src/CallClientState.js.map +1 -1
  16. package/dist/dist-esm/react-components/src/components/RTE/RTEInputBoxComponent.d.ts +2 -1
  17. package/dist/dist-esm/react-components/src/components/RTE/RTEInputBoxComponent.js +11 -3
  18. package/dist/dist-esm/react-components/src/components/RTE/RTEInputBoxComponent.js.map +1 -1
  19. package/dist/dist-esm/react-components/src/components/RTE/RTERibbonButtons.js +1 -1
  20. package/dist/dist-esm/react-components/src/components/RTE/RTERibbonButtons.js.map +1 -1
  21. package/dist/dist-esm/react-components/src/components/RTE/RTESendBox.js +4 -9
  22. package/dist/dist-esm/react-components/src/components/RTE/RTESendBox.js.map +1 -1
  23. package/dist/dist-esm/react-components/src/components/RTE/RTESendBoxErrors.js +6 -0
  24. package/dist/dist-esm/react-components/src/components/RTE/RTESendBoxErrors.js.map +1 -1
  25. package/dist/dist-esm/react-components/src/components/RTE/RichTextEditor.d.ts +1 -1
  26. package/dist/dist-esm/react-components/src/components/RTE/RichTextEditor.js +12 -18
  27. package/dist/dist-esm/react-components/src/components/RTE/RichTextEditor.js.map +1 -1
  28. package/dist/dist-esm/react-components/src/components/styles/RichTextEditor.styles.d.ts +5 -1
  29. package/dist/dist-esm/react-components/src/components/styles/RichTextEditor.styles.js +49 -84
  30. package/dist/dist-esm/react-components/src/components/styles/RichTextEditor.styles.js.map +1 -1
  31. package/dist/dist-esm/react-composites/src/composites/CallComposite/Strings.d.ts +8 -0
  32. package/dist/dist-esm/react-composites/src/composites/CallComposite/Strings.js.map +1 -1
  33. package/dist/dist-esm/react-composites/src/composites/CallComposite/adapter/AzureCommunicationCallAdapter.d.ts +1 -0
  34. package/dist/dist-esm/react-composites/src/composites/CallComposite/adapter/AzureCommunicationCallAdapter.js +8 -0
  35. package/dist/dist-esm/react-composites/src/composites/CallComposite/adapter/AzureCommunicationCallAdapter.js.map +1 -1
  36. package/dist/dist-esm/react-composites/src/composites/CallComposite/adapter/CallAdapter.d.ts +4 -0
  37. package/dist/dist-esm/react-composites/src/composites/CallComposite/adapter/CallAdapter.js.map +1 -1
  38. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/CallArrangement.js +72 -23
  39. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/CallArrangement.js.map +1 -1
  40. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/SidePane/SidePane.d.ts +1 -0
  41. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/SidePane/SidePane.js +2 -1
  42. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/SidePane/SidePane.js.map +1 -1
  43. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/SidePane/usePeoplePane.d.ts +1 -0
  44. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/SidePane/usePeoplePane.js +25 -1
  45. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/SidePane/usePeoplePane.js.map +1 -1
  46. package/dist/dist-esm/react-composites/src/composites/CallComposite/hooks/useHandlers.js +4 -0
  47. package/dist/dist-esm/react-composites/src/composites/CallComposite/hooks/useHandlers.js.map +1 -1
  48. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/AzureCommunicationCallWithChatAdapter.d.ts +1 -0
  49. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/AzureCommunicationCallWithChatAdapter.js +6 -0
  50. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/AzureCommunicationCallWithChatAdapter.js.map +1 -1
  51. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/CallWithChatAdapter.d.ts +4 -0
  52. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/CallWithChatAdapter.js.map +1 -1
  53. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/CallWithChatBackedCallAdapter.d.ts +1 -0
  54. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/CallWithChatBackedCallAdapter.js +6 -0
  55. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/CallWithChatBackedCallAdapter.js.map +1 -1
  56. package/dist/dist-esm/react-composites/src/composites/common/ExitSpotlightButton.js +1 -1
  57. package/dist/dist-esm/react-composites/src/composites/common/ExitSpotlightButton.js.map +1 -1
  58. package/dist/dist-esm/react-composites/src/composites/common/SidePaneHeader.d.ts +3 -0
  59. package/dist/dist-esm/react-composites/src/composites/common/SidePaneHeader.js +6 -1
  60. package/dist/dist-esm/react-composites/src/composites/common/SidePaneHeader.js.map +1 -1
  61. package/dist/dist-esm/react-composites/src/composites/common/TabHeader.d.ts +1 -0
  62. package/dist/dist-esm/react-composites/src/composites/common/TabHeader.js +5 -1
  63. package/dist/dist-esm/react-composites/src/composites/common/TabHeader.js.map +1 -1
  64. package/dist/dist-esm/react-composites/src/composites/common/icons.d.ts +6 -0
  65. package/dist/dist-esm/react-composites/src/composites/common/icons.js +6 -2
  66. package/dist/dist-esm/react-composites/src/composites/common/icons.js.map +1 -1
  67. package/dist/dist-esm/react-composites/src/composites/common/styles/Pane.styles.js +8 -1
  68. package/dist/dist-esm/react-composites/src/composites/common/styles/Pane.styles.js.map +1 -1
  69. package/dist/dist-esm/react-composites/src/composites/localization/locales/en-US/strings.json +2 -0
  70. package/package.json +6 -5
@@ -17,6 +17,7 @@ var reactFileTypeIcons = require('@fluentui/react-file-type-icons');
17
17
  var roosterjsEditorPlugins = require('roosterjs-editor-plugins');
18
18
  var roosterjsEditorCore = require('roosterjs-editor-core');
19
19
  var roosterjsReact = require('roosterjs-react');
20
+ var roosterjsEditorApi = require('roosterjs-editor-api');
20
21
  var uuid = require('uuid');
21
22
  var reactChat = require('@fluentui-contrib/react-chat');
22
23
  var react$1 = require('@griffel/react');
@@ -173,7 +174,7 @@ function getDefaultExportFromCjs (x) {
173
174
  // Copyright (c) Microsoft Corporation.
174
175
  // Licensed under the MIT License.
175
176
  // GENERATED FILE. DO NOT EDIT MANUALLY.
176
- var telemetryVersion = '1.14.0-alpha-202403010014';
177
+ var telemetryVersion = '1.14.0-alpha-202403030013';
177
178
 
178
179
 
179
180
  var telemetryVersion$1 = /*@__PURE__*/getDefaultExportFromCjs(telemetryVersion);
@@ -1170,6 +1171,10 @@ const createDefaultCommonCallingHandlers = memoizeOne((callClient, deviceManager
1170
1171
  yield (call === null || call === void 0 ? void 0 : call.feature(communicationCalling.Features.Spotlight).stopSpotlight(participants));
1171
1172
  });
1172
1173
  /* @conditional-compile-remove(spotlight) */
1174
+ const onStopAllSpotlight = () => __awaiter$Q(void 0, void 0, void 0, function* () {
1175
+ yield (call === null || call === void 0 ? void 0 : call.feature(communicationCalling.Features.Spotlight).stopAllSpotlight());
1176
+ });
1177
+ /* @conditional-compile-remove(spotlight) */
1173
1178
  const canSpotlight = call === null || call === void 0 ? void 0 : call.feature(communicationCalling.Features.Capabilities).capabilities.spotlightParticipant.isPresent;
1174
1179
  /* @conditional-compile-remove(spotlight) */
1175
1180
  const onStartLocalSpotlight = canSpotlight
@@ -1250,6 +1255,8 @@ const createDefaultCommonCallingHandlers = memoizeOne((callClient, deviceManager
1250
1255
  /* @conditional-compile-remove(spotlight) */
1251
1256
  onStopSpotlight,
1252
1257
  /* @conditional-compile-remove(spotlight) */
1258
+ onStopAllSpotlight,
1259
+ /* @conditional-compile-remove(spotlight) */
1253
1260
  onStartLocalSpotlight,
1254
1261
  /* @conditional-compile-remove(spotlight) */
1255
1262
  onStopLocalSpotlight,
@@ -9172,97 +9179,62 @@ const richTextEditorStyle = react.mergeStyles({
9172
9179
  /**
9173
9180
  * @private
9174
9181
  */
9175
- const ribbonButtonStyle = (theme) => {
9182
+ const ribbonOverflowButtonStyle = (theme) => {
9176
9183
  return {
9177
- icon: { color: theme.palette.neutralPrimary, height: 'auto' },
9178
- menuIcon: { color: theme.palette.neutralPrimary, height: 'auto' },
9179
- root: { minWidth: 'auto', backgroundColor: 'transparent' },
9180
- rootChecked: {
9181
- backgroundColor: 'transparent',
9182
- selectors: {
9183
- // Icon's color doesn't work here because of the specificity
9184
- '.ms-Button-icon': {
9185
- color: theme.palette.themePrimary
9186
- },
9187
- '.ms-Button-menuIcon': {
9188
- color: theme.palette.themePrimary
9189
- }
9190
- }
9191
- },
9192
- rootHovered: {
9193
- backgroundColor: 'transparent',
9194
- selectors: {
9195
- // Icon's color doesn't work here because of the specificity
9196
- '.ms-Button-icon': {
9197
- color: theme.palette.themePrimary
9198
- },
9199
- '.ms-Button-menuIcon': {
9200
- color: theme.palette.themePrimary
9201
- }
9202
- }
9203
- },
9204
- rootCheckedHovered: {
9205
- backgroundColor: 'transparent',
9206
- selectors: {
9207
- // Icon's color doesn't work here because of the specificity
9208
- '.ms-Button-icon': {
9209
- color: theme.palette.themePrimary
9210
- },
9211
- '.ms-Button-menuIcon': {
9212
- color: theme.palette.themePrimary
9213
- }
9214
- }
9215
- },
9216
- rootCheckedPressed: {
9217
- backgroundColor: 'transparent',
9218
- selectors: {
9219
- // Icon's color doesn't work here because of the specificity
9220
- '.ms-Button-icon': {
9221
- color: theme.palette.themePrimary
9222
- },
9223
- '.ms-Button-menuIcon': {
9224
- color: theme.palette.themePrimary
9225
- }
9226
- }
9227
- },
9228
- rootPressed: {
9229
- backgroundColor: 'transparent',
9230
- selectors: {
9231
- // Icon's color doesn't work here because of the specificity
9232
- '.ms-Button-icon': {
9233
- color: theme.palette.themePrimary
9234
- },
9235
- '.ms-Button-menuIcon': {
9236
- color: theme.palette.themePrimary
9237
- }
9238
- }
9239
- },
9240
- rootExpanded: {
9241
- backgroundColor: 'transparent',
9242
- selectors: {
9243
- // Icon's color doesn't work here because of the specificity
9244
- '.ms-Button-icon': {
9245
- color: theme.palette.themePrimary
9246
- },
9247
- '.ms-Button-menuIcon': {
9248
- color: theme.palette.themePrimary
9184
+ subComponentStyles: {
9185
+ menuItem: {
9186
+ icon: { color: theme.palette.neutralPrimary, paddingTop: '0.5rem' },
9187
+ root: ribbonOverflowButtonRootStyles(theme)
9188
+ },
9189
+ callout: {}
9190
+ }
9191
+ };
9192
+ };
9193
+ const ribbonOverflowButtonRootStyles = (theme) => {
9194
+ return {
9195
+ selectors: {
9196
+ // Icon's color doesn't work here because of the specificity
9197
+ '&:hover': {
9198
+ selectors: {
9199
+ '.ms-ContextualMenu-icon': {
9200
+ color: theme.palette.neutralPrimary
9201
+ }
9249
9202
  }
9250
9203
  }
9251
- },
9252
- rootExpandedHovered: {
9253
- backgroundColor: 'transparent',
9254
- selectors: {
9255
- //icon color is not working here because of the specificity
9256
- '.ms-Button-icon': {
9257
- color: theme.palette.themePrimary
9258
- },
9259
- '.ms-Button-menuIcon': {
9260
- color: theme.palette.themePrimary
9261
- }
9204
+ }
9205
+ };
9206
+ };
9207
+ const ribbonButtonRootStyles = (theme) => {
9208
+ return {
9209
+ backgroundColor: 'transparent',
9210
+ selectors: {
9211
+ // Icon's color doesn't work here because of the specificity
9212
+ '.ms-Button-icon': {
9213
+ color: theme.palette.themePrimary
9214
+ },
9215
+ '.ms-Button-menuIcon': {
9216
+ color: theme.palette.themePrimary
9262
9217
  }
9263
9218
  }
9264
9219
  };
9265
9220
  };
9221
+ /**
9222
+ * @private
9223
+ */
9224
+ const ribbonButtonStyle = (theme) => {
9225
+ return {
9226
+ icon: { color: theme.palette.neutralPrimary, height: 'auto' },
9227
+ menuIcon: { color: theme.palette.neutralPrimary, height: 'auto' },
9228
+ root: { minWidth: 'auto', backgroundColor: 'transparent' },
9229
+ rootChecked: ribbonButtonRootStyles(theme),
9230
+ rootHovered: ribbonButtonRootStyles(theme),
9231
+ rootCheckedHovered: ribbonButtonRootStyles(theme),
9232
+ rootCheckedPressed: ribbonButtonRootStyles(theme),
9233
+ rootPressed: ribbonButtonRootStyles(theme),
9234
+ rootExpanded: ribbonButtonRootStyles(theme),
9235
+ rootExpandedHovered: ribbonButtonRootStyles(theme)
9236
+ };
9237
+ };
9266
9238
  /**
9267
9239
  * @private
9268
9240
  */
@@ -9325,7 +9297,7 @@ const createKnownRibbonButton = (key, theme, icon) => {
9325
9297
  // AllButtonStringKeys is a union of all the string keys of all the buttons
9326
9298
  const result = buttons[0];
9327
9299
  button.iconName = icon;
9328
- button.commandBarProperties = Object.assign(Object.assign({}, button.commandBarProperties), { buttonStyles: Object.assign(Object.assign({}, (_a = button.commandBarProperties) === null || _a === void 0 ? void 0 : _a.buttonStyles), ribbonButtonStyle(theme)) });
9300
+ button.commandBarProperties = Object.assign(Object.assign({}, button.commandBarProperties), { buttonStyles: Object.assign(Object.assign({}, (_a = button.commandBarProperties) === null || _a === void 0 ? void 0 : _a.buttonStyles), ribbonButtonStyle(theme)), canCheck: false });
9329
9301
  return result;
9330
9302
  }
9331
9303
  return undefined;
@@ -9374,10 +9346,9 @@ const ribbonButtonsStrings = (strings) => {
9374
9346
  * @beta
9375
9347
  */
9376
9348
  React.forwardRef((props, ref) => {
9377
- const { content, onChange, placeholderText, strings } = props;
9349
+ const { initialContent, onChange, placeholderText, strings } = props;
9378
9350
  const editor = React.useRef(null);
9379
- const [divComponent, setDivComponent] = React.useState(null);
9380
- const theme = react.useTheme();
9351
+ const theme = useTheme();
9381
9352
  React.useImperativeHandle(ref, () => {
9382
9353
  return {
9383
9354
  focus() {
@@ -9388,26 +9359,19 @@ React.forwardRef((props, ref) => {
9388
9359
  };
9389
9360
  }, []);
9390
9361
  React.useEffect(() => {
9391
- var _a, _b;
9392
- if (content !== ((_a = editor.current) === null || _a === void 0 ? void 0 : _a.getContent())) {
9393
- (_b = editor.current) === null || _b === void 0 ? void 0 : _b.setContent(content || '');
9394
- }
9395
- }, [content]);
9396
- React.useEffect(() => {
9397
- if (divComponent !== null && theme.palette.neutralPrimary !== undefined) {
9362
+ if (editor.current !== null) {
9398
9363
  // Adjust color prop for the div component when theme is updated
9399
9364
  // because doNotAdjustEditorColor is set for Rooster
9400
- divComponent.style.color = theme.palette.neutralPrimary;
9365
+ roosterjsEditorApi.setTextColor(editor.current, theme.palette.neutralPrimary);
9401
9366
  }
9402
- }, [divComponent, theme]);
9367
+ }, [theme]);
9403
9368
  const ribbonPlugin = React.useMemo(() => {
9404
9369
  return roosterjsReact.createRibbonPlugin();
9405
9370
  }, []);
9406
9371
  const editorCreator = React.useCallback((div, options) => {
9407
9372
  editor.current = new roosterjsEditorCore.Editor(div, options);
9408
- setDivComponent(div);
9409
9373
  // Remove the background color of the editor
9410
- div.style.backgroundColor = 'transparent';
9374
+ roosterjsEditorApi.setBackgroundColor(editor.current, 'transparent');
9411
9375
  return editor.current;
9412
9376
  }, []);
9413
9377
  const plugins = React.useMemo(() => {
@@ -9426,13 +9390,14 @@ React.forwardRef((props, ref) => {
9426
9390
  styles: ribbonButtonStyle(theme),
9427
9391
  menuProps: {
9428
9392
  items: [], // CommandBar will determine items rendered in overflow
9429
- isBeakVisible: false
9393
+ isBeakVisible: false,
9394
+ styles: ribbonOverflowButtonStyle(theme)
9430
9395
  }
9431
9396
  }, strings: ribbonButtonsStrings(strings) }));
9432
9397
  }, [strings, ribbonPlugin, theme]);
9433
9398
  return (React.createElement("div", null,
9434
9399
  ribbon,
9435
- React.createElement(roosterjsReact.Rooster, { inDarkMode: isDarkThemed(theme), plugins: plugins, className: richTextEditorStyle, editorCreator: editorCreator,
9400
+ React.createElement(roosterjsReact.Rooster, { initialContent: initialContent, inDarkMode: isDarkThemed(theme), plugins: plugins, className: richTextEditorStyle, editorCreator: editorCreator,
9436
9401
  // TODO: confirm the color during inline images implementation
9437
9402
  imageSelectionBorderColor: 'blue',
9438
9403
  // doNotAdjustEditorColor is used to fix the default background color for Rooster component
@@ -20599,7 +20564,9 @@ const _videoGalleryRemoteParticipantsMemo = (remoteParticipants, isHideAttendeeN
20599
20564
  /* @conditional-compile-remove(reaction) */
20600
20565
  remoteParticipantReaction,
20601
20566
  /* @conditional-compile-remove(spotlight) */
20602
- participant.spotlight);
20567
+ participant.spotlight,
20568
+ /* @conditional-compile-remove(ppt-live) */
20569
+ participant.contentSharingStream);
20603
20570
  }));
20604
20571
  });
20605
20572
  };
@@ -20609,15 +20576,18 @@ raisedHand, // temp unknown type to build stable
20609
20576
  /* @conditional-compile-remove(reaction) */
20610
20577
  reaction, // temp unknown type to build stable
20611
20578
  /* @conditional-compile-remove(spotlight) */
20612
- spotlight // temp unknown type to build stable
20613
- ) => {
20579
+ spotlight, // temp unknown type to build stable
20580
+ /* @conditional-compile-remove(ppt-live) */
20581
+ contentSharingStream) => {
20614
20582
  return convertRemoteParticipantToVideoGalleryRemoteParticipant(userId, isMuted, isSpeaking, videoStreams, state, displayName,
20615
20583
  /* @conditional-compile-remove(raise-hand) */
20616
20584
  raisedHand,
20617
20585
  /* @conditional-compile-remove(reaction) */
20618
20586
  reaction,
20619
20587
  /* @conditional-compile-remove(spotlight) */
20620
- spotlight);
20588
+ spotlight,
20589
+ /* @conditional-compile-remove(ppt-live) */
20590
+ contentSharingStream);
20621
20591
  });
20622
20592
  /** @private */
20623
20593
  const convertRemoteParticipantToVideoGalleryRemoteParticipant = (userId, isMuted, isSpeaking, videoStreams, state, displayName,
@@ -20626,8 +20596,9 @@ raisedHand, // temp unknown type to build stable
20626
20596
  /* @conditional-compile-remove(reaction) */
20627
20597
  reaction, // temp unknown type to build stable
20628
20598
  /* @conditional-compile-remove(spotlight) */
20629
- spotlight // temp unknown type to build stable
20630
- ) => {
20599
+ spotlight, // temp unknown type to build stable
20600
+ /* @conditional-compile-remove(ppt-live) */
20601
+ contentSharingStream) => {
20631
20602
  const rawVideoStreamsArray = Object.values(videoStreams);
20632
20603
  let videoStream = undefined;
20633
20604
  let screenShareStream = undefined;
@@ -20641,6 +20612,10 @@ spotlight // temp unknown type to build stable
20641
20612
  if (sdkScreenShareStream) {
20642
20613
  screenShareStream = convertRemoteVideoStreamToVideoGalleryStream(sdkScreenShareStream);
20643
20614
  }
20615
+ /* @conditional-compile-remove(ppt-live) */
20616
+ if (contentSharingStream) {
20617
+ screenShareStream = convertRemoteContentSharingStreamToVideoGalleryStream(contentSharingStream);
20618
+ }
20644
20619
  return {
20645
20620
  userId,
20646
20621
  displayName,
@@ -20673,6 +20648,15 @@ const convertRemoteVideoStreamToVideoGalleryStream = (stream) => {
20673
20648
  streamSize: stream.streamSize
20674
20649
  };
20675
20650
  };
20651
+ /* @conditional-compile-remove(ppt-live) */
20652
+ const convertRemoteContentSharingStreamToVideoGalleryStream = (stream) => {
20653
+ return {
20654
+ isAvailable: !!stream,
20655
+ isReceiving: true,
20656
+ isMirrored: false,
20657
+ renderElement: stream
20658
+ };
20659
+ };
20676
20660
  /** @private */
20677
20661
  const memoizeLocalParticipant = memoizeOne((identifier, displayName, isMuted, isScreenSharingOn, localVideoStream,
20678
20662
  /* @conditional-compile-remove(rooms) */ role,
@@ -23635,7 +23619,11 @@ const COMPOSITE_ONLY_ICONS = {
23635
23619
  /* @conditional-compile-remove(control-bar-button-injection) */
23636
23620
  DefaultCustomButton: React.createElement(reactIcons.Circle20Regular, null),
23637
23621
  /* @conditional-compile-remove(dtmf-dialer) */
23638
- DtmfDialpadButton: React.createElement(reactIcons.Dialpad20Regular, null)
23622
+ DtmfDialpadButton: React.createElement(reactIcons.Dialpad20Regular, null),
23623
+ /* @conditional-compile-remove(spotlight) */
23624
+ PeoplePaneMoreButton: React.createElement(reactIcons.MoreHorizontal20Filled, null),
23625
+ /* @conditional-compile-remove(spotlight) */
23626
+ StopAllSpotlightMenuButton: React.createElement(reactIcons.VideoPersonStarOff20Filled, null)
23639
23627
  };
23640
23628
  /**
23641
23629
  * The default set of icons that are available to used in the Composites.
@@ -23668,7 +23656,7 @@ const CallCompositeIcon = (props) => (React.createElement(react.FontIcon, Object
23668
23656
  */
23669
23657
  const CallWithChatCompositeIcon = (props) => (React.createElement(react.FontIcon, Object.assign({}, props)));
23670
23658
 
23671
- var call$k={cameraLabel:"Camera",noCamerasLabel:"No cameras found",cameraPermissionDenied:"Your browser is blocking access to your camera",cameraTurnedOff:"Your camera is turned off",chatButtonLabel:"Chat",close:"Close",complianceBannerNowOnlyRecording:"You are now only recording this meeting.",complianceBannerNowOnlyTranscription:"You are now only transcribing this meeting.",complianceBannerRecordingAndTranscriptionSaved:"Recording and transcription are being saved.",complianceBannerRecordingAndTranscriptionStarted:"Recording and transcription have started.",complianceBannerRecordingAndTranscriptionStopped:"Recording and transcription have stopped.",complianceBannerRecordingSaving:"Recording is being saved.",complianceBannerRecordingStarted:"Recording has started.",complianceBannerRecordingStopped:"Recording has stopped.",complianceBannerTranscriptionStarted:"Transcription has started.",complianceBannerTranscriptionConsent:"By joining, you are giving consent for this meeting to be transcribed.",complianceBannerTranscriptionSaving:"Transcription is being saved.",complianceBannerTranscriptionStopped:"Transcription has stopped.",configurationPageTitle:"Start a call",copyInviteLinkButtonLabel:"Copy invite link",copyInviteLinkActionedAriaLabel:"Invite link copied",defaultPlaceHolder:"Select an option",dismissSidePaneButtonLabel:"Close",videoEffectsPaneTitle:"Effects",videoEffectsPaneBackgroundSelectionTitle:"Background",configurationPageVideoEffectsButtonLabel:"Effects",unableToStartVideoEffect:"Unable to apply video effect.",blurBackgroundEffectButtonLabel:"Blur",blurBackgroundTooltip:"Blur Background",removeBackgroundEffectButtonLabel:"None",removeBackgroundTooltip:"Remove Background",cameraOffBackgroundEffectWarningText:"Your camera is off. Turn on camera to see video effect.",failedToJoinCallDueToNoNetworkMoreDetails:"Call was disconnected due to a network issue. Check your connection and join again.",failedToJoinCallDueToNoNetworkTitle:"Call disconnected",failedToJoinTeamsMeetingReasonAccessDeniedMoreDetails:"You were not granted entry in the call. If this was a mistake, re-join the call.",failedToJoinTeamsMeetingReasonAccessDeniedTitle:"Dismissed from lobby",learnMore:"Learn more",leavingCallTitle:"Leaving...",leftCallMoreDetails:"If this was a mistake, re-join the call.",leftCallTitle:"You left the call",lobbyScreenConnectingToCallTitle:"Joining call",lobbyScreenWaitingToBeAdmittedTitle:"Waiting to be admitted",microphonePermissionDenied:"Your browser is blocking access to your microphone",microphoneToggleInLobbyNotAllowed:"Cannot mute or unmute while in lobby.",mutedMessage:"You're muted",networkReconnectMoreDetails:"Looks like something went wrong. We're trying to get back into the call.",networkReconnectTitle:"Hold on",notInvitedToRoomDetails:"You are not able to join this room because you do not have an invite.",notInvitedToRoomTitle:"Not invited to room",peopleButtonLabel:"People",selectedPeopleButtonLabel:"People Button Selected",peoplePaneTitle:"People",peopleButtonTooltipOpen:"Show participants",peopleButtonTooltipClose:"Hide participants",peoplePaneSubTitle:"In this call {numberOfPeople}",privacyPolicy:"Privacy policy",rejoinCallButtonLabel:"Re-join call",removedFromCallMoreDetails:"Another participant removed you from the call.",removedFromCallTitle:"You were removed",removeMenuLabel:"Remove",startSpotlightParticipantListMenuLabel:"Spotlight for everyone",addSpotlightParticipantListMenuLabel:"Add spotlight",stopSpotlightParticipantListMenuLabel:"Stop spotlighting",stopSpotlightOnSelfParticipantListMenuLabel:"Exit spotlight",spotlightLimitReachedParticipantListMenuTitle:"Spotlight limit reached",returnToCallButtonAriaDescription:"Return to Call",returnToCallButtonAriaLabel:"Back",roomNotFoundDetails:"The room ID provided could not be found.",roomNotFoundTitle:"Room not found",roomNotValidDetails:"This room is not valid at this current time.",roomNotValidTitle:"Room not valid",inviteToRoomRemovedDetails:"Your invite to join this room was removed.",inviteToRoomRemovedTitle:"Invite to room removed",soundLabel:"Sound",noMicrophonesLabel:"No microphones found",noSpeakersLabel:"No speakers found",startCallButtonLabel:"Start call",openDialpadButtonLabel:"Dial phone number",peoplePaneAddPeopleButtonLabel:"Add People",dialpadStartCallButtonLabel:"Call",dialpadModalTitle:"Dial Phone Number",dialpadModalAriaLabel:"Dialpad",dialpadCloseModalButtonAriaLabel:"Close dialpad",moreButtonCallingLabel:"More",resumeCallButtonLabel:"Resume",resumingCallButtonLabel:"Resuming...",resumeCallButtonAriaLabel:"Resume call",resumingCallButtonAriaLabel:"Resume call",holdScreenLabel:"You're on hold",openDtmfDialpadLabel:"Show dialpad",dtmfDialpadPlaceholderText:"Enter number",outboundCallingNoticeString:"Calling...",participantJoinedNoticeString:"{displayName} joined",twoParticipantJoinedNoticeString:"{displayName1} and {displayName2} have joined",threeParticipantJoinedNoticeString:"{displayName1}, {displayName2} and {displayName3} have joined",participantLeftNoticeString:"{displayName} left",twoParticipantLeftNoticeString:"{displayName1} and {displayName2} have left",threeParticipantLeftNoticeString:"{displayName1}, {displayName2} and {displayName3} have left",unnamedParticipantString:"unnamed participant",manyUnnamedParticipantsJoined:"unnamed participant and {numOfParticipants} other participants joined",manyUnnamedParticipantsLeft:"unnamed participant and {numOfParticipants} other participants left",manyParticipantsJoined:"{displayName1}, {displayName2}, {displayName3} and {numOfParticipants} other participants joined",manyParticipantsLeft:"{displayName1}, {displayName2}, {displayName3} and {numOfParticipants} other participants left",liveCaptionsLabel:"Live captions",captionsSettingsLabel:"Caption settings",startCaptionsButtonOnLabel:"Turn on captions",startCaptionsButtonOffLabel:"Turn off captions",startCaptionsButtonTooltipOnContent:"Turn off captions",startCaptionsButtonTooltipOffContent:"Turn on captions",captionsSettingsModalTitle:"Captions Settings",captionsSettingsSpokenLanguageDropdownLabel:"Spoken language",captionsSettingsCaptionLanguageDropdownLabel:"Captions language",captionsSettingsSpokenLanguageDropdownInfoText:"Language that everyone on this call is speaking.",captionsSettingsCaptionLanguageDropdownInfoText:"Captions will appear in this langugage.",captionsSettingsConfirmButtonLabel:"Confirm",captionsSettingsCancelButtonLabel:"Cancel",captionsSettingsModalAriaLabel:"Captions Setting Modal",captionsSettingsCloseModalButtonAriaLabel:"Close Captions Setting",captionsBannerMoreButtonCallingLabel:"More",captionsBannerMoreButtonTooltip:"More options",dismissModalAriaLabel:"Local and remote picture and picture, press enter to return to call",callRejectedTitle:"The call could not be completed",callRejectedMoreDetails:"The person you are trying to reach is unavailable. Please try again later.",callTimeoutTitle:"The call could not be completed",callTimeoutDetails:"The person you are trying to reach is unavailable. Please try again later.",callTimeoutBotTitle:"The call could not be completed",callTimeoutBotDetails:"The service that you are trying to reach is unavailable. Please try again later.",dtmfDialerButtonLabel:"Dialpad",dtmfDialerButtonTooltipOn:"Show dialpad",dtmfDialerButtonTooltipOff:"Hide dialpad",dtmfDialerMoreButtonLabelOn:"Show dialpad",dtmfDialerMoreButtonLabelOff:"Hide dialpad",spokenLanguageStrings:{"ar-ae":"Arabic - U.A.E.","ar-sa":"Arabic - Saudi Arabia","da-dk":"Danish","de-de":"German - Germany","en-au":"English - Australia","en-ca":"English - Canada","en-gb":"English - United Kingdom","en-in":"English - India","en-nz":"English - New Zealand","en-us":"English - United States","es-es":"Spanish - Spain (Modern Sort)","es-mx":"Spanish - Mexico","fi-fi":"Finnish","fr-ca":"French - Canada","fr-fr":"French - France","hi-in":"Hindi","it-it":"Italian - Italy","ja-jp":"Japanese","ko-kr":"Korean","nb-no":"Norwegian (Bokmål)","nl-be":"Dutch - Belgium","nl-nl":"Dutch - Netherlands","pl-pl":"Polish","pt-br":"Portuguese - Brazil","ru-ru":"Russian","sv-se":"Swedish","zh-cn":"Chinese - People's Republic of China","zh-hk":"Chinese - Hong Kong SAR","cs-cz":"Czech","pt-pt":"Portuguese - Portugal","tr-tr":"Turkish","vi-vn":"Vietnamese","th-th":"Thai","he-il":"Hebrew","cy-gb":"Welsh","uk-ua":"Ukrainian","el-gr":"Greek","hu-hu":"Hungarian","ro-ro":"Romanian","sk-sk":"Slovak","zh-tw":"Chinese - Taiwan"},captionLanguageStrings:{ar:"Arabic",da:"Danish",de:"German",en:"English",es:"Spanish",fi:"Finnish","fr-ca":"French - Canada",fr:"French - France",hi:"Hindi",it:"Italian",ja:"Japanese",ko:"Korean",nb:"Norwegian (Bokmål)",nl:"Dutch",pl:"Polish",pt:"Portuguese - Brazil",ru:"Russian",sv:"Swedish","zh-Hans":"Chinese (Simplified)","zh-Hant":"Chinese (Traditional)",cs:"Czech","pt-pt":"Portuguese - Portugal",tr:"Turkish",vi:"Vietnamese",th:"Thai",he:"Hebrew",cy:"Welsh",uk:"Ukrainian",el:"Greek",hu:"Hungarian",ro:"Romanian",sk:"Slovak"},captionsBannerSpinnerText:"Starting captions...",transferPageTransferorText:"Transferring...",transferPageTransferTargetText:"Connecting...",transferPageUnknownTransferorDisplayName:"Unknown",transferPageUnknownTransferTargetDisplayName:"Unknown",transferPageNoticeString:"You are being transferred",participantCouldNotBeReachedTitle:"Target participant is currently not available",participantCouldNotBeReachedMoreDetails:"Please contact participant when they are available",permissionToReachTargetParticipantNotAllowedTitle:"Permission to reach target participant is not allowed",permissionToReachTargetParticipantNotAllowedMoreDetails:"Please check that the target participant is in the same tenant",unableToResolveTenantTitle:"Unable to resolve tenant id for the target participant",unableToResolveTenantMoreDetails:"Please check the participant id is entered correctly",participantIdIsMalformedTitle:"Participant id is not in the correct format",participantIdIsMalformedMoreDetails:"Please check that the participant id is in the correct format",moreButtonGalleryControlLabel:"View",moreButtonGalleryPositionToggleLabel:"Move gallery to top",moreButtonGallerySpeakerLayoutLabel:"Speaker",moreButtonGalleryFloatingLocalLayoutLabel:"Dynamic",moreButtonGalleryDefaultLayoutLabel:"Gallery view",moreButtonGalleryFocusedContentLayoutLabel:"Focus on content",moreButtonLargeGalleryDefaultLayoutLabel:"Large Gallery",capabilityChangedNotification:{turnVideoOn:{lostDueToMeetingOption:"Your camera has been disabled. You can no longer share video.",grantedDueToMeetingOption:"Your camera has been enabled. Turn it on if you'd like to share video."},unmuteMic:{lostDueToMeetingOption:"Your mic has been disabled. You can no longer unmute.",grantedDueToMeetingOption:"Your mic has been enabled. Unmute if you'd like to speak."},shareScreen:{lostDueToRoleChangeToAttendee:"Your role has been changed. Some actions, like sharing content, won't be available to you.",grantedDueToRoleChangeToPresenter:"You're a presenter. You can share content and facilitate the meeting."}},surveyTitle:"Help us improve",starSurveyHelperText:"How was the quality of the call?",starSurveyOneStarText:"The quality was bad.",starSurveyTwoStarText:"The quality was poor.",starSurveyThreeStarText:"The quality was good.",starSurveyFourStarText:"The quality was great.",starSurveyFiveStarText:"The quality was excellent.",surveyConfirmButtonLabel:"Send Feedback",starRatingAriaLabel:"Select {0} of {1} stars",surveySkipButtonLabel:"Skip",tagsSurveyQuestion:"What could have been better?",tagsSurveyTextFieldDefaultText:"Other, please specify",tagsSurveyHelperText:"Check any issues you experienced",surveyTextboxDefaultText:"Other, please specify",endOfSurveyText:"Thank you for your feedback!",surveyIssues:{overallRating:{callCannotJoin:"I could not join call",callCannotInvite:"I could not invite others into the call",hadToRejoin:"I had to rejoin the call",callEndedUnexpectedly:"Call ended for me unexpectedly",otherIssues:"I was having other issues with the call"},audioRating:{noLocalAudio:"The other side could not hear any sound",noRemoteAudio:"I could not hear any sound",echo:"I heard echos on the call",audioNoise:"I heard noise on the call",lowVolume:"Volume was low",audioStoppedUnexpectedly:"Audio stopped unexpectedly",distortedSpeech:"Audio was distorted",audioInterruption:"Audio was interrupted",otherIssues:"I was having other audio issues in this call"},videoRating:{noVideoReceived:"I could not see any video",noVideoSent:"Others could not see me",lowQuality:"Video quality was low",freezes:"Video frozen",stoppedUnexpectedly:"Video stopped unexpectedly",darkVideoReceived:"I can only see dark screens when others turn on their camera",audioVideoOutOfSync:"Audio and Video was out of sync",otherIssues:"I was having other video issues in this call"},screenshareRating:{noContentLocal:"Other people could not see my screenshare",noContentRemote:"I could not see other people's screenshare",cannotPresent:"I could not present my screen",lowQuality:"Screen share quality was low",freezes:"Screen share frozen",stoppedUnexpectedly:"Screen share stopped unexpectedly",largeDelay:"Screen share has a large delay",otherIssues:"I was having other screen share issues in this call"}},SurveyIssuesHeadingStrings:{overallRating:"Overall",audioRating:"Audio",videoRating:"Video",screenshareRating:"Presenting"},spotlightPrompt:{startSpotlightHeading:"Spotlight for everyone?",startSpotlightText:"You'll highlight this video for everyone in the meeting.",startSpotlightOnSelfText:"You'll highlight your video for everyone in the meeting.",startSpotlightConfirmButtonLabel:"Spotlight for everyone",startSpotlightCancelButtonLabel:"Cancel",stopSpotlightHeading:"Stop spotlighting this video?",stopSpotlightOnSelfHeading:"Exit spotlight?",stopSpotlightText:"This video will no longer be highlighted for everyone in the meeting.",stopSpotlightOnSelfText:"Your video will no longer be highlighted for everyone in the meeting.",stopSpotlightConfirmButtonLabel:"Stop spotlighting",stopSpotlightOnSelfConfirmButtonLabel:"Exit spotlight",stopSpotlightCancelButtonLabel:"Cancel"},exitSpotlightButtonLabel:"Exit spotlight",exitSpotlightButtonTooltip:"Exit spotlight"};var chat$k={chatListHeader:"In this chat",uploadFile:"Upload File"};var callWithChat$k={chatButtonLabel:"Chat",chatButtonNewMessageNotificationLabel:"New Message",chatButtonTooltipClosedWithMessageCount:"Show chat ({unreadMessagesCount} unread)",chatButtonTooltipClose:"Hide chat",chatButtonTooltipOpen:"Show chat",chatPaneTitle:"Chat",copyInviteLinkButtonLabel:"Copy invite link",copyInviteLinkActionedAriaLabel:"Invite link copied",dismissSidePaneButtonLabel:"Close",moreDrawerAudioDeviceMenuTitle:"Audio Device",moreDrawerButtonLabel:"More options",moreDrawerButtonTooltip:"More options",moreDrawerMicrophoneMenuTitle:"Microphone",moreDrawerSpeakerMenuTitle:"Speaker",moreDrawerCaptionsMenuTitle:"Live captions",moreDrawerSpokenLanguageMenuTitle:"Spoken language",moreDrawerCaptionLanguageMenuTitle:"Caption language",moreDrawerGalleryOptionsMenuTitle:"Gallery options",peopleButtonLabel:"People",selectedPeopleButtonLabel:"People Button Selected",peopleButtonTooltipOpen:"Show participants",peopleButtonTooltipClose:"Hide participants",peoplePaneSubTitle:"In this call",peoplePaneTitle:"People",pictureInPictureTileAriaLabel:"Video Feeds. Click to return to call screen.",removeMenuLabel:"Remove",openDialpadButtonLabel:"Dial phone number",returnToCallButtonAriaDescription:"Return to Call",returnToCallButtonAriaLabel:"Back",peoplePaneAddPeopleButtonLabel:"Add People",dialpadStartCallButtonLabel:"Call",dialpadModalTitle:"Dial Phone Number",dialpadModalAriaLabel:"Dialpad",dialpadCloseModalButtonAriaLabel:"Close dialpad",openDtmfDialpadLabel:"Show dialpad",dtmfDialpadPlaceholderText:"Enter number"};var en_US = {call:call$k,chat:chat$k,callWithChat:callWithChat$k};
23659
+ var call$k={cameraLabel:"Camera",noCamerasLabel:"No cameras found",cameraPermissionDenied:"Your browser is blocking access to your camera",cameraTurnedOff:"Your camera is turned off",chatButtonLabel:"Chat",close:"Close",complianceBannerNowOnlyRecording:"You are now only recording this meeting.",complianceBannerNowOnlyTranscription:"You are now only transcribing this meeting.",complianceBannerRecordingAndTranscriptionSaved:"Recording and transcription are being saved.",complianceBannerRecordingAndTranscriptionStarted:"Recording and transcription have started.",complianceBannerRecordingAndTranscriptionStopped:"Recording and transcription have stopped.",complianceBannerRecordingSaving:"Recording is being saved.",complianceBannerRecordingStarted:"Recording has started.",complianceBannerRecordingStopped:"Recording has stopped.",complianceBannerTranscriptionStarted:"Transcription has started.",complianceBannerTranscriptionConsent:"By joining, you are giving consent for this meeting to be transcribed.",complianceBannerTranscriptionSaving:"Transcription is being saved.",complianceBannerTranscriptionStopped:"Transcription has stopped.",configurationPageTitle:"Start a call",copyInviteLinkButtonLabel:"Copy invite link",copyInviteLinkActionedAriaLabel:"Invite link copied",defaultPlaceHolder:"Select an option",dismissSidePaneButtonLabel:"Close",videoEffectsPaneTitle:"Effects",videoEffectsPaneBackgroundSelectionTitle:"Background",configurationPageVideoEffectsButtonLabel:"Effects",unableToStartVideoEffect:"Unable to apply video effect.",blurBackgroundEffectButtonLabel:"Blur",blurBackgroundTooltip:"Blur Background",removeBackgroundEffectButtonLabel:"None",removeBackgroundTooltip:"Remove Background",cameraOffBackgroundEffectWarningText:"Your camera is off. Turn on camera to see video effect.",failedToJoinCallDueToNoNetworkMoreDetails:"Call was disconnected due to a network issue. Check your connection and join again.",failedToJoinCallDueToNoNetworkTitle:"Call disconnected",failedToJoinTeamsMeetingReasonAccessDeniedMoreDetails:"You were not granted entry in the call. If this was a mistake, re-join the call.",failedToJoinTeamsMeetingReasonAccessDeniedTitle:"Dismissed from lobby",learnMore:"Learn more",leavingCallTitle:"Leaving...",leftCallMoreDetails:"If this was a mistake, re-join the call.",leftCallTitle:"You left the call",lobbyScreenConnectingToCallTitle:"Joining call",lobbyScreenWaitingToBeAdmittedTitle:"Waiting to be admitted",microphonePermissionDenied:"Your browser is blocking access to your microphone",microphoneToggleInLobbyNotAllowed:"Cannot mute or unmute while in lobby.",mutedMessage:"You're muted",networkReconnectMoreDetails:"Looks like something went wrong. We're trying to get back into the call.",networkReconnectTitle:"Hold on",notInvitedToRoomDetails:"You are not able to join this room because you do not have an invite.",notInvitedToRoomTitle:"Not invited to room",peopleButtonLabel:"People",selectedPeopleButtonLabel:"People Button Selected",peoplePaneTitle:"People",peoplePaneMoreButtonAriaLabel:"More",peopleButtonTooltipOpen:"Show participants",peopleButtonTooltipClose:"Hide participants",peoplePaneSubTitle:"In this call {numberOfPeople}",privacyPolicy:"Privacy policy",rejoinCallButtonLabel:"Re-join call",removedFromCallMoreDetails:"Another participant removed you from the call.",removedFromCallTitle:"You were removed",removeMenuLabel:"Remove",startSpotlightParticipantListMenuLabel:"Spotlight for everyone",addSpotlightParticipantListMenuLabel:"Add spotlight",stopSpotlightParticipantListMenuLabel:"Stop spotlighting",stopSpotlightOnSelfParticipantListMenuLabel:"Exit spotlight",spotlightLimitReachedParticipantListMenuTitle:"Spotlight limit reached",stopAllSpotlightMenuLabel:"Stop all spotlights",returnToCallButtonAriaDescription:"Return to Call",returnToCallButtonAriaLabel:"Back",roomNotFoundDetails:"The room ID provided could not be found.",roomNotFoundTitle:"Room not found",roomNotValidDetails:"This room is not valid at this current time.",roomNotValidTitle:"Room not valid",inviteToRoomRemovedDetails:"Your invite to join this room was removed.",inviteToRoomRemovedTitle:"Invite to room removed",soundLabel:"Sound",noMicrophonesLabel:"No microphones found",noSpeakersLabel:"No speakers found",startCallButtonLabel:"Start call",openDialpadButtonLabel:"Dial phone number",peoplePaneAddPeopleButtonLabel:"Add People",dialpadStartCallButtonLabel:"Call",dialpadModalTitle:"Dial Phone Number",dialpadModalAriaLabel:"Dialpad",dialpadCloseModalButtonAriaLabel:"Close dialpad",moreButtonCallingLabel:"More",resumeCallButtonLabel:"Resume",resumingCallButtonLabel:"Resuming...",resumeCallButtonAriaLabel:"Resume call",resumingCallButtonAriaLabel:"Resume call",holdScreenLabel:"You're on hold",openDtmfDialpadLabel:"Show dialpad",dtmfDialpadPlaceholderText:"Enter number",outboundCallingNoticeString:"Calling...",participantJoinedNoticeString:"{displayName} joined",twoParticipantJoinedNoticeString:"{displayName1} and {displayName2} have joined",threeParticipantJoinedNoticeString:"{displayName1}, {displayName2} and {displayName3} have joined",participantLeftNoticeString:"{displayName} left",twoParticipantLeftNoticeString:"{displayName1} and {displayName2} have left",threeParticipantLeftNoticeString:"{displayName1}, {displayName2} and {displayName3} have left",unnamedParticipantString:"unnamed participant",manyUnnamedParticipantsJoined:"unnamed participant and {numOfParticipants} other participants joined",manyUnnamedParticipantsLeft:"unnamed participant and {numOfParticipants} other participants left",manyParticipantsJoined:"{displayName1}, {displayName2}, {displayName3} and {numOfParticipants} other participants joined",manyParticipantsLeft:"{displayName1}, {displayName2}, {displayName3} and {numOfParticipants} other participants left",liveCaptionsLabel:"Live captions",captionsSettingsLabel:"Caption settings",startCaptionsButtonOnLabel:"Turn on captions",startCaptionsButtonOffLabel:"Turn off captions",startCaptionsButtonTooltipOnContent:"Turn off captions",startCaptionsButtonTooltipOffContent:"Turn on captions",captionsSettingsModalTitle:"Captions Settings",captionsSettingsSpokenLanguageDropdownLabel:"Spoken language",captionsSettingsCaptionLanguageDropdownLabel:"Captions language",captionsSettingsSpokenLanguageDropdownInfoText:"Language that everyone on this call is speaking.",captionsSettingsCaptionLanguageDropdownInfoText:"Captions will appear in this langugage.",captionsSettingsConfirmButtonLabel:"Confirm",captionsSettingsCancelButtonLabel:"Cancel",captionsSettingsModalAriaLabel:"Captions Setting Modal",captionsSettingsCloseModalButtonAriaLabel:"Close Captions Setting",captionsBannerMoreButtonCallingLabel:"More",captionsBannerMoreButtonTooltip:"More options",dismissModalAriaLabel:"Local and remote picture and picture, press enter to return to call",callRejectedTitle:"The call could not be completed",callRejectedMoreDetails:"The person you are trying to reach is unavailable. Please try again later.",callTimeoutTitle:"The call could not be completed",callTimeoutDetails:"The person you are trying to reach is unavailable. Please try again later.",callTimeoutBotTitle:"The call could not be completed",callTimeoutBotDetails:"The service that you are trying to reach is unavailable. Please try again later.",dtmfDialerButtonLabel:"Dialpad",dtmfDialerButtonTooltipOn:"Show dialpad",dtmfDialerButtonTooltipOff:"Hide dialpad",dtmfDialerMoreButtonLabelOn:"Show dialpad",dtmfDialerMoreButtonLabelOff:"Hide dialpad",spokenLanguageStrings:{"ar-ae":"Arabic - U.A.E.","ar-sa":"Arabic - Saudi Arabia","da-dk":"Danish","de-de":"German - Germany","en-au":"English - Australia","en-ca":"English - Canada","en-gb":"English - United Kingdom","en-in":"English - India","en-nz":"English - New Zealand","en-us":"English - United States","es-es":"Spanish - Spain (Modern Sort)","es-mx":"Spanish - Mexico","fi-fi":"Finnish","fr-ca":"French - Canada","fr-fr":"French - France","hi-in":"Hindi","it-it":"Italian - Italy","ja-jp":"Japanese","ko-kr":"Korean","nb-no":"Norwegian (Bokmål)","nl-be":"Dutch - Belgium","nl-nl":"Dutch - Netherlands","pl-pl":"Polish","pt-br":"Portuguese - Brazil","ru-ru":"Russian","sv-se":"Swedish","zh-cn":"Chinese - People's Republic of China","zh-hk":"Chinese - Hong Kong SAR","cs-cz":"Czech","pt-pt":"Portuguese - Portugal","tr-tr":"Turkish","vi-vn":"Vietnamese","th-th":"Thai","he-il":"Hebrew","cy-gb":"Welsh","uk-ua":"Ukrainian","el-gr":"Greek","hu-hu":"Hungarian","ro-ro":"Romanian","sk-sk":"Slovak","zh-tw":"Chinese - Taiwan"},captionLanguageStrings:{ar:"Arabic",da:"Danish",de:"German",en:"English",es:"Spanish",fi:"Finnish","fr-ca":"French - Canada",fr:"French - France",hi:"Hindi",it:"Italian",ja:"Japanese",ko:"Korean",nb:"Norwegian (Bokmål)",nl:"Dutch",pl:"Polish",pt:"Portuguese - Brazil",ru:"Russian",sv:"Swedish","zh-Hans":"Chinese (Simplified)","zh-Hant":"Chinese (Traditional)",cs:"Czech","pt-pt":"Portuguese - Portugal",tr:"Turkish",vi:"Vietnamese",th:"Thai",he:"Hebrew",cy:"Welsh",uk:"Ukrainian",el:"Greek",hu:"Hungarian",ro:"Romanian",sk:"Slovak"},captionsBannerSpinnerText:"Starting captions...",transferPageTransferorText:"Transferring...",transferPageTransferTargetText:"Connecting...",transferPageUnknownTransferorDisplayName:"Unknown",transferPageUnknownTransferTargetDisplayName:"Unknown",transferPageNoticeString:"You are being transferred",participantCouldNotBeReachedTitle:"Target participant is currently not available",participantCouldNotBeReachedMoreDetails:"Please contact participant when they are available",permissionToReachTargetParticipantNotAllowedTitle:"Permission to reach target participant is not allowed",permissionToReachTargetParticipantNotAllowedMoreDetails:"Please check that the target participant is in the same tenant",unableToResolveTenantTitle:"Unable to resolve tenant id for the target participant",unableToResolveTenantMoreDetails:"Please check the participant id is entered correctly",participantIdIsMalformedTitle:"Participant id is not in the correct format",participantIdIsMalformedMoreDetails:"Please check that the participant id is in the correct format",moreButtonGalleryControlLabel:"View",moreButtonGalleryPositionToggleLabel:"Move gallery to top",moreButtonGallerySpeakerLayoutLabel:"Speaker",moreButtonGalleryFloatingLocalLayoutLabel:"Dynamic",moreButtonGalleryDefaultLayoutLabel:"Gallery view",moreButtonGalleryFocusedContentLayoutLabel:"Focus on content",moreButtonLargeGalleryDefaultLayoutLabel:"Large Gallery",capabilityChangedNotification:{turnVideoOn:{lostDueToMeetingOption:"Your camera has been disabled. You can no longer share video.",grantedDueToMeetingOption:"Your camera has been enabled. Turn it on if you'd like to share video."},unmuteMic:{lostDueToMeetingOption:"Your mic has been disabled. You can no longer unmute.",grantedDueToMeetingOption:"Your mic has been enabled. Unmute if you'd like to speak."},shareScreen:{lostDueToRoleChangeToAttendee:"Your role has been changed. Some actions, like sharing content, won't be available to you.",grantedDueToRoleChangeToPresenter:"You're a presenter. You can share content and facilitate the meeting."}},surveyTitle:"Help us improve",starSurveyHelperText:"How was the quality of the call?",starSurveyOneStarText:"The quality was bad.",starSurveyTwoStarText:"The quality was poor.",starSurveyThreeStarText:"The quality was good.",starSurveyFourStarText:"The quality was great.",starSurveyFiveStarText:"The quality was excellent.",surveyConfirmButtonLabel:"Send Feedback",starRatingAriaLabel:"Select {0} of {1} stars",surveySkipButtonLabel:"Skip",tagsSurveyQuestion:"What could have been better?",tagsSurveyTextFieldDefaultText:"Other, please specify",tagsSurveyHelperText:"Check any issues you experienced",surveyTextboxDefaultText:"Other, please specify",endOfSurveyText:"Thank you for your feedback!",surveyIssues:{overallRating:{callCannotJoin:"I could not join call",callCannotInvite:"I could not invite others into the call",hadToRejoin:"I had to rejoin the call",callEndedUnexpectedly:"Call ended for me unexpectedly",otherIssues:"I was having other issues with the call"},audioRating:{noLocalAudio:"The other side could not hear any sound",noRemoteAudio:"I could not hear any sound",echo:"I heard echos on the call",audioNoise:"I heard noise on the call",lowVolume:"Volume was low",audioStoppedUnexpectedly:"Audio stopped unexpectedly",distortedSpeech:"Audio was distorted",audioInterruption:"Audio was interrupted",otherIssues:"I was having other audio issues in this call"},videoRating:{noVideoReceived:"I could not see any video",noVideoSent:"Others could not see me",lowQuality:"Video quality was low",freezes:"Video frozen",stoppedUnexpectedly:"Video stopped unexpectedly",darkVideoReceived:"I can only see dark screens when others turn on their camera",audioVideoOutOfSync:"Audio and Video was out of sync",otherIssues:"I was having other video issues in this call"},screenshareRating:{noContentLocal:"Other people could not see my screenshare",noContentRemote:"I could not see other people's screenshare",cannotPresent:"I could not present my screen",lowQuality:"Screen share quality was low",freezes:"Screen share frozen",stoppedUnexpectedly:"Screen share stopped unexpectedly",largeDelay:"Screen share has a large delay",otherIssues:"I was having other screen share issues in this call"}},SurveyIssuesHeadingStrings:{overallRating:"Overall",audioRating:"Audio",videoRating:"Video",screenshareRating:"Presenting"},spotlightPrompt:{startSpotlightHeading:"Spotlight for everyone?",startSpotlightText:"You'll highlight this video for everyone in the meeting.",startSpotlightOnSelfText:"You'll highlight your video for everyone in the meeting.",startSpotlightConfirmButtonLabel:"Spotlight for everyone",startSpotlightCancelButtonLabel:"Cancel",stopSpotlightHeading:"Stop spotlighting this video?",stopSpotlightOnSelfHeading:"Exit spotlight?",stopSpotlightText:"This video will no longer be highlighted for everyone in the meeting.",stopSpotlightOnSelfText:"Your video will no longer be highlighted for everyone in the meeting.",stopSpotlightConfirmButtonLabel:"Stop spotlighting",stopSpotlightOnSelfConfirmButtonLabel:"Exit spotlight",stopSpotlightCancelButtonLabel:"Cancel"},exitSpotlightButtonLabel:"Exit spotlight",exitSpotlightButtonTooltip:"Exit spotlight"};var chat$k={chatListHeader:"In this chat",uploadFile:"Upload File"};var callWithChat$k={chatButtonLabel:"Chat",chatButtonNewMessageNotificationLabel:"New Message",chatButtonTooltipClosedWithMessageCount:"Show chat ({unreadMessagesCount} unread)",chatButtonTooltipClose:"Hide chat",chatButtonTooltipOpen:"Show chat",chatPaneTitle:"Chat",copyInviteLinkButtonLabel:"Copy invite link",copyInviteLinkActionedAriaLabel:"Invite link copied",dismissSidePaneButtonLabel:"Close",moreDrawerAudioDeviceMenuTitle:"Audio Device",moreDrawerButtonLabel:"More options",moreDrawerButtonTooltip:"More options",moreDrawerMicrophoneMenuTitle:"Microphone",moreDrawerSpeakerMenuTitle:"Speaker",moreDrawerCaptionsMenuTitle:"Live captions",moreDrawerSpokenLanguageMenuTitle:"Spoken language",moreDrawerCaptionLanguageMenuTitle:"Caption language",moreDrawerGalleryOptionsMenuTitle:"Gallery options",peopleButtonLabel:"People",selectedPeopleButtonLabel:"People Button Selected",peopleButtonTooltipOpen:"Show participants",peopleButtonTooltipClose:"Hide participants",peoplePaneSubTitle:"In this call",peoplePaneTitle:"People",pictureInPictureTileAriaLabel:"Video Feeds. Click to return to call screen.",removeMenuLabel:"Remove",openDialpadButtonLabel:"Dial phone number",returnToCallButtonAriaDescription:"Return to Call",returnToCallButtonAriaLabel:"Back",peoplePaneAddPeopleButtonLabel:"Add People",dialpadStartCallButtonLabel:"Call",dialpadModalTitle:"Dial Phone Number",dialpadModalAriaLabel:"Dialpad",dialpadCloseModalButtonAriaLabel:"Close dialpad",openDtmfDialpadLabel:"Show dialpad",dtmfDialpadPlaceholderText:"Enter number"};var en_US = {call:call$k,chat:chat$k,callWithChat:callWithChat$k};
23672
23660
 
23673
23661
  // Copyright (c) Microsoft Corporation.
23674
23662
  // Licensed under the MIT License.
@@ -26161,6 +26149,10 @@ const createCompositeHandlers = memoizeOne((adapter) => {
26161
26149
  yield adapter.stopSpotlight(userIds);
26162
26150
  }),
26163
26151
  /* @conditional-compile-remove(spotlight) */
26152
+ onStopAllSpotlight: () => __awaiter$j(void 0, void 0, void 0, function* () {
26153
+ yield adapter.stopAllSpotlight();
26154
+ }),
26155
+ /* @conditional-compile-remove(spotlight) */
26164
26156
  onStartLocalSpotlight: () => __awaiter$j(void 0, void 0, void 0, function* () {
26165
26157
  yield adapter.startSpotlight();
26166
26158
  }),
@@ -27897,7 +27889,7 @@ const DtmfDialpadButton = (props) => {
27897
27889
  * @private
27898
27890
  */
27899
27891
  const ExitSpotlightButton = (props) => {
27900
- return (React.createElement(ControlBarButton, Object.assign({ "data-ui-id": 'call-composite-exit-spotlight-button', labelKey: 'exitSpotlightButtonLabelKey', showLabel: props.displayType !== 'compact', onRenderIcon: () => React.createElement(_HighContrastAwareIcon, { iconName: 'StopSpotlightContextualMenuItem' }), onClick: props.onClick }, props)));
27892
+ return (React.createElement(ControlBarButton, Object.assign({ "data-ui-id": 'call-composite-exit-spotlight-button', labelKey: 'exitSpotlightButtonLabelKey', showLabel: props.displayType !== 'compact', onRenderIcon: () => React.createElement(_HighContrastAwareIcon, { iconName: 'ControlButtonExitSpotlight' }), onClick: props.onClick }, props)));
27901
27893
  };
27902
27894
 
27903
27895
  // Copyright (c) Microsoft Corporation.
@@ -28836,7 +28828,14 @@ const mobilePaneControlBarStyle = { root: { height: '3rem' } };
28836
28828
  * @private
28837
28829
  */
28838
28830
  const mobilePaneBackButtonStyles = {
28839
- root: { border: 'none', minWidth: '2.5rem', height: '100%', background: 'none', padding: '0 1rem' },
28831
+ root: {
28832
+ border: 'none',
28833
+ minWidth: '2.5rem',
28834
+ maxWidth: '2.875rem',
28835
+ height: '100%',
28836
+ background: 'none',
28837
+ padding: '0 1rem'
28838
+ },
28840
28839
  rootChecked: { background: 'none' },
28841
28840
  rootCheckedHovered: { background: 'none' }
28842
28841
  };
@@ -28967,7 +28966,11 @@ const PeopleAndChatHeader = (props) => {
28967
28966
  React.createElement(react.Stack, { horizontal: true, styles: availableSpaceStyles },
28968
28967
  React.createElement(react.Stack.Item, { grow: true }, onChatButtonClicked && (React.createElement(react.DefaultButton, { onClick: onChatButtonClicked, styles: mobilePaneButtonStylesThemed, checked: activeTab === 'chat', "aria-selected": activeTab === 'chat', role: 'tab', disabled: props.disableChatButton }, strings.chatButtonLabel))),
28969
28968
  React.createElement(react.Stack.Item, { grow: true }, onPeopleButtonClicked && (React.createElement(react.DefaultButton, { onClick: onPeopleButtonClicked, styles: mobilePaneButtonStylesThemed, checked: activeTab === 'people', "aria-selected": activeTab === 'people', role: 'tab', disabled: props.disablePeopleButton }, strings.peopleButtonLabel)))))),
28970
- React.createElement(react.DefaultButton, { styles: mobilePaneHiddenIconStyles, onRenderIcon: () => React.createElement(CallWithChatCompositeIcon, { iconName: "ChevronLeft" }) })));
28969
+ props.onHeaderMenuClick ? (React.createElement(react.DefaultButton, { ariaLabel: strings.peoplePaneMoreButtonAriaLabel, styles: react.concatStyleSets(mobilePaneBackButtonStyles, {
28970
+ icon: { display: 'flex', alignItems: 'center' }
28971
+ }), iconProps: { iconName: 'PeoplePaneMoreButton' }, onClick: props.onHeaderMenuClick })) : (
28972
+ /* Hidden icon to take the same space as the actual back button on the left. */
28973
+ React.createElement(react.DefaultButton, { styles: mobilePaneHiddenIconStyles, onRenderIcon: () => React.createElement(CallWithChatCompositeIcon, { iconName: "ChevronLeft" }) }))));
28971
28974
  };
28972
28975
 
28973
28976
  // Copyright (c) Microsoft Corporation.
@@ -29000,13 +29003,14 @@ const SidePane = (props) => {
29000
29003
  var _a;
29001
29004
  return (React.createElement(PeopleAndChatHeader, { onClose: overrideSidePaneId === 'chat' ? (_a = props.onChatButtonClicked) !== null && _a !== void 0 ? _a : noop : closePane, activeTab: (sidePaneRenderer === null || sidePaneRenderer === void 0 ? void 0 : sidePaneRenderer.id) === 'people' ? 'people' : 'chat',
29002
29005
  // legacy arguments to be removed in breaking change:
29003
- disablePeopleButton: props.disablePeopleButton, disableChatButton: props.disableChatButton, onPeopleButtonClicked: (sidePaneRenderer === null || sidePaneRenderer === void 0 ? void 0 : sidePaneRenderer.id) === 'people' ? noop : props.onPeopleButtonClicked, onChatButtonClicked: overrideSidePaneId === 'chat' ? noop : props.onChatButtonClicked }));
29006
+ disablePeopleButton: props.disablePeopleButton, disableChatButton: props.disableChatButton, onPeopleButtonClicked: (sidePaneRenderer === null || sidePaneRenderer === void 0 ? void 0 : sidePaneRenderer.id) === 'people' ? noop : props.onPeopleButtonClicked, onChatButtonClicked: overrideSidePaneId === 'chat' ? noop : props.onChatButtonClicked, onHeaderMenuClick: props.onHeaderMenuClick }));
29004
29007
  }, [
29005
29008
  overrideSidePaneId,
29006
29009
  props.onChatButtonClicked,
29007
29010
  props.onPeopleButtonClicked,
29008
29011
  props.disablePeopleButton,
29009
29012
  props.disableChatButton,
29013
+ props.onHeaderMenuClick,
29010
29014
  sidePaneRenderer === null || sidePaneRenderer === void 0 ? void 0 : sidePaneRenderer.id,
29011
29015
  closePane
29012
29016
  ]);
@@ -29041,6 +29045,7 @@ const EmptyElement = () => React.createElement(React.Fragment, null);
29041
29045
  * @private
29042
29046
  */
29043
29047
  const SidePaneHeader = (props) => {
29048
+ var _a;
29044
29049
  const theme = useTheme();
29045
29050
  const sidePaneCloseButtonStyles = React.useMemo(() => ({
29046
29051
  root: {
@@ -29057,7 +29062,11 @@ const SidePaneHeader = (props) => {
29057
29062
  return React.createElement(SidePaneMobileHeader, Object.assign({}, props));
29058
29063
  }
29059
29064
  return (React.createElement(react.Stack, { horizontal: true, horizontalAlign: "space-between", styles: sidePaneHeaderContainerStyles, verticalAlign: "center" },
29060
- React.createElement(react.Stack.Item, { role: "heading", styles: sidePaneHeaderStyles }, props.headingText),
29065
+ React.createElement(react.Stack.Item /* @conditional-compile-remove(spotlight) */, { grow: true, role: "heading", styles: sidePaneHeaderStyles }, props.headingText),
29066
+ /* @conditional-compile-remove(spotlight) */ ((_a = props.menuProps) === null || _a === void 0 ? void 0 : _a.items) && props.menuProps.items.length > 0 && (React.createElement(react.Stack.Item, null,
29067
+ React.createElement(react.CommandBarButton, { ariaLabel: props.moreSidePaneButtonAriaLabel, styles: react.concatStyleSets(sidePaneCloseButtonStyles, {
29068
+ icon: { display: 'flex', alignItems: 'center' }
29069
+ }), iconProps: { iconName: 'PeoplePaneMoreButton' }, menuProps: props.menuProps, onRenderMenuIcon: () => null }))),
29061
29070
  React.createElement(react.Stack.Item, null,
29062
29071
  React.createElement(react.CommandBarButton, { ariaLabel: props.dismissSidePaneButtonAriaLabel, styles: sidePaneCloseButtonStyles, iconProps: { iconName: 'cancel' }, onClick: props.onClose }))));
29063
29072
  };
@@ -29550,6 +29559,8 @@ const usePeoplePane = (props) => {
29550
29559
  /* @conditional-compile-remove(spotlight) */
29551
29560
  onStopRemoteSpotlight,
29552
29561
  /* @conditional-compile-remove(spotlight) */
29562
+ onStopAllSpotlight,
29563
+ /* @conditional-compile-remove(spotlight) */
29553
29564
  maxParticipantsToSpotlight } = props;
29554
29565
  const closePane = React.useCallback(() => {
29555
29566
  var _a;
@@ -29557,7 +29568,29 @@ const usePeoplePane = (props) => {
29557
29568
  (_a = peopleButtonRef === null || peopleButtonRef === void 0 ? void 0 : peopleButtonRef.current) === null || _a === void 0 ? void 0 : _a.focus();
29558
29569
  }, [peopleButtonRef, updateSidePaneRenderer]);
29559
29570
  const localeStrings = useLocale().strings.call;
29560
- const onRenderHeader = React.useCallback(() => (React.createElement(SidePaneHeader, { onClose: closePane, headingText: localeStrings.peoplePaneTitle, dismissSidePaneButtonAriaLabel: localeStrings.dismissSidePaneButtonLabel, mobileView: mobileView !== null && mobileView !== void 0 ? mobileView : false })), [mobileView, closePane, localeStrings]);
29571
+ /* @conditional-compile-remove(spotlight) */
29572
+ const sidePaneHeaderMenuProps = React.useMemo(() => {
29573
+ const menuItems = [];
29574
+ if (onStopAllSpotlight && spotlightedParticipantUserIds && spotlightedParticipantUserIds.length > 0) {
29575
+ menuItems.push({
29576
+ key: 'stopAllSpotlightKey',
29577
+ text: localeStrings.stopAllSpotlightMenuLabel,
29578
+ iconProps: { iconName: 'StopAllSpotlightMenuButton', styles: { root: { lineHeight: 0 } } },
29579
+ onClick: () => {
29580
+ onStopAllSpotlight();
29581
+ },
29582
+ ariaLabel: localeStrings.stopAllSpotlightMenuLabel
29583
+ });
29584
+ }
29585
+ return {
29586
+ items: menuItems
29587
+ };
29588
+ }, [onStopAllSpotlight, spotlightedParticipantUserIds, localeStrings.stopAllSpotlightMenuLabel]);
29589
+ const onRenderHeader = React.useCallback(() => (React.createElement(SidePaneHeader, { onClose: closePane, headingText: localeStrings.peoplePaneTitle, dismissSidePaneButtonAriaLabel: localeStrings.dismissSidePaneButtonLabel, mobileView: mobileView !== null && mobileView !== void 0 ? mobileView : false,
29590
+ /* @conditional-compile-remove(spotlight) */
29591
+ moreSidePaneButtonAriaLabel: localeStrings.peoplePaneMoreButtonAriaLabel,
29592
+ /* @conditional-compile-remove(spotlight) */
29593
+ menuProps: sidePaneHeaderMenuProps })), [mobileView, closePane, localeStrings, /* @conditional-compile-remove(spotlight) */ sidePaneHeaderMenuProps]);
29561
29594
  /* @conditional-compile-remove(spotlight) */
29562
29595
  const onFetchParticipantMenuItemsForCallComposite = React.useCallback((participantId, myUserId, defaultMenuItems) => {
29563
29596
  const _defaultMenuItems = defaultMenuItems !== null && defaultMenuItems !== void 0 ? defaultMenuItems : [];
@@ -30477,7 +30510,7 @@ const getStopRemoteSpotlightWithPromptCallback = (onStopSpotlight, setIsPromptOp
30477
30510
  * @private
30478
30511
  */
30479
30512
  const CallArrangement = (props) => {
30480
- var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;
30513
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m;
30481
30514
  const containerClassName = React.useMemo(() => {
30482
30515
  return props.mobileView ? containerStyleMobile : containerStyleDesktop;
30483
30516
  }, [props.mobileView]);
@@ -30526,21 +30559,31 @@ const CallArrangement = (props) => {
30526
30559
  const { onStartLocalSpotlightWithPrompt, onStopLocalSpotlightWithPrompt } = useLocalSpotlightCallbacksWithPrompt(onStartLocalSpotlight, onStopLocalSpotlight, setIsPromptOpen, setPromptProps);
30527
30560
  /* @conditional-compile-remove(spotlight) */
30528
30561
  const { onStartRemoteSpotlightWithPrompt, onStopRemoteSpotlightWithPrompt } = useRemoteSpotlightCallbacksWithPrompt(onStartRemoteSpotlight, onStopRemoteSpotlight, setIsPromptOpen, setPromptProps);
30529
- const { isPeoplePaneOpen, openPeoplePane, closePeoplePane } = usePeoplePane(Object.assign(Object.assign({}, peoplePaneProps), {
30530
- /* @conditional-compile-remove(spotlight) */ spotlightedParticipantUserIds: spotlightedParticipants,
30531
- /* @conditional-compile-remove(spotlight) */ onStartLocalSpotlight: hideSpotlightButtons
30532
- ? undefined
30533
- : onStartLocalSpotlightWithPrompt,
30534
- /* @conditional-compile-remove(spotlight) */ onStopLocalSpotlight: hideSpotlightButtons
30535
- ? undefined
30536
- : onStopLocalSpotlightWithPrompt,
30537
- /* @conditional-compile-remove(spotlight) */ onStartRemoteSpotlight: hideSpotlightButtons
30538
- ? undefined
30539
- : onStartRemoteSpotlightWithPrompt,
30540
- /* @conditional-compile-remove(spotlight) */ onStopRemoteSpotlight: hideSpotlightButtons
30541
- ? undefined
30542
- : onStopRemoteSpotlightWithPrompt,
30543
- /* @conditional-compile-remove(spotlight) */ maxParticipantsToSpotlight }));
30562
+ /* @conditional-compile-remove(spotlight) */
30563
+ const canSpotlight = (_c = (_b = adapter.getState().call) === null || _b === void 0 ? void 0 : _b.capabilitiesFeature) === null || _c === void 0 ? void 0 : _c.capabilities.spotlightParticipant.isPresent;
30564
+ const spotlightPeoplePaneProps = React.useMemo(() => {
30565
+ /* @conditional-compile-remove(spotlight) */
30566
+ return {
30567
+ spotlightedParticipantUserIds: spotlightedParticipants,
30568
+ onStartLocalSpotlight: hideSpotlightButtons ? undefined : onStartLocalSpotlightWithPrompt,
30569
+ onStopLocalSpotlight: hideSpotlightButtons ? undefined : onStopLocalSpotlightWithPrompt,
30570
+ onStartRemoteSpotlight: hideSpotlightButtons ? undefined : onStartRemoteSpotlightWithPrompt,
30571
+ onStopRemoteSpotlight: hideSpotlightButtons ? undefined : onStopRemoteSpotlightWithPrompt,
30572
+ onStopAllSpotlight: hideSpotlightButtons || !canSpotlight ? undefined : () => adapter.stopAllSpotlight(),
30573
+ maxParticipantsToSpotlight
30574
+ };
30575
+ }, [
30576
+ /* @conditional-compile-remove(spotlight) */ adapter,
30577
+ /* @conditional-compile-remove(spotlight) */ hideSpotlightButtons,
30578
+ /* @conditional-compile-remove(spotlight) */ maxParticipantsToSpotlight,
30579
+ /* @conditional-compile-remove(spotlight) */ onStartLocalSpotlightWithPrompt,
30580
+ /* @conditional-compile-remove(spotlight) */ onStartRemoteSpotlightWithPrompt,
30581
+ /* @conditional-compile-remove(spotlight) */ onStopLocalSpotlightWithPrompt,
30582
+ /* @conditional-compile-remove(spotlight) */ onStopRemoteSpotlightWithPrompt,
30583
+ /* @conditional-compile-remove(spotlight) */ spotlightedParticipants,
30584
+ /* @conditional-compile-remove(spotlight) */ canSpotlight
30585
+ ]);
30586
+ const { isPeoplePaneOpen, openPeoplePane, closePeoplePane } = usePeoplePane(Object.assign(Object.assign({}, peoplePaneProps), spotlightPeoplePaneProps));
30544
30587
  const togglePeoplePane = React.useCallback(() => {
30545
30588
  if (isPeoplePaneOpen) {
30546
30589
  closePeoplePane();
@@ -30594,7 +30637,7 @@ const CallArrangement = (props) => {
30594
30637
  }, [togglePeoplePane]);
30595
30638
  const drawerContainerStylesValue = React.useMemo(() => drawerContainerStyles(DRAWER_Z_INDEX), []);
30596
30639
  /* @conditional-compile-remove(rooms) */
30597
- const role = (_b = adapter.getState().call) === null || _b === void 0 ? void 0 : _b.role;
30640
+ const role = (_d = adapter.getState().call) === null || _d === void 0 ? void 0 : _d.role;
30598
30641
  let canUnmute = true;
30599
30642
  /* @conditional-compile-remove(rooms) */
30600
30643
  canUnmute = role !== 'Consumer' ? true : false;
@@ -30624,15 +30667,51 @@ const CallArrangement = (props) => {
30624
30667
  /* @conditional-compile-remove(capabilities) */
30625
30668
  // Filter out shareScreen capability notifications if on mobile
30626
30669
  const filteredCapabilitesChangedNotifications = props.mobileView
30627
- ? (_c = props.capabilitiesChangedNotificationBarProps) === null || _c === void 0 ? void 0 : _c.capabilitiesChangedNotifications.filter((notification) => notification.capabilityName !== 'shareScreen')
30628
- : (_d = props.capabilitiesChangedNotificationBarProps) === null || _d === void 0 ? void 0 : _d.capabilitiesChangedNotifications;
30670
+ ? (_e = props.capabilitiesChangedNotificationBarProps) === null || _e === void 0 ? void 0 : _e.capabilitiesChangedNotifications.filter((notification) => notification.capabilityName !== 'shareScreen')
30671
+ : (_f = props.capabilitiesChangedNotificationBarProps) === null || _f === void 0 ? void 0 : _f.capabilitiesChangedNotifications;
30672
+ /* @conditional-compile-remove(spotlight) */
30673
+ const onHeaderMenuClick = React.useMemo(() => {
30674
+ if (!props.mobileView) {
30675
+ return undefined;
30676
+ }
30677
+ const headerMenuItems = [];
30678
+ if (isPeoplePaneOpen) {
30679
+ if (spotlightedParticipants && spotlightedParticipants.length > 0 && !hideSpotlightButtons && canSpotlight) {
30680
+ headerMenuItems.push({
30681
+ itemKey: 'stopAllSpotlightKey',
30682
+ text: locale.strings.call.stopAllSpotlightMenuLabel,
30683
+ iconProps: {
30684
+ iconName: 'StopAllSpotlightMenuButton',
30685
+ styles: { root: { lineHeight: 0 } }
30686
+ },
30687
+ onItemClick: () => {
30688
+ adapter.stopAllSpotlight();
30689
+ setDrawerMenuItems([]);
30690
+ }
30691
+ });
30692
+ }
30693
+ }
30694
+ return headerMenuItems.length > 0
30695
+ ? () => {
30696
+ setDrawerMenuItems(headerMenuItems);
30697
+ }
30698
+ : undefined;
30699
+ }, [
30700
+ props.mobileView,
30701
+ isPeoplePaneOpen,
30702
+ spotlightedParticipants,
30703
+ hideSpotlightButtons,
30704
+ canSpotlight,
30705
+ locale.strings.call.stopAllSpotlightMenuLabel,
30706
+ adapter
30707
+ ]);
30629
30708
  return (React.createElement("div", { ref: containerRef, className: react.mergeStyles(containerDivStyles), id: props.id },
30630
30709
  React.createElement(react.Stack, { verticalFill: true, horizontalAlign: "stretch", className: containerClassName, "data-ui-id": props.dataUiId },
30631
30710
  React.createElement(react.Stack, { reversed: true, horizontal: verticalControlBar, grow: true, styles: callArrangementContainerStyles(verticalControlBar) },
30632
- ((_e = props.callControlProps) === null || _e === void 0 ? void 0 : _e.options) !== false && !isMobileWithActivePane && (React.createElement(react.Stack, { verticalAlign: 'center', className: react.mergeStyles({
30711
+ ((_g = props.callControlProps) === null || _g === void 0 ? void 0 : _g.options) !== false && !isMobileWithActivePane && (React.createElement(react.Stack, { verticalAlign: 'center', className: react.mergeStyles({
30633
30712
  zIndex: CONTROL_BAR_Z_INDEX,
30634
30713
  padding: verticalControlBar ? '0.25rem' : 'unset'
30635
- }) }, isLegacyCallControlEnabled((_f = props.callControlProps) === null || _f === void 0 ? void 0 : _f.options) ? (React.createElement(CallControls, Object.assign({}, props.callControlProps, { containerWidth: containerWidth, containerHeight: containerHeight, isMobile: props.mobileView,
30714
+ }) }, isLegacyCallControlEnabled((_h = props.callControlProps) === null || _h === void 0 ? void 0 : _h.options) ? (React.createElement(CallControls, Object.assign({}, props.callControlProps, { containerWidth: containerWidth, containerHeight: containerHeight, isMobile: props.mobileView,
30636
30715
  /* @conditional-compile-remove(one-to-n-calling) */
30637
30716
  peopleButtonChecked: isPeoplePaneOpen,
30638
30717
  /* @conditional-compile-remove(one-to-n-calling) */
@@ -30657,7 +30736,7 @@ const CallArrangement = (props) => {
30657
30736
  dtmfDialerPresent: props.dtmfDialerPresent, peopleButtonRef: peopleButtonRef, cameraButtonRef: cameraButtonRef,
30658
30737
  /* @conditional-compile-remove(spotlight) */
30659
30738
  onStopLocalSpotlight: localParticipant.spotlight ? onStopLocalSpotlight : undefined }))))),
30660
- ((_g = props.callControlProps) === null || _g === void 0 ? void 0 : _g.options) !== false && showDrawer && (React.createElement(react.Stack, { styles: drawerContainerStylesValue },
30739
+ ((_j = props.callControlProps) === null || _j === void 0 ? void 0 : _j.options) !== false && showDrawer && (React.createElement(react.Stack, { styles: drawerContainerStylesValue },
30661
30740
  React.createElement(PreparedMoreDrawer, { callControls: props.callControlProps.options, onLightDismiss: closeDrawer, onPeopleButtonClicked: onMoreDrawerPeopleClicked,
30662
30741
  /* @conditional-compile-remove(PSTN-calls) */ /* @conditional-compile-remove(one-to-n-calling) */
30663
30742
  disableButtonsForHoldScreen: isInLocalHold,
@@ -30693,7 +30772,9 @@ const CallArrangement = (props) => {
30693
30772
  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)
30694
30773
  ? undefined
30695
30774
  : togglePeoplePane, disablePeopleButton: typeof props.callControlProps.options !== 'boolean' &&
30696
- isDisabled$4((_h = props.callControlProps.options) === null || _h === void 0 ? void 0 : _h.participantsButton), onChatButtonClicked: (_j = props.mobileChatTabHeader) === null || _j === void 0 ? void 0 : _j.onClick, disableChatButton: (_k = props.mobileChatTabHeader) === null || _k === void 0 ? void 0 : _k.disabled }),
30775
+ isDisabled$4((_k = props.callControlProps.options) === null || _k === void 0 ? void 0 : _k.participantsButton), onChatButtonClicked: (_l = props.mobileChatTabHeader) === null || _l === void 0 ? void 0 : _l.onClick, disableChatButton: (_m = props.mobileChatTabHeader) === null || _m === void 0 ? void 0 : _m.disabled,
30776
+ /* @conditional-compile-remove(spotlight) */
30777
+ onHeaderMenuClick: onHeaderMenuClick }),
30697
30778
  props.mobileView && (React.createElement(ModalLocalAndRemotePIP, { modalLayerHostId: props.modalLayerHostId, hidden: !isSidePaneOpen, styles: pipStyles, strings: modalStrings, minDragPosition: minMaxDragPosition.minDragPosition, maxDragPosition: minMaxDragPosition.maxDragPosition, onDismissSidePane: () => {
30698
30779
  closePeoplePane();
30699
30780
  if (props.onCloseChatPane) {
@@ -34370,6 +34451,8 @@ class AzureCommunicationCallAdapter {
34370
34451
  this.startSpotlight.bind(this);
34371
34452
  /* @conditional-compile-remove(spotlight) */
34372
34453
  this.stopSpotlight.bind(this);
34454
+ /* @conditional-compile-remove(spotlight) */
34455
+ this.stopAllSpotlight.bind(this);
34373
34456
  }
34374
34457
  dispose() {
34375
34458
  this.resetDiagnosticsForwarder();
@@ -34843,6 +34926,12 @@ class AzureCommunicationCallAdapter {
34843
34926
  this.handlers.onStopSpotlight(userIds);
34844
34927
  });
34845
34928
  }
34929
+ /* @conditional-compile-remove(spotlight) */
34930
+ stopAllSpotlight() {
34931
+ return __awaiter$5(this, void 0, void 0, function* () {
34932
+ this.handlers.onStopAllSpotlight();
34933
+ });
34934
+ }
34846
34935
  getState() {
34847
34936
  return this.context.getState();
34848
34937
  }
@@ -35607,6 +35696,12 @@ class CallWithChatBackedCallAdapter {
35607
35696
  return this.callWithChatAdapter.stopSpotlight(userIds);
35608
35697
  });
35609
35698
  }
35699
+ /* @conditional-compile-remove(spotlight) */
35700
+ stopAllSpotlight() {
35701
+ return __awaiter$4(this, void 0, void 0, function* () {
35702
+ return this.callWithChatAdapter.stopAllSpotlight();
35703
+ });
35704
+ }
35610
35705
  }
35611
35706
  function callAdapterStateFromCallWithChatAdapterState(callWithChatAdapterState) {
35612
35707
  return {
@@ -36761,6 +36856,12 @@ class AzureCommunicationCallWithChatAdapter {
36761
36856
  return this.callAdapter.stopSpotlight(userIds);
36762
36857
  });
36763
36858
  }
36859
+ /* @conditional-compile-remove(spotlight) */
36860
+ stopAllSpotlight() {
36861
+ return __awaiter$2(this, void 0, void 0, function* () {
36862
+ return this.callAdapter.stopAllSpotlight();
36863
+ });
36864
+ }
36764
36865
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
36765
36866
  on(event, listener) {
36766
36867
  switch (event) {