@azure/communication-react 1.14.1-alpha-202403261958 → 1.14.1-alpha-202403270012

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 (101) hide show
  1. package/dist/communication-react.d.ts +1 -1
  2. package/dist/dist-cjs/communication-react/{RichTextSendBoxWrapper-BRqOsupu.js → RichTextSendBoxWrapper-Yty3fOoA.js} +6 -6
  3. package/dist/dist-cjs/communication-react/{RichTextSendBoxWrapper-BRqOsupu.js.map → RichTextSendBoxWrapper-Yty3fOoA.js.map} +1 -1
  4. package/dist/dist-cjs/communication-react/{index-Ba2HAv_Y.js → index-BEomNZbT.js} +675 -647
  5. package/dist/dist-cjs/communication-react/index-BEomNZbT.js.map +1 -0
  6. package/dist/dist-cjs/communication-react/index.js +3 -3
  7. package/dist/dist-esm/acs-ui-common/src/telemetryVersion.js +1 -1
  8. package/dist/dist-esm/acs-ui-common/src/telemetryVersion.js.map +1 -1
  9. package/dist/dist-esm/chat-component-bindings/src/handlers/createHandlers.js.map +1 -1
  10. package/dist/dist-esm/chat-component-bindings/src/messageThreadSelector.js +6 -6
  11. package/dist/dist-esm/chat-component-bindings/src/messageThreadSelector.js.map +1 -1
  12. package/dist/dist-esm/communication-react/src/index.js.map +1 -1
  13. package/dist/dist-esm/react-components/src/components/AttachmentCard.d.ts +3 -1
  14. package/dist/dist-esm/react-components/src/components/AttachmentCard.js +75 -59
  15. package/dist/dist-esm/react-components/src/components/AttachmentCard.js.map +1 -1
  16. package/dist/dist-esm/react-components/src/components/AttachmentDownloadCards.d.ts +1 -1
  17. package/dist/dist-esm/react-components/src/components/AttachmentDownloadCards.js +11 -10
  18. package/dist/dist-esm/react-components/src/components/AttachmentDownloadCards.js.map +1 -1
  19. package/dist/dist-esm/react-components/src/components/AttachmentUploadCards.js +2 -12
  20. package/dist/dist-esm/react-components/src/components/AttachmentUploadCards.js.map +1 -1
  21. package/dist/dist-esm/react-components/src/components/ChatMessage/ChatMessageComponentAsEditBox.js +8 -8
  22. package/dist/dist-esm/react-components/src/components/ChatMessage/ChatMessageComponentAsEditBox.js.map +1 -1
  23. package/dist/dist-esm/react-components/src/components/ChatMessage/ChatMessageComponentAsRichTextEditBox.js +5 -5
  24. package/dist/dist-esm/react-components/src/components/ChatMessage/ChatMessageComponentAsRichTextEditBox.js.map +1 -1
  25. package/dist/dist-esm/react-components/src/components/ChatMessage/ChatMessageComponentWrapper.js.map +1 -1
  26. package/dist/dist-esm/react-components/src/components/ChatMessage/MessageComponents/ChatMessageComponentAsMessageBubble.js +6 -6
  27. package/dist/dist-esm/react-components/src/components/ChatMessage/MessageComponents/ChatMessageComponentAsMessageBubble.js.map +1 -1
  28. package/dist/dist-esm/react-components/src/components/ChatMessage/MessageComponents/FluentChatMessageComponent.js +10 -8
  29. package/dist/dist-esm/react-components/src/components/ChatMessage/MessageComponents/FluentChatMessageComponent.js.map +1 -1
  30. package/dist/dist-esm/react-components/src/components/ChatMessage/MyMessageComponents/ChatMyMessageComponentAsMessageBubble.js +6 -6
  31. package/dist/dist-esm/react-components/src/components/ChatMessage/MyMessageComponents/ChatMyMessageComponentAsMessageBubble.js.map +1 -1
  32. package/dist/dist-esm/react-components/src/components/ChatMessage/MyMessageComponents/FluentChatMyMessageComponent.js +10 -8
  33. package/dist/dist-esm/react-components/src/components/ChatMessage/MyMessageComponents/FluentChatMyMessageComponent.js.map +1 -1
  34. package/dist/dist-esm/react-components/src/components/MessageThread.js +3 -3
  35. package/dist/dist-esm/react-components/src/components/MessageThread.js.map +1 -1
  36. package/dist/dist-esm/react-components/src/components/RichTextEditor/RichTextInputBoxComponent.js +7 -6
  37. package/dist/dist-esm/react-components/src/components/RichTextEditor/RichTextInputBoxComponent.js.map +1 -1
  38. package/dist/dist-esm/react-components/src/components/RichTextEditor/RichTextSendBox.js +24 -24
  39. package/dist/dist-esm/react-components/src/components/RichTextEditor/RichTextSendBox.js.map +1 -1
  40. package/dist/dist-esm/react-components/src/components/RichTextEditor/RichTextSendBoxErrors.js +6 -6
  41. package/dist/dist-esm/react-components/src/components/RichTextEditor/RichTextSendBoxErrors.js.map +1 -1
  42. package/dist/dist-esm/react-components/src/components/SendBox.js +33 -23
  43. package/dist/dist-esm/react-components/src/components/SendBox.js.map +1 -1
  44. package/dist/dist-esm/react-components/src/components/index.js.map +1 -1
  45. package/dist/dist-esm/react-components/src/components/styles/AttachmentCard.styles.d.ts +9 -0
  46. package/dist/dist-esm/react-components/src/components/styles/AttachmentCard.styles.js +27 -0
  47. package/dist/dist-esm/react-components/src/components/styles/AttachmentCard.styles.js.map +1 -0
  48. package/dist/dist-esm/react-components/src/components/styles/SendBox.styles.js +3 -2
  49. package/dist/dist-esm/react-components/src/components/styles/SendBox.styles.js.map +1 -1
  50. package/dist/dist-esm/react-components/src/components/utils/ChatMessageComponentAsEditBoxUtils.js +6 -5
  51. package/dist/dist-esm/react-components/src/components/utils/ChatMessageComponentAsEditBoxUtils.js.map +1 -1
  52. package/dist/dist-esm/react-components/src/components/utils/ChatMessageComponentUtils.js +10 -10
  53. package/dist/dist-esm/react-components/src/components/utils/ChatMessageComponentUtils.js.map +1 -1
  54. package/dist/dist-esm/react-components/src/components/utils/SendBoxUtils.js +2 -2
  55. package/dist/dist-esm/react-components/src/components/utils/SendBoxUtils.js.map +1 -1
  56. package/dist/dist-esm/react-components/src/components/utils/common.js +2 -2
  57. package/dist/dist-esm/react-components/src/components/utils/common.js.map +1 -1
  58. package/dist/dist-esm/react-components/src/theming/FluentV9ThemeProvider.js +1 -1
  59. package/dist/dist-esm/react-components/src/theming/FluentV9ThemeProvider.js.map +1 -1
  60. package/dist/dist-esm/react-components/src/theming/icons.js +3 -3
  61. package/dist/dist-esm/react-components/src/theming/icons.js.map +1 -1
  62. package/dist/dist-esm/react-components/src/types/Attachment.d.ts +9 -0
  63. package/dist/dist-esm/react-components/src/types/Attachment.js.map +1 -1
  64. package/dist/dist-esm/react-components/src/types/ChatMessage.js.map +1 -1
  65. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/CallWithChatComposite.js +3 -3
  66. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/CallWithChatComposite.js.map +1 -1
  67. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/AzureCommunicationCallWithChatAdapter.js +15 -15
  68. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/AzureCommunicationCallWithChatAdapter.js.map +1 -1
  69. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/CallWithChatAdapter.js.map +1 -1
  70. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/CallWithChatBackedChatAdapter.js +8 -8
  71. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/CallWithChatBackedChatAdapter.js.map +1 -1
  72. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/state/CallWithChatAdapterState.js +2 -2
  73. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/state/CallWithChatAdapterState.js.map +1 -1
  74. package/dist/dist-esm/react-composites/src/composites/ChatComposite/ChatComposite.js +4 -4
  75. package/dist/dist-esm/react-composites/src/composites/ChatComposite/ChatComposite.js.map +1 -1
  76. package/dist/dist-esm/react-composites/src/composites/ChatComposite/ChatScreen.js +8 -8
  77. package/dist/dist-esm/react-composites/src/composites/ChatComposite/ChatScreen.js.map +1 -1
  78. package/dist/dist-esm/react-composites/src/composites/ChatComposite/Strings.js.map +1 -1
  79. package/dist/dist-esm/react-composites/src/composites/ChatComposite/adapter/AzureCommunicationChatAdapter.js +22 -22
  80. package/dist/dist-esm/react-composites/src/composites/ChatComposite/adapter/AzureCommunicationChatAdapter.js.map +1 -1
  81. package/dist/dist-esm/react-composites/src/composites/ChatComposite/adapter/AzureCommunicationFileUploadAdapter.js +6 -6
  82. package/dist/dist-esm/react-composites/src/composites/ChatComposite/adapter/AzureCommunicationFileUploadAdapter.js.map +1 -1
  83. package/dist/dist-esm/react-composites/src/composites/ChatComposite/adapter/ChatAdapter.js.map +1 -1
  84. package/dist/dist-esm/react-composites/src/composites/ChatComposite/adapter/ChatAdapterProvider.js +1 -1
  85. package/dist/dist-esm/react-composites/src/composites/ChatComposite/adapter/ChatAdapterProvider.js.map +1 -1
  86. package/dist/dist-esm/react-composites/src/composites/ChatComposite/file-sharing/FileUploadButton.js +4 -4
  87. package/dist/dist-esm/react-composites/src/composites/ChatComposite/file-sharing/FileUploadButton.js.map +1 -1
  88. package/dist/dist-esm/react-composites/src/composites/ChatComposite/hooks/useHandlers.js +3 -3
  89. package/dist/dist-esm/react-composites/src/composites/ChatComposite/hooks/useHandlers.js.map +1 -1
  90. package/dist/dist-esm/react-composites/src/composites/ChatComposite/index.js.map +1 -1
  91. package/dist/dist-esm/react-composites/src/composites/ChatComposite/selectors/baseSelectors.js +1 -1
  92. package/dist/dist-esm/react-composites/src/composites/ChatComposite/selectors/baseSelectors.js.map +1 -1
  93. package/dist/dist-esm/react-composites/src/composites/common/SendBox.js +8 -8
  94. package/dist/dist-esm/react-composites/src/composites/common/SendBox.js.map +1 -1
  95. package/dist/dist-esm/react-composites/src/composites/common/icons.js +2 -2
  96. package/dist/dist-esm/react-composites/src/composites/common/icons.js.map +1 -1
  97. package/package.json +1 -1
  98. package/dist/dist-cjs/communication-react/index-Ba2HAv_Y.js.map +0 -1
  99. package/dist/dist-esm/react-components/src/components/styles/IconButton.styles.d.ts +0 -5
  100. package/dist/dist-esm/react-components/src/components/styles/IconButton.styles.js +0 -17
  101. package/dist/dist-esm/react-components/src/components/styles/IconButton.styles.js.map +0 -1
@@ -14,12 +14,12 @@ var textareaCaretTs = require('textarea-caret-ts');
14
14
  var reactComponents = require('@fluentui/react-components');
15
15
  var useDebounce = require('use-debounce');
16
16
  var reactFileTypeIcons = require('@fluentui/react-file-type-icons');
17
+ var react$1 = require('@griffel/react');
17
18
  var roosterjsEditorPlugins = require('roosterjs-editor-plugins');
18
19
  var roosterjsEditorCore = require('roosterjs-editor-core');
19
20
  var roosterjsReact = require('roosterjs-react');
20
21
  var reactChat = require('@fluentui-contrib/react-chat');
21
22
  var uuid = require('uuid');
22
- var react$1 = require('@griffel/react');
23
23
  var parse = require('html-react-parser');
24
24
  var Linkify = require('react-linkify');
25
25
  var DOMPurify = require('dompurify');
@@ -173,7 +173,7 @@ function getDefaultExportFromCjs (x) {
173
173
  // Copyright (c) Microsoft Corporation.
174
174
  // Licensed under the MIT License.
175
175
  // GENERATED FILE. DO NOT EDIT MANUALLY.
176
- var telemetryVersion = '1.14.1-alpha-202403261958';
176
+ var telemetryVersion = '1.14.1-alpha-202403270012';
177
177
 
178
178
 
179
179
  var telemetryVersion$1 = /*@__PURE__*/getDefaultExportFromCjs(telemetryVersion);
@@ -6354,8 +6354,9 @@ const sendButtonStyle = react.mergeStyles({
6354
6354
  */
6355
6355
  const sendIconStyle = (props) => {
6356
6356
  const { theme, hasText, disabled = false,
6357
- /* @conditional-compile-remove(file-sharing) */ hasFile, hasErrorMessage, customSendIconStyle, defaultTextColor = theme.palette.neutralTertiary } = props;
6358
- const hasNoContent = !hasText && /* @conditional-compile-remove(file-sharing) */ !hasFile;
6357
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */ hasFile, hasErrorMessage, customSendIconStyle, defaultTextColor = theme.palette.neutralTertiary } = props;
6358
+ const hasNoContent = !hasText &&
6359
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */ !hasFile;
6359
6360
  return react.mergeStyles(editorTextBoxButtonStyle, {
6360
6361
  color: disabled || hasErrorMessage || hasNoContent ? defaultTextColor : theme.palette.themePrimary
6361
6362
  }, customSendIconStyle);
@@ -6699,9 +6700,9 @@ const DEFAULT_COMPONENT_ICONS = {
6699
6700
  LowerHandContextualMenuItem: React.createElement(reactIcons.HandRightOff20Regular, null),
6700
6701
  /* @conditional-compile-remove(reaction) */
6701
6702
  ReactionButtonIcon: React.createElement(reactIcons.Emoji20Regular, null),
6702
- /* @conditional-compile-remove(file-sharing) */
6703
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
6703
6704
  CancelFileUpload: React.createElement(reactIcons.Dismiss16Regular, null),
6704
- /* @conditional-compile-remove(file-sharing) */
6705
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
6705
6706
  DownloadFile: React.createElement(reactIcons.ArrowDownload16Regular, null),
6706
6707
  /* @conditional-compile-remove(data-loss-prevention) */
6707
6708
  DataLossPreventionProhibited: React.createElement(DataLossPreventionProhibited16Regular, null),
@@ -8749,26 +8750,83 @@ const SendBoxErrors = (props) => {
8749
8750
 
8750
8751
  // Copyright (c) Microsoft Corporation.
8751
8752
  // Licensed under the MIT License.
8752
- /* @conditional-compile-remove(file-sharing) */
8753
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
8753
8754
  /**
8754
8755
  * Conditionally modify locale strings passed to the attachment card
8755
8756
  * @returns file upload card strings
8756
8757
  */
8757
8758
  const useLocaleAttachmentCardStringsTrampoline = () => {
8758
- /* @conditional-compile-remove(file-sharing) */
8759
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
8759
8760
  return useLocale$1().strings.sendBox;
8760
8761
  };
8761
8762
 
8763
+ // Copyright (c) Microsoft Corporation.
8764
+ // Licensed under the MIT License.
8765
+ /**
8766
+ * @private
8767
+ */
8768
+ const useAttachmentCardStyles = reactComponents.makeStyles({
8769
+ root: {
8770
+ width: '12rem',
8771
+ minWidth: '75%'
8772
+ }
8773
+ });
8774
+ /**
8775
+ * @private
8776
+ */
8777
+ const fileNameContainerClassName = react.mergeStyles({
8778
+ marginTop: _pxToRem(5),
8779
+ width: '5.75rem',
8780
+ overflow: 'hidden',
8781
+ textOverflow: 'ellipsis',
8782
+ span: {
8783
+ whiteSpace: 'nowrap'
8784
+ }
8785
+ });
8786
+
8762
8787
  // Copyright (c) Microsoft Corporation.
8763
8788
  // Licensed under the MIT License.
8764
8789
  /**
8765
8790
  * @internal
8766
- * A component for displaying a attachment card with attachment icon and progress bar.
8791
+ * A component for displaying an attachment card with attachment icon and progress bar.
8792
+ *
8793
+ * `_AttachmentCard` internally uses the `Card` component from `@fluentui/react-components`. You can checkout the details about these components [here](https://react.fluentui.dev/?path=/docs/components-card).
8767
8794
  */
8768
8795
  const _AttachmentCard = (props) => {
8769
8796
  var _a, _b, _c, _d;
8770
- const { attachmentName, attachmentExtension, progress, actionIcon } = props;
8771
- const theme = react.useTheme();
8797
+ const { attachmentName, attachmentExtension, progress, actionIcon, actionHandler } = props;
8798
+ const attachmentCardStyles = useAttachmentCardStyles();
8799
+ // default/placeholder before actual code implemented
8800
+ const menuActions = React.useMemo(() => {
8801
+ return [
8802
+ {
8803
+ name: actionIcon && (actionIcon === null || actionIcon === void 0 ? void 0 : actionIcon.props.ariaLabel),
8804
+ icon: actionIcon !== null && actionIcon !== void 0 ? actionIcon : React.createElement(React.Fragment, null),
8805
+ onClick: (attachment) => {
8806
+ if (attachment) {
8807
+ actionHandler === null || actionHandler === void 0 ? void 0 : actionHandler();
8808
+ }
8809
+ }
8810
+ }
8811
+ ];
8812
+ }, [actionIcon, actionHandler]);
8813
+ // placeholder before refactoring the props
8814
+ const attachment = React.useMemo(() => {
8815
+ return {
8816
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
8817
+ id: 'attachmentId',
8818
+ extension: attachmentExtension,
8819
+ name: attachmentName,
8820
+ url: 'https://localhost' // placeholder not used
8821
+ };
8822
+ }, [attachmentExtension, attachmentName]);
8823
+ // placeholder before refactoring the props
8824
+ const onDownloadErrorMessage = React.useCallback((errorMessage) => {
8825
+ console.log(errorMessage);
8826
+ }, []);
8827
+ const isUploadComplete = React.useMemo(() => {
8828
+ return progress !== undefined && progress > 0 && progress < 1;
8829
+ }, [progress]);
8772
8830
  const [announcerString, setAnnouncerString] = React.useState(undefined);
8773
8831
  const localeStrings = useLocaleAttachmentCardStringsTrampoline();
8774
8832
  const uploadStartedString = (_b = (_a = props.strings) === null || _a === void 0 ? void 0 : _a.uploading) !== null && _b !== void 0 ? _b : localeStrings.uploading;
@@ -8785,61 +8843,42 @@ const _AttachmentCard = (props) => {
8785
8843
  setAnnouncerString(undefined);
8786
8844
  }
8787
8845
  }, [progress, showProgressIndicator, attachmentName, uploadStartedString, uploadCompletedString]);
8788
- const progressBarThicknessPx = 4;
8789
- const containerClassName = react.mergeStyles({
8790
- width: '12rem',
8791
- background: theme.palette.neutralLighter,
8792
- borderRadius: theme.effects.roundedCorner4,
8793
- border: `${_pxToRem(1)} solid ${theme.palette.neutralQuaternary}`,
8794
- cursor: 'pointer'
8795
- });
8796
- const attachmentInfoWrapperClassName = react.mergeStyles({
8797
- padding: _pxToRem(12),
8798
- // To make space for the progress indicator.
8799
- paddingBottom: showProgressIndicator ? _pxToRem(12 - progressBarThicknessPx * 2) : _pxToRem(12)
8800
- });
8801
- const attachmentNameContainerClassName = react.mergeStyles({
8802
- paddingLeft: _pxToRem(4),
8803
- minWidth: '75%',
8804
- maxWidth: '75%'
8805
- });
8806
- const attachmentNameTextClassName = react.mergeStyles({
8807
- overflow: 'hidden',
8808
- textOverflow: 'ellipsis',
8809
- lineHeight: 'normal',
8810
- whiteSpace: 'nowrap',
8811
- paddingRight: _pxToRem(4)
8812
- });
8813
- const actionIconClassName = react.mergeStyles({
8814
- cursor: 'pointer'
8815
- });
8816
- const progressIndicatorStyles = {
8817
- itemProgress: {
8818
- padding: `${_pxToRem(progressBarThicknessPx - 1)} 0`, // item progress height won't apply without an explicit padding
8819
- // To make the progress indicator border curve along the bottom of attachment card.
8820
- borderRadius: `0 0 ${theme.effects.roundedCorner4} ${theme.effects.roundedCorner4}`
8821
- },
8822
- progressBar: {
8823
- height: _pxToRem(progressBarThicknessPx)
8824
- }
8825
- };
8826
8846
  return (React.createElement("div", { "data-is-focusable": true },
8827
8847
  React.createElement(Announcer$1, { announcementString: announcerString, ariaLive: 'polite' }),
8828
- React.createElement(react.Stack, { className: containerClassName, onClick: () => {
8829
- var _a;
8830
- (_a = props.actionHandler) === null || _a === void 0 ? void 0 : _a.call(props);
8831
- } },
8832
- React.createElement(react.Stack, { horizontal: true, horizontalAlign: "space-between", verticalAlign: "center", className: attachmentInfoWrapperClassName },
8833
- React.createElement(react.Stack, null,
8834
- React.createElement(react.Icon, { "data-ui-id": 'filetype-icon', iconName: reactFileTypeIcons.getFileTypeIconProps({
8835
- extension: attachmentExtension,
8836
- size: 24,
8837
- imageFileType: 'svg'
8838
- }).iconName })),
8839
- React.createElement(react.Stack, { className: attachmentNameContainerClassName },
8840
- React.createElement(react.Text, { className: attachmentNameTextClassName }, attachmentName)),
8841
- React.createElement(react.Stack, { verticalAlign: "center", className: actionIconClassName }, actionIcon && actionIcon)),
8842
- showProgressIndicator && React.createElement(react.ProgressIndicator, { percentComplete: progress, styles: progressIndicatorStyles }))));
8848
+ React.createElement(reactComponents.Card, { className: attachmentCardStyles.root, size: "small", role: "listitem" },
8849
+ React.createElement(reactComponents.CardHeader, { image: React.createElement(react.Icon, { "data-ui-id": 'filetype-icon', iconName: reactFileTypeIcons.getFileTypeIconProps({
8850
+ extension: attachmentExtension,
8851
+ size: 24,
8852
+ imageFileType: 'svg'
8853
+ }).iconName }), header: React.createElement("div", { className: fileNameContainerClassName },
8854
+ React.createElement(reactComponents.Text, { title: attachmentName }, attachmentName)), action: getMenuItems(menuActions, attachment, onDownloadErrorMessage) })),
8855
+ isUploadComplete ? (React.createElement(reactComponents.CardFooter, null,
8856
+ React.createElement(reactComponents.ProgressBar, { thickness: "medium", value: progress, shape: "rounded" }))) : (React.createElement(React.Fragment, null, " "))));
8857
+ };
8858
+ const getMenuItems = (menuActions, attachment, handleOnClickError) => {
8859
+ if (menuActions.length === 0) {
8860
+ return React.createElement(React.Fragment, null);
8861
+ }
8862
+ return menuActions.length === 1 ? (React.createElement(reactComponents.ToolbarButton, { "aria-label": menuActions[0].name, icon: menuActions[0].icon, onClick: () => {
8863
+ try {
8864
+ menuActions[0].onClick(attachment);
8865
+ }
8866
+ catch (e) {
8867
+ handleOnClickError === null || handleOnClickError === void 0 ? void 0 : handleOnClickError(e.message);
8868
+ }
8869
+ } })) : (React.createElement(reactComponents.Toolbar, null,
8870
+ React.createElement(reactComponents.Menu, null,
8871
+ React.createElement(reactComponents.MenuTrigger, null,
8872
+ React.createElement(reactComponents.ToolbarButton, { "aria-label": "More", icon: React.createElement(reactIcons.MoreHorizontal24Filled, null) })),
8873
+ React.createElement(reactComponents.MenuPopover, null,
8874
+ React.createElement(reactComponents.MenuList, null, menuActions.map((menuItem, index) => (React.createElement(reactComponents.MenuItem, { key: index, icon: menuItem.icon, onClick: () => {
8875
+ try {
8876
+ menuItem.onClick(attachment);
8877
+ }
8878
+ catch (e) {
8879
+ handleOnClickError === null || handleOnClickError === void 0 ? void 0 : handleOnClickError(e.message);
8880
+ }
8881
+ } }, menuItem.name))))))));
8843
8882
  };
8844
8883
 
8845
8884
  // Copyright (c) Microsoft Corporation.
@@ -8876,42 +8915,19 @@ const _AttachmentCardGroup = (props) => {
8876
8915
 
8877
8916
  // Copyright (c) Microsoft Corporation.
8878
8917
  // Licensed under the MIT License.
8879
- /**
8880
- * @private
8881
- */
8882
- const iconButtonClassName = react.mergeStyles({
8883
- color: 'unset',
8884
- width: '1rem',
8885
- height: '1rem',
8886
- background: 'transparent',
8887
- ':hover': {
8888
- color: 'unset',
8889
- background: 'transparent'
8890
- }
8891
- });
8892
-
8893
- // Copyright (c) Microsoft Corporation.
8894
- // Licensed under the MIT License.
8895
- const actionIconStyle$1 = { height: '1rem' };
8918
+ const actionIconStyle = { height: '1rem' };
8896
8919
  /**
8897
8920
  * @internal
8898
8921
  */
8899
8922
  const _AttachmentUploadCards = (props) => {
8900
- var _a;
8901
8923
  const attachments = props.activeFileUploads;
8902
- const localeStrings = useLocaleAttachmentCardStringsTrampoline();
8903
- const removeAttachmentButtonString = React.useMemo(() => () => {
8904
- var _a, _b;
8905
- return (_b = (_a = props.strings) === null || _a === void 0 ? void 0 : _a.removeAttachment) !== null && _b !== void 0 ? _b : localeStrings.removeAttachment;
8906
- }, [(_a = props.strings) === null || _a === void 0 ? void 0 : _a.removeAttachment, localeStrings.removeAttachment]);
8907
8924
  if (!attachments || attachments.length === 0) {
8908
8925
  return React.createElement(React.Fragment, null);
8909
8926
  }
8910
8927
  return (React.createElement(_AttachmentCardGroup, null, attachments &&
8911
8928
  attachments
8912
8929
  .filter((attachment) => !attachment.error)
8913
- .map((attachment) => (React.createElement(_AttachmentCard, { attachmentName: attachment.filename, progress: attachment.progress, key: attachment.id, attachmentExtension: extension(attachment.filename), actionIcon: React.createElement(react.IconButton, { className: iconButtonClassName, ariaLabel: removeAttachmentButtonString() },
8914
- React.createElement(react.Icon, { iconName: "CancelFileUpload", style: actionIconStyle$1 })), actionHandler: () => {
8930
+ .map((attachment) => (React.createElement(_AttachmentCard, { attachmentName: attachment.filename, progress: attachment.progress, key: attachment.id, attachmentExtension: extension(attachment.filename), actionIcon: React.createElement(react.Icon, { iconName: "CancelFileUpload", className: react.mergeStyles(actionIconStyle) }), actionHandler: () => {
8915
8931
  props.onCancelFileUpload && props.onCancelFileUpload(attachment.id);
8916
8932
  }, strings: props.strings })))));
8917
8933
  };
@@ -8923,7 +8939,7 @@ const _AttachmentUploadCards = (props) => {
8923
8939
  */
8924
8940
  const MAXIMUM_LENGTH_OF_MESSAGE = 8000;
8925
8941
  const EMPTY_MESSAGE_REGEX = /^\s*$/;
8926
- /* @conditional-compile-remove(file-sharing) */
8942
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
8927
8943
  /**
8928
8944
  * @private
8929
8945
  */
@@ -8933,7 +8949,7 @@ const hasIncompleteFileUploads = (activeFileUploads) => {
8933
8949
  .filter((attachmentUpload) => !attachmentUpload.error)
8934
8950
  .every((attachmentUpload) => attachmentUpload.uploadComplete));
8935
8951
  };
8936
- /* @conditional-compile-remove(file-sharing) */
8952
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
8937
8953
  /**
8938
8954
  * @private
8939
8955
  */
@@ -8958,6 +8974,363 @@ const sanitizeText = (message) => {
8958
8974
  }
8959
8975
  };
8960
8976
 
8977
+ // Copyright (c) Microsoft Corporation.
8978
+ // Licensed under the MIT License.
8979
+ // These color records are required for createV9Theme
8980
+ // For more info, check https://react.fluentui.dev/iframe.html?viewMode=docs&id=concepts-migration-from-v8-components-theme-migration--page#compatible-themes
8981
+ /**
8982
+ * @private
8983
+ */
8984
+ const grey = {
8985
+ '0': '#000000',
8986
+ '2': '#050505',
8987
+ '4': '#0a0a0a',
8988
+ '6': '#0f0f0f',
8989
+ '8': '#141414',
8990
+ '10': '#1a1a1a',
8991
+ '12': '#1f1f1f',
8992
+ '14': '#242424',
8993
+ '16': '#292929',
8994
+ '18': '#2e2e2e',
8995
+ '20': '#333333',
8996
+ '22': '#383838',
8997
+ '24': '#3d3d3d',
8998
+ '26': '#424242',
8999
+ '28': '#474747',
9000
+ '30': '#4d4d4d',
9001
+ '32': '#525252',
9002
+ '34': '#575757',
9003
+ '36': '#5c5c5c',
9004
+ '38': '#616161',
9005
+ '40': '#666666',
9006
+ '42': '#6b6b6b',
9007
+ '44': '#707070',
9008
+ '46': '#757575',
9009
+ '48': '#7a7a7a',
9010
+ '50': '#808080',
9011
+ '52': '#858585',
9012
+ '54': '#8a8a8a',
9013
+ '56': '#8f8f8f',
9014
+ '58': '#949494',
9015
+ '60': '#999999',
9016
+ '62': '#9e9e9e',
9017
+ '64': '#a3a3a3',
9018
+ '66': '#a8a8a8',
9019
+ '68': '#adadad',
9020
+ '70': '#b3b3b3',
9021
+ '72': '#b8b8b8',
9022
+ '74': '#bdbdbd',
9023
+ '76': '#c2c2c2',
9024
+ '78': '#c7c7c7',
9025
+ '80': '#cccccc',
9026
+ '82': '#d1d1d1',
9027
+ '84': '#d6d6d6',
9028
+ '86': '#dbdbdb',
9029
+ '88': '#e0e0e0',
9030
+ '90': '#e6e6e6',
9031
+ '92': '#ebebeb',
9032
+ '94': '#f0f0f0',
9033
+ '96': '#f5f5f5',
9034
+ '98': '#fafafa',
9035
+ '100': '#ffffff'
9036
+ };
9037
+ /**
9038
+ * @private
9039
+ */
9040
+ const whiteAlpha = {
9041
+ '5': 'rgba(255, 255, 255, 0.05)',
9042
+ '10': 'rgba(255, 255, 255, 0.1)',
9043
+ '20': 'rgba(255, 255, 255, 0.2)',
9044
+ '30': 'rgba(255, 255, 255, 0.3)',
9045
+ '40': 'rgba(255, 255, 255, 0.4)',
9046
+ '50': 'rgba(255, 255, 255, 0.5)',
9047
+ '60': 'rgba(255, 255, 255, 0.6)',
9048
+ '70': 'rgba(255, 255, 255, 0.7)',
9049
+ '80': 'rgba(255, 255, 255, 0.8)',
9050
+ '90': 'rgba(255, 255, 255, 0.9)'
9051
+ };
9052
+ /**
9053
+ * @private
9054
+ */
9055
+ const blackAlpha = {
9056
+ '5': 'rgba(0, 0, 0, 0.05)',
9057
+ '10': 'rgba(0, 0, 0, 0.1)',
9058
+ '20': 'rgba(0, 0, 0, 0.2)',
9059
+ '30': 'rgba(0, 0, 0, 0.3)',
9060
+ '40': 'rgba(0, 0, 0, 0.4)',
9061
+ '50': 'rgba(0, 0, 0, 0.5)',
9062
+ '60': 'rgba(0, 0, 0, 0.6)',
9063
+ '70': 'rgba(0, 0, 0, 0.7)',
9064
+ '80': 'rgba(0, 0, 0, 0.8)',
9065
+ '90': 'rgba(0, 0, 0, 0.9)'
9066
+ };
9067
+ /**
9068
+ * @private
9069
+ */
9070
+ const grey10Alpha = {
9071
+ '5': 'rgba(26, 26, 26, 0.05)',
9072
+ '10': 'rgba(26, 26, 26, 0.1)',
9073
+ '20': 'rgba(26, 26, 26, 0.2)',
9074
+ '30': 'rgba(26, 26, 26, 0.3)',
9075
+ '40': 'rgba(26, 26, 26, 0.4)',
9076
+ '50': 'rgba(26, 26, 26, 0.5)',
9077
+ '60': 'rgba(26, 26, 26, 0.6)',
9078
+ '70': 'rgba(26, 26, 26, 0.7)',
9079
+ '80': 'rgba(26, 26, 26, 0.8)',
9080
+ '90': 'rgba(26, 26, 26, 0.9)'
9081
+ };
9082
+ /**
9083
+ * @private
9084
+ */
9085
+ const grey12Alpha = {
9086
+ '5': 'rgba(31, 31, 31, 0.05)',
9087
+ '10': 'rgba(31, 31, 31, 0.1)',
9088
+ '20': 'rgba(31, 31, 31, 0.2)',
9089
+ '30': 'rgba(31, 31, 31, 0.3)',
9090
+ '40': 'rgba(31, 31, 31, 0.4)',
9091
+ '50': 'rgba(31, 31, 31, 0.5)',
9092
+ '60': 'rgba(31, 31, 31, 0.6)',
9093
+ '70': 'rgba(31, 31, 31, 0.7)',
9094
+ '80': 'rgba(31, 31, 31, 0.8)',
9095
+ '90': 'rgba(31, 31, 31, 0.9)'
9096
+ };
9097
+
9098
+ // Copyright (c) Microsoft Corporation.
9099
+ // Licensed under the MIT License.
9100
+ // These mappings are required for createV9Theme
9101
+ // For more info, check https://react.fluentui.dev/iframe.html?viewMode=docs&id=concepts-migration-from-v8-components-theme-migration--page#compatible-themes
9102
+ /**
9103
+ * Creates v9 color tokens from a v8 palette.
9104
+ */
9105
+ const mapAliasColors = (palette, inverted) => {
9106
+ return {
9107
+ colorNeutralForeground1: palette.neutralPrimary,
9108
+ colorNeutralForeground1Hover: palette.neutralPrimary,
9109
+ colorNeutralForeground1Pressed: palette.neutralPrimary,
9110
+ colorNeutralForeground1Selected: palette.neutralPrimary,
9111
+ colorNeutralForeground2: palette.neutralSecondary,
9112
+ colorNeutralForeground2Hover: palette.neutralPrimary,
9113
+ colorNeutralForeground2Pressed: palette.neutralPrimary,
9114
+ colorNeutralForeground2Selected: palette.neutralPrimary,
9115
+ colorNeutralForeground2BrandHover: palette.themePrimary,
9116
+ colorNeutralForeground2BrandPressed: palette.themeDarkAlt,
9117
+ colorNeutralForeground2BrandSelected: palette.themePrimary,
9118
+ colorNeutralForeground3: palette.neutralTertiary,
9119
+ colorNeutralForeground3Hover: palette.neutralSecondary,
9120
+ colorNeutralForeground3Pressed: palette.neutralSecondary,
9121
+ colorNeutralForeground3Selected: palette.neutralSecondary,
9122
+ colorNeutralForeground3BrandHover: palette.themePrimary,
9123
+ colorNeutralForeground3BrandPressed: palette.themeDarkAlt,
9124
+ colorNeutralForeground3BrandSelected: palette.themePrimary,
9125
+ colorNeutralForeground4: palette.neutralQuaternary,
9126
+ colorNeutralForegroundDisabled: palette.neutralTertiaryAlt,
9127
+ colorNeutralForegroundInvertedDisabled: whiteAlpha[40],
9128
+ colorBrandForegroundLink: palette.themeDarkAlt,
9129
+ colorBrandForegroundLinkHover: palette.themeDark,
9130
+ colorBrandForegroundLinkPressed: palette.themeDarker,
9131
+ colorBrandForegroundLinkSelected: palette.themeDarkAlt,
9132
+ colorNeutralForeground2Link: palette.neutralSecondary,
9133
+ colorNeutralForeground2LinkHover: palette.neutralPrimary,
9134
+ colorNeutralForeground2LinkPressed: palette.neutralPrimary,
9135
+ colorNeutralForeground2LinkSelected: palette.neutralPrimary,
9136
+ colorCompoundBrandForeground1: palette.themePrimary,
9137
+ colorCompoundBrandForeground1Hover: palette.themeDarkAlt,
9138
+ colorCompoundBrandForeground1Pressed: palette.themeDark,
9139
+ colorBrandForeground1: palette.themePrimary,
9140
+ colorBrandForeground2: palette.themeDarkAlt,
9141
+ colorBrandForeground2Hover: palette.themeDarkAlt,
9142
+ colorBrandForeground2Pressed: palette.themeDarkAlt,
9143
+ colorNeutralForeground1Static: palette.neutralPrimary,
9144
+ colorNeutralForegroundInverted: palette.white,
9145
+ colorNeutralForegroundInvertedHover: palette.white,
9146
+ colorNeutralForegroundInvertedPressed: palette.white,
9147
+ colorNeutralForegroundInvertedSelected: palette.white,
9148
+ colorNeutralForegroundOnBrand: palette.white,
9149
+ colorNeutralForegroundStaticInverted: palette.white,
9150
+ colorNeutralForegroundInvertedLink: palette.white,
9151
+ colorNeutralForegroundInvertedLinkHover: palette.white,
9152
+ colorNeutralForegroundInvertedLinkPressed: palette.white,
9153
+ colorNeutralForegroundInvertedLinkSelected: palette.white,
9154
+ colorNeutralForegroundInverted2: palette.white,
9155
+ colorBrandForegroundInverted: palette.themeSecondary,
9156
+ colorBrandForegroundInvertedHover: palette.themeTertiary,
9157
+ colorBrandForegroundInvertedPressed: palette.themeSecondary,
9158
+ colorBrandForegroundOnLight: palette.themePrimary,
9159
+ colorBrandForegroundOnLightHover: palette.themeDarkAlt,
9160
+ colorBrandForegroundOnLightPressed: palette.themeDark,
9161
+ colorBrandForegroundOnLightSelected: palette.themeDark,
9162
+ colorNeutralBackground1: palette.white,
9163
+ colorNeutralBackground1Hover: palette.neutralLighter,
9164
+ colorNeutralBackground1Pressed: palette.neutralQuaternaryAlt,
9165
+ colorNeutralBackground1Selected: palette.neutralLight,
9166
+ colorNeutralBackground2: palette.neutralLighterAlt,
9167
+ colorNeutralBackground2Hover: palette.neutralLighter,
9168
+ colorNeutralBackground2Pressed: palette.neutralQuaternaryAlt,
9169
+ colorNeutralBackground2Selected: palette.neutralLight,
9170
+ colorNeutralBackground3: palette.neutralLighter,
9171
+ colorNeutralBackground3Hover: palette.neutralLight,
9172
+ colorNeutralBackground3Pressed: palette.neutralQuaternary,
9173
+ colorNeutralBackground3Selected: palette.neutralQuaternaryAlt,
9174
+ colorNeutralBackground4: palette.neutralLighter,
9175
+ colorNeutralBackground4Hover: palette.neutralLighterAlt,
9176
+ colorNeutralBackground4Pressed: palette.neutralLighter,
9177
+ colorNeutralBackground4Selected: palette.white,
9178
+ colorNeutralBackground5: palette.neutralLight,
9179
+ colorNeutralBackground5Hover: palette.neutralLighter,
9180
+ colorNeutralBackground5Pressed: palette.neutralLighter,
9181
+ colorNeutralBackground5Selected: palette.neutralLighterAlt,
9182
+ colorNeutralBackground6: palette.neutralLight,
9183
+ colorNeutralBackgroundStatic: grey[20],
9184
+ colorNeutralBackgroundInverted: palette.neutralSecondary,
9185
+ colorNeutralBackgroundAlpha: inverted ? grey10Alpha[50] : whiteAlpha[50],
9186
+ colorNeutralBackgroundAlpha2: inverted ? grey12Alpha[70] : whiteAlpha[80],
9187
+ colorSubtleBackground: 'transparent',
9188
+ colorSubtleBackgroundHover: palette.neutralLighter,
9189
+ colorSubtleBackgroundPressed: palette.neutralQuaternaryAlt,
9190
+ colorSubtleBackgroundSelected: palette.neutralLight,
9191
+ colorSubtleBackgroundLightAlphaHover: inverted ? whiteAlpha[10] : whiteAlpha[80],
9192
+ colorSubtleBackgroundLightAlphaPressed: inverted ? whiteAlpha[5] : whiteAlpha[50],
9193
+ colorSubtleBackgroundLightAlphaSelected: 'transparent',
9194
+ colorSubtleBackgroundInverted: 'transparent',
9195
+ colorSubtleBackgroundInvertedHover: blackAlpha[10],
9196
+ colorSubtleBackgroundInvertedPressed: blackAlpha[30],
9197
+ colorSubtleBackgroundInvertedSelected: blackAlpha[20],
9198
+ colorTransparentBackground: 'transparent',
9199
+ colorTransparentBackgroundHover: 'transparent',
9200
+ colorTransparentBackgroundPressed: 'transparent',
9201
+ colorTransparentBackgroundSelected: 'transparent',
9202
+ colorNeutralBackgroundDisabled: palette.neutralLighter,
9203
+ colorNeutralBackgroundInvertedDisabled: whiteAlpha[10],
9204
+ colorNeutralStencil1: palette.neutralLight,
9205
+ colorNeutralStencil2: palette.neutralLighterAlt,
9206
+ colorNeutralStencil1Alpha: inverted ? whiteAlpha[10] : blackAlpha[10],
9207
+ colorNeutralStencil2Alpha: inverted ? whiteAlpha[5] : blackAlpha[5],
9208
+ colorBackgroundOverlay: blackAlpha[40],
9209
+ colorScrollbarOverlay: blackAlpha[50],
9210
+ colorBrandBackground: palette.themePrimary,
9211
+ colorBrandBackgroundHover: palette.themeDarkAlt,
9212
+ colorBrandBackgroundPressed: palette.themeDarker,
9213
+ colorBrandBackgroundSelected: palette.themeDark,
9214
+ colorCompoundBrandBackground: palette.themePrimary,
9215
+ colorCompoundBrandBackgroundHover: palette.themeDarkAlt,
9216
+ colorCompoundBrandBackgroundPressed: palette.themeDark,
9217
+ colorBrandBackgroundStatic: palette.themePrimary,
9218
+ colorBrandBackground2: palette.themeLighterAlt,
9219
+ colorBrandBackground2Hover: palette.themeLighterAlt,
9220
+ colorBrandBackground2Pressed: palette.themeLighterAlt,
9221
+ colorBrandBackground3Static: palette.themeDark,
9222
+ colorBrandBackground4Static: palette.themeDarker,
9223
+ colorBrandBackgroundInverted: palette.white,
9224
+ colorBrandBackgroundInvertedHover: palette.themeLighterAlt,
9225
+ colorBrandBackgroundInvertedPressed: palette.themeLight,
9226
+ colorBrandBackgroundInvertedSelected: palette.themeLighter,
9227
+ colorNeutralCardBackground: inverted ? grey[20] : grey[98],
9228
+ colorNeutralCardBackgroundHover: inverted ? grey[24] : palette.white,
9229
+ colorNeutralCardBackgroundPressed: inverted ? grey[18] : grey[96],
9230
+ colorNeutralCardBackgroundSelected: inverted ? grey[22] : grey[92],
9231
+ colorNeutralCardBackgroundDisabled: inverted ? grey[8] : grey[94],
9232
+ colorNeutralStrokeAccessible: palette.neutralSecondary,
9233
+ colorNeutralStrokeAccessibleHover: palette.neutralSecondary,
9234
+ colorNeutralStrokeAccessiblePressed: palette.neutralSecondary,
9235
+ colorNeutralStrokeAccessibleSelected: palette.themePrimary,
9236
+ colorNeutralStroke1: palette.neutralQuaternary,
9237
+ colorNeutralStroke1Hover: palette.neutralTertiaryAlt,
9238
+ colorNeutralStroke1Pressed: palette.neutralTertiaryAlt,
9239
+ colorNeutralStroke1Selected: palette.neutralTertiaryAlt,
9240
+ colorNeutralStroke2: palette.neutralQuaternaryAlt,
9241
+ colorNeutralStroke3: palette.neutralLighter,
9242
+ colorNeutralStrokeSubtle: palette.neutralQuaternaryAlt,
9243
+ colorNeutralStrokeOnBrand: palette.white,
9244
+ colorNeutralStrokeOnBrand2: palette.white,
9245
+ colorNeutralStrokeOnBrand2Hover: palette.white,
9246
+ colorNeutralStrokeOnBrand2Pressed: palette.white,
9247
+ colorNeutralStrokeOnBrand2Selected: palette.white,
9248
+ colorBrandStroke1: palette.themePrimary,
9249
+ colorBrandStroke2: palette.themeLight,
9250
+ colorBrandStroke2Hover: palette.themeLight,
9251
+ colorBrandStroke2Pressed: palette.themeLight,
9252
+ colorBrandStroke2Contrast: palette.themeLight,
9253
+ colorCompoundBrandStroke: palette.themePrimary,
9254
+ colorCompoundBrandStrokeHover: palette.themeDarkAlt,
9255
+ colorCompoundBrandStrokePressed: palette.themeDark,
9256
+ colorNeutralStrokeDisabled: palette.neutralQuaternaryAlt,
9257
+ colorNeutralStrokeInvertedDisabled: whiteAlpha[40],
9258
+ colorTransparentStroke: 'transparent',
9259
+ colorTransparentStrokeInteractive: 'transparent',
9260
+ colorTransparentStrokeDisabled: 'transparent',
9261
+ colorNeutralStrokeAlpha: inverted ? whiteAlpha[10] : blackAlpha[5],
9262
+ colorNeutralStrokeAlpha2: whiteAlpha[20],
9263
+ colorStrokeFocus1: palette.white,
9264
+ colorStrokeFocus2: palette.black,
9265
+ colorNeutralShadowAmbient: 'rgba(0,0,0,0.12)',
9266
+ colorNeutralShadowKey: 'rgba(0,0,0,0.14)',
9267
+ colorNeutralShadowAmbientLighter: 'rgba(0,0,0,0.06)',
9268
+ colorNeutralShadowKeyLighter: 'rgba(0,0,0,0.07)',
9269
+ colorNeutralShadowAmbientDarker: 'rgba(0,0,0,0.20)',
9270
+ colorNeutralShadowKeyDarker: 'rgba(0,0,0,0.24)',
9271
+ colorBrandShadowAmbient: 'rgba(0,0,0,0.30)',
9272
+ colorBrandShadowKey: 'rgba(0,0,0,0.25)'
9273
+ };
9274
+ };
9275
+ /**
9276
+ * Creates v9 shadow tokens from v8 effects.
9277
+ */
9278
+ const mapShadowTokens = (effects) => {
9279
+ return {
9280
+ shadow4: effects.elevation4,
9281
+ shadow8: effects.elevation8,
9282
+ shadow16: effects.elevation16,
9283
+ shadow64: effects.elevation64
9284
+ };
9285
+ };
9286
+ /**
9287
+ * Creates v9 border radius tokens from v8 effects
9288
+ */
9289
+ const mapBorderRadiusTokens = (effects) => {
9290
+ return {
9291
+ borderRadiusSmall: effects.roundedCorner2,
9292
+ borderRadiusMedium: effects.roundedCorner4,
9293
+ borderRadiusLarge: effects.roundedCorner6
9294
+ };
9295
+ };
9296
+ /**
9297
+ * Creates a v9 theme from a v8 theme and base v9 theme.
9298
+ * FluentUI webLightTheme is used in case if no baseThemeV9 is provided.
9299
+ *
9300
+ * @private
9301
+ */
9302
+ const createV9Theme = (themeV8, baseThemeV9) => {
9303
+ const baseTheme = baseThemeV9 !== null && baseThemeV9 !== void 0 ? baseThemeV9 : reactComponents.webLightTheme;
9304
+ return Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({}, baseTheme), mapAliasColors(themeV8.palette, themeV8.isInverted)), mapShadowTokens(themeV8.effects)), mapBorderRadiusTokens(themeV8.effects)), { colorBrandBackground2: themeV8.palette.themeLight, colorBrandBackground2Hover: themeV8.palette.themeLight, colorBrandBackground2Pressed: themeV8.palette.themeLight, colorStatusWarningBackground3: '#D83B01', errorText: themeV8.semanticColors.errorText, colorNeutralStroke1Selected: themeV8.palette.neutralQuaternary, colorNeutralForeground2: themeV8.palette.neutralSecondary, colorBrandForegroundLink: themeV8.palette.themePrimary, colorBrandForegroundLinkHover: themeV8.palette.themeDarker, colorNeutralBackground1Selected: themeV8.palette.neutralQuaternaryAlt,
9305
+ // Fix for an issue with black borders for iOS that are added with 'after' selector
9306
+ colorStrokeFocus2: 'transparent' });
9307
+ };
9308
+
9309
+ // Copyright (c) Microsoft Corporation.
9310
+ // Licensed under the MIT License.
9311
+ /**
9312
+ * @private
9313
+ */
9314
+ const useFluentV9Wrapper = reactComponents.makeStyles({
9315
+ body: Object.assign(Object.assign(Object.assign(Object.assign({ height: '100%' }, reactComponents.shorthands.margin(0)), reactComponents.shorthands.overflow('hidden')), reactComponents.shorthands.padding(0)), { width: '100%' })
9316
+ });
9317
+ /**
9318
+ * @private
9319
+ */
9320
+ const FluentV9ThemeProvider = (props) => {
9321
+ const { v8Theme, children } = props;
9322
+ const v9Theme = createV9Theme(v8Theme);
9323
+ const dir = v8Theme.rtl ? 'rtl' : 'ltr';
9324
+ return (
9325
+ // TextDirectionProvider is needed to fix issue with direction value update in FluentProvider
9326
+ React.createElement(react$1.TextDirectionProvider, { dir: dir },
9327
+ React.createElement(FluentProviderWithStylesOverrides, { theme: v9Theme, dir: dir }, children)));
9328
+ };
9329
+ const FluentProviderWithStylesOverrides = (props) => {
9330
+ const classes = useFluentV9Wrapper();
9331
+ return React.createElement(reactComponents.FluentProvider, Object.assign({}, props, { className: classes.body, applyStylesToPortals: false }));
9332
+ };
9333
+
8961
9334
  // Copyright (c) Microsoft Corporation.
8962
9335
  // Licensed under the MIT License.
8963
9336
  /**
@@ -8972,7 +9345,7 @@ const SendBox$1 = (props) => {
8972
9345
  const { disabled, systemMessage, supportNewline, onSendMessage, onTyping, onRenderIcon, onRenderSystemMessage, styles, autoFocus,
8973
9346
  /* @conditional-compile-remove(mention) */
8974
9347
  mentionLookupOptions,
8975
- /* @conditional-compile-remove(file-sharing) */
9348
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
8976
9349
  activeFileUploads } = props;
8977
9350
  const theme = useTheme();
8978
9351
  const localeStrings = useLocale$1().strings.sendBox;
@@ -8981,7 +9354,7 @@ const SendBox$1 = (props) => {
8981
9354
  const [textValue, setTextValue] = React.useState('');
8982
9355
  const [textValueOverflow, setTextValueOverflow] = React.useState(false);
8983
9356
  const sendTextFieldRef = React.useRef(null);
8984
- /* @conditional-compile-remove(file-sharing) */
9357
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
8985
9358
  const [attachmentUploadsPendingError, setAttachmentUploadsPendingError] = React.useState(undefined);
8986
9359
  const sendMessageOnClick = () => {
8987
9360
  var _a;
@@ -8990,9 +9363,9 @@ const SendBox$1 = (props) => {
8990
9363
  return;
8991
9364
  }
8992
9365
  // Don't send message until all files have been uploaded successfully
8993
- /* @conditional-compile-remove(file-sharing) */
9366
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
8994
9367
  setAttachmentUploadsPendingError(undefined);
8995
- /* @conditional-compile-remove(file-sharing) */
9368
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
8996
9369
  if (hasIncompleteFileUploads(activeFileUploads)) {
8997
9370
  setAttachmentUploadsPendingError({ message: strings.attachmentUploadsPendingError, timestamp: Date.now() });
8998
9371
  return;
@@ -9001,7 +9374,7 @@ const SendBox$1 = (props) => {
9001
9374
  // we don't want to send empty messages including spaces, newlines, tabs
9002
9375
  // Message can be empty if there is a valid attachment upload
9003
9376
  if (sanitizeText(message).length > 0 ||
9004
- /* @conditional-compile-remove(file-sharing) */ hasCompletedFileUploads(activeFileUploads)) {
9377
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */ hasCompletedFileUploads(activeFileUploads)) {
9005
9378
  onSendMessage && onSendMessage(message);
9006
9379
  setTextValue('');
9007
9380
  }
@@ -9021,25 +9394,25 @@ const SendBox$1 = (props) => {
9021
9394
  const mergedSendIconStyle = React.useMemo(() => sendIconStyle({
9022
9395
  theme,
9023
9396
  hasText: !!textValue,
9024
- /* @conditional-compile-remove(file-sharing) */ hasFile: hasCompletedFileUploads(activeFileUploads),
9397
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */ hasFile: hasCompletedFileUploads(activeFileUploads),
9025
9398
  hasErrorMessage: !!errorMessage,
9026
9399
  customSendIconStyle: styles === null || styles === void 0 ? void 0 : styles.sendMessageIcon
9027
9400
  }), [
9028
9401
  theme,
9029
9402
  textValue,
9030
- /* @conditional-compile-remove(file-sharing) */ activeFileUploads,
9403
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */ activeFileUploads,
9031
9404
  errorMessage,
9032
9405
  styles === null || styles === void 0 ? void 0 : styles.sendMessageIcon
9033
9406
  ]);
9034
9407
  const onRenderSendIcon = React.useCallback((isHover) => onRenderIcon ? (onRenderIcon(isHover)) : (React.createElement(react.Icon, { iconName: isHover && textValue ? 'SendBoxSendHovered' : 'SendBoxSend', className: mergedSendIconStyle })), [mergedSendIconStyle, onRenderIcon, textValue]);
9035
9408
  // Ensure that errors are cleared when there are no files in sendBox
9036
- /* @conditional-compile-remove(file-sharing) */
9409
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
9037
9410
  React.useEffect(() => {
9038
9411
  if (!(activeFileUploads === null || activeFileUploads === void 0 ? void 0 : activeFileUploads.filter((upload) => !upload.error).length)) {
9039
9412
  setAttachmentUploadsPendingError(undefined);
9040
9413
  }
9041
9414
  }, [activeFileUploads]);
9042
- /* @conditional-compile-remove(file-sharing) */
9415
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
9043
9416
  const sendBoxErrorsProps = React.useMemo(() => {
9044
9417
  var _a;
9045
9418
  return {
@@ -9047,22 +9420,30 @@ const SendBox$1 = (props) => {
9047
9420
  attachmentUploadError: (_a = activeFileUploads === null || activeFileUploads === void 0 ? void 0 : activeFileUploads.filter((attachmentUpload) => attachmentUpload.error).pop()) === null || _a === void 0 ? void 0 : _a.error
9048
9421
  };
9049
9422
  }, [activeFileUploads, attachmentUploadsPendingError]);
9050
- /* @conditional-compile-remove(file-sharing) */
9423
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
9051
9424
  const onRenderFileUploads = React.useCallback(() => {
9052
9425
  var _a, _b, _c, _d, _e, _f;
9053
9426
  if (!(activeFileUploads === null || activeFileUploads === void 0 ? void 0 : activeFileUploads.filter((upload) => !upload.error).length)) {
9054
9427
  return null;
9055
9428
  }
9056
9429
  return props.onRenderFileUploads ? (props.onRenderFileUploads()) : (React.createElement(react.Stack, { className: attachmentUploadCardsStyles },
9057
- React.createElement(_AttachmentUploadCards, { activeFileUploads: activeFileUploads, onCancelFileUpload: props.onCancelFileUpload, strings: {
9058
- removeAttachment: (_b = (_a = props.strings) === null || _a === void 0 ? void 0 : _a.removeAttachment) !== null && _b !== void 0 ? _b : localeStrings.removeAttachment,
9059
- uploading: (_d = (_c = props.strings) === null || _c === void 0 ? void 0 : _c.uploading) !== null && _d !== void 0 ? _d : localeStrings.uploading,
9060
- uploadCompleted: (_f = (_e = props.strings) === null || _e === void 0 ? void 0 : _e.uploadCompleted) !== null && _f !== void 0 ? _f : localeStrings.uploadCompleted
9061
- } })));
9062
- }, [activeFileUploads, props, localeStrings]);
9430
+ React.createElement(FluentV9ThemeProvider, { v8Theme: theme },
9431
+ React.createElement(_AttachmentUploadCards, { activeFileUploads: activeFileUploads, onCancelFileUpload: props.onCancelFileUpload, strings: {
9432
+ removeAttachment: (_b = (_a = props.strings) === null || _a === void 0 ? void 0 : _a.removeAttachment) !== null && _b !== void 0 ? _b : localeStrings.removeAttachment,
9433
+ uploading: (_d = (_c = props.strings) === null || _c === void 0 ? void 0 : _c.uploading) !== null && _d !== void 0 ? _d : localeStrings.uploading,
9434
+ uploadCompleted: (_f = (_e = props.strings) === null || _e === void 0 ? void 0 : _e.uploadCompleted) !== null && _f !== void 0 ? _f : localeStrings.uploadCompleted
9435
+ } }))));
9436
+ }, [
9437
+ activeFileUploads,
9438
+ props,
9439
+ theme,
9440
+ localeStrings.removeAttachment,
9441
+ localeStrings.uploading,
9442
+ localeStrings.uploadCompleted
9443
+ ]);
9063
9444
  return (React.createElement(react.Stack, { className: react.mergeStyles(sendBoxWrapperStyles, { overflow: 'visible' } // This is needed for the mention popup to be visible
9064
- ) }, /* @conditional-compile-remove(file-sharing) */
9065
- React.createElement(SendBoxErrors, Object.assign({}, sendBoxErrorsProps)),
9445
+ ) },
9446
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */ React.createElement(SendBoxErrors, Object.assign({}, sendBoxErrorsProps)),
9066
9447
  React.createElement(react.Stack, { className: borderAndBoxShadowStyle({
9067
9448
  theme,
9068
9449
  hasErrorMessage: !!errorMessage,
@@ -9084,7 +9465,7 @@ const SendBox$1 = (props) => {
9084
9465
  }
9085
9466
  e.stopPropagation();
9086
9467
  }, id: 'sendIconWrapper', className: mergedSendButtonStyle, ariaLabel: localeStrings.sendButtonAriaLabel, tooltipContent: localeStrings.sendButtonAriaLabel })),
9087
- /* @conditional-compile-remove(file-sharing) */
9468
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
9088
9469
  onRenderFileUploads())));
9089
9470
  };
9090
9471
 
@@ -9662,9 +10043,9 @@ const richTextBorderBoxStyle = (props) => {
9662
10043
  */
9663
10044
  const RichTextInputBoxComponent = (props) => {
9664
10045
  const { placeholderText, initialContent, onChange, onEnterKeyDown, editorComponentRef, disabled, strings, actionComponents,
9665
- /* @conditional-compile-remove(file-sharing) */
10046
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
9666
10047
  onRenderFileUploads,
9667
- /* @conditional-compile-remove(file-sharing) */
10048
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
9668
10049
  hasFiles, richTextEditorStyleProps, isHorizontalLayoutDisabled = false } = props;
9669
10050
  const theme = useTheme();
9670
10051
  const [showRichTextEditorFormatting, setShowRichTextEditorFormatting] = React.useState(false);
@@ -9703,11 +10084,11 @@ const RichTextInputBoxComponent = (props) => {
9703
10084
  const useHorizontalLayout = React.useMemo(() => {
9704
10085
  return (!isHorizontalLayoutDisabled &&
9705
10086
  !showRichTextEditorFormatting &&
9706
- /* @conditional-compile-remove(file-sharing) */ !hasFiles);
10087
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */ !hasFiles);
9707
10088
  }, [
9708
10089
  isHorizontalLayoutDisabled,
9709
10090
  showRichTextEditorFormatting,
9710
- /* @conditional-compile-remove(file-sharing) */ hasFiles
10091
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */ hasFiles
9711
10092
  ]);
9712
10093
  return (React.createElement("div", { className: richTextBorderBoxStyle({
9713
10094
  theme: theme,
@@ -9716,8 +10097,9 @@ const RichTextInputBoxComponent = (props) => {
9716
10097
  React.createElement(react.Stack, { grow: true, horizontal: useHorizontalLayout, horizontalAlign: useHorizontalLayout ? 'end' : 'space-between', className: inputBoxContentStackStyle, wrap: useHorizontalLayout },
9717
10098
  React.createElement(react.Stack, { grow: true, className: inputBoxRichTextStackStyle },
9718
10099
  React.createElement(react.Stack.Item, { className: inputBoxRichTextStackItemStyle },
9719
- React.createElement(RichTextEditor, { initialContent: initialContent, placeholderText: placeholderText, onChange: onChange, onKeyDown: onKeyDown, ref: editorComponentRef, strings: strings, showRichTextEditorFormatting: showRichTextEditorFormatting, styles: richTextEditorStyle })), /* @conditional-compile-remove(file-sharing) */
9720
- onRenderFileUploads && onRenderFileUploads()),
10100
+ React.createElement(RichTextEditor, { initialContent: initialContent, placeholderText: placeholderText, onChange: onChange, onKeyDown: onKeyDown, ref: editorComponentRef, strings: strings, showRichTextEditorFormatting: showRichTextEditorFormatting, styles: richTextEditorStyle })),
10101
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */ onRenderFileUploads &&
10102
+ onRenderFileUploads()),
9721
10103
  actionButtons)));
9722
10104
  };
9723
10105
 
@@ -9728,9 +10110,9 @@ const RichTextInputBoxComponent = (props) => {
9728
10110
  */
9729
10111
  const RichTextSendBoxErrors = (props) => {
9730
10112
  const {
9731
- /* @conditional-compile-remove(file-sharing) */
10113
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
9732
10114
  attachmentUploadError,
9733
- /* @conditional-compile-remove(file-sharing) */
10115
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
9734
10116
  attachmentUploadsPendingError, systemMessage, textTooLongMessage } = props;
9735
10117
  const [sendBoxError, setSendBoxError] = React.useState(undefined);
9736
10118
  React.useEffect(() => {
@@ -9755,11 +10137,11 @@ const RichTextSendBoxErrors = (props) => {
9755
10137
  if (prev) {
9756
10138
  errors.push(prev);
9757
10139
  }
9758
- /* @conditional-compile-remove(file-sharing) */
10140
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
9759
10141
  if (attachmentUploadsPendingError) {
9760
10142
  errors.push(attachmentUploadsPendingError);
9761
10143
  }
9762
- /* @conditional-compile-remove(file-sharing) */
10144
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
9763
10145
  if (attachmentUploadError) {
9764
10146
  errors.push(attachmentUploadError);
9765
10147
  }
@@ -9771,8 +10153,8 @@ const RichTextSendBoxErrors = (props) => {
9771
10153
  return sortedErrors[0];
9772
10154
  });
9773
10155
  }, [
9774
- /* @conditional-compile-remove(file-sharing) */ attachmentUploadError,
9775
- /* @conditional-compile-remove(file-sharing) */ attachmentUploadsPendingError
10156
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */ attachmentUploadError,
10157
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */ attachmentUploadsPendingError
9776
10158
  ]);
9777
10159
  const onDismiss = React.useCallback(() => {
9778
10160
  if (systemMessage && !isMessageEmpty$1(systemMessage)) {
@@ -9796,9 +10178,9 @@ const isMessageEmpty$1 = (message) => {
9796
10178
  */
9797
10179
  const RichTextSendBox = (props) => {
9798
10180
  const { disabled = false, systemMessage, onSendMessage,
9799
- /* @conditional-compile-remove(file-sharing) */
10181
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
9800
10182
  activeFileUploads,
9801
- /* @conditional-compile-remove(file-sharing) */
10183
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
9802
10184
  onCancelFileUpload } = props;
9803
10185
  const theme = useTheme();
9804
10186
  const locale = useLocale$1();
@@ -9811,7 +10193,7 @@ const RichTextSendBox = (props) => {
9811
10193
  }, [localeStrings, props.strings]);
9812
10194
  const [contentValue, setContentValue] = React.useState('');
9813
10195
  const [contentValueOverflow, setContentValueOverflow] = React.useState(false);
9814
- /* @conditional-compile-remove(file-sharing) */
10196
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
9815
10197
  const [attachmentUploadsPendingError, setFileUploadsPendingError] = React.useState(undefined);
9816
10198
  const editorComponentRef = React.useRef(null);
9817
10199
  const contentTooLongMessage = React.useMemo(() => (contentValueOverflow ? strings.textTooLong : undefined), [contentValueOverflow, strings.textTooLong]);
@@ -9828,9 +10210,9 @@ const RichTextSendBox = (props) => {
9828
10210
  return;
9829
10211
  }
9830
10212
  // Don't send message until all files have been uploaded successfully
9831
- /* @conditional-compile-remove(file-sharing) */
10213
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
9832
10214
  setFileUploadsPendingError(undefined);
9833
- /* @conditional-compile-remove(file-sharing) */
10215
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
9834
10216
  if (hasIncompleteFileUploads(activeFileUploads)) {
9835
10217
  setFileUploadsPendingError({ message: strings.attachmentUploadsPendingError, timestamp: Date.now() });
9836
10218
  return;
@@ -9839,7 +10221,7 @@ const RichTextSendBox = (props) => {
9839
10221
  // we don't want to send empty messages including spaces, newlines, tabs
9840
10222
  // Message can be empty if there is a valid file upload
9841
10223
  if (sanitizeText(message).length > 0 ||
9842
- /* @conditional-compile-remove(file-sharing) */ hasCompletedFileUploads(activeFileUploads)) {
10224
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */ hasCompletedFileUploads(activeFileUploads)) {
9843
10225
  onSendMessage(message);
9844
10226
  setContentValue('');
9845
10227
  (_a = editorComponentRef.current) === null || _a === void 0 ? void 0 : _a.setEmptyContent();
@@ -9850,29 +10232,29 @@ const RichTextSendBox = (props) => {
9850
10232
  contentValueOverflow,
9851
10233
  disabled,
9852
10234
  onSendMessage,
9853
- /* @conditional-compile-remove(file-sharing) */ activeFileUploads,
9854
- /* @conditional-compile-remove(file-sharing) */ strings.attachmentUploadsPendingError
10235
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */ activeFileUploads,
10236
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */ strings.attachmentUploadsPendingError
9855
10237
  ]);
9856
10238
  const hasErrorMessage = React.useMemo(() => {
9857
10239
  var _a;
9858
10240
  return (!!systemMessage ||
9859
10241
  !!contentTooLongMessage ||
9860
- /* @conditional-compile-remove(file-sharing) */
10242
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
9861
10243
  !!attachmentUploadsPendingError ||
9862
- /* @conditional-compile-remove(file-sharing) */
10244
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
9863
10245
  !!((_a = activeFileUploads === null || activeFileUploads === void 0 ? void 0 : activeFileUploads.filter((attachmentUpload) => attachmentUpload.error).pop()) === null || _a === void 0 ? void 0 : _a.error));
9864
10246
  }, [
9865
- /* @conditional-compile-remove(file-sharing) */
10247
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
9866
10248
  activeFileUploads,
9867
10249
  contentTooLongMessage,
9868
- /* @conditional-compile-remove(file-sharing) */
10250
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
9869
10251
  attachmentUploadsPendingError,
9870
10252
  systemMessage
9871
10253
  ]);
9872
10254
  const onRenderSendIcon = React.useCallback((isHover) => (React.createElement(react.Icon, { iconName: isHover && contentValue ? 'SendBoxSendHovered' : 'SendBoxSend', className: sendIconStyle({
9873
10255
  theme,
9874
10256
  hasText: !!contentValue,
9875
- /* @conditional-compile-remove(file-sharing) */
10257
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
9876
10258
  hasFile: false,
9877
10259
  hasErrorMessage: hasErrorMessage,
9878
10260
  defaultTextColor: theme.palette.neutralSecondary,
@@ -9881,22 +10263,22 @@ const RichTextSendBox = (props) => {
9881
10263
  const sendBoxErrorsProps = React.useMemo(() => {
9882
10264
  var _a;
9883
10265
  return {
9884
- /* @conditional-compile-remove(file-sharing) */
10266
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
9885
10267
  attachmentUploadsPendingError: attachmentUploadsPendingError,
9886
- /* @conditional-compile-remove(file-sharing) */
10268
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
9887
10269
  attachmentUploadError: (_a = activeFileUploads === null || activeFileUploads === void 0 ? void 0 : activeFileUploads.filter((attachmentUpload) => attachmentUpload.error).pop()) === null || _a === void 0 ? void 0 : _a.error,
9888
10270
  systemMessage: systemMessage,
9889
10271
  textTooLongMessage: contentTooLongMessage
9890
10272
  };
9891
10273
  }, [
9892
- /* @conditional-compile-remove(file-sharing) */
10274
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
9893
10275
  activeFileUploads,
9894
10276
  contentTooLongMessage,
9895
- /* @conditional-compile-remove(file-sharing) */
10277
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
9896
10278
  attachmentUploadsPendingError,
9897
10279
  systemMessage
9898
10280
  ]);
9899
- /* @conditional-compile-remove(file-sharing) */
10281
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
9900
10282
  const onRenderFileUploads = React.useCallback(() => {
9901
10283
  return (React.createElement(react.Stack, { className: attachmentUploadCardsStyles },
9902
10284
  React.createElement(_AttachmentUploadCards, { activeFileUploads: activeFileUploads, onCancelFileUpload: onCancelFileUpload, strings: {
@@ -9911,16 +10293,16 @@ const RichTextSendBox = (props) => {
9911
10293
  e.stopPropagation(); // Prevents the click from bubbling up and triggering a focus event on the chat.
9912
10294
  }, className: richTextActionButtonsStyle, ariaLabel: localeStrings.sendButtonAriaLabel, tooltipContent: localeStrings.sendButtonAriaLabel }));
9913
10295
  }, [localeStrings.sendButtonAriaLabel, onRenderSendIcon, sendMessageOnClick]);
9914
- /* @conditional-compile-remove(file-sharing) */
10296
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
9915
10297
  const hasFileUploads = React.useMemo(() => {
9916
10298
  return hasCompletedFileUploads(activeFileUploads) || hasIncompleteFileUploads(activeFileUploads);
9917
10299
  }, [activeFileUploads]);
9918
10300
  return (React.createElement(react.Stack, null,
9919
10301
  React.createElement(RichTextSendBoxErrors, Object.assign({}, sendBoxErrorsProps)),
9920
10302
  React.createElement(RichTextInputBoxComponent, { placeholderText: strings.placeholderText, onChange: setContent, onEnterKeyDown: sendMessageOnClick, editorComponentRef: editorComponentRef, strings: strings, disabled: disabled, actionComponents: sendButton, richTextEditorStyleProps: sendBoxRichTextEditorStyle,
9921
- /* @conditional-compile-remove(file-sharing) */
10303
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
9922
10304
  onRenderFileUploads: onRenderFileUploads,
9923
- /* @conditional-compile-remove(file-sharing) */
10305
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
9924
10306
  hasFiles: hasFileUploads })));
9925
10307
  };
9926
10308
 
@@ -10410,23 +10792,24 @@ const onRenderSubmitIcon = (className) => {
10410
10792
  return React.createElement(react.Icon, { iconName: 'EditBoxSubmit', className: className });
10411
10793
  };
10412
10794
  function isMessageEmpty(messageText,
10413
- /* @conditional-compile-remove(file-sharing) */
10795
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
10414
10796
  attachmentMetadata) {
10415
- /* @conditional-compile-remove(file-sharing) */
10797
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
10416
10798
  return messageText.trim().length === 0 && (attachmentMetadata === null || attachmentMetadata === void 0 ? void 0 : attachmentMetadata.length) === 0;
10417
10799
  }
10418
10800
  /**
10419
10801
  * @private
10420
10802
  */
10421
10803
  function getMessageState(messageText,
10422
- /* @conditional-compile-remove(file-sharing) */ attachmentMetadata) {
10423
- return isMessageEmpty(messageText, /* @conditional-compile-remove(file-sharing) */ attachmentMetadata)
10804
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */ attachmentMetadata) {
10805
+ return isMessageEmpty(messageText,
10806
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */ attachmentMetadata)
10424
10807
  ? 'too short'
10425
10808
  : isMessageTooLong(messageText.length)
10426
10809
  ? 'too long'
10427
10810
  : 'OK';
10428
10811
  }
10429
- /* @conditional-compile-remove(file-sharing) */
10812
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
10430
10813
  /**
10431
10814
  * @private
10432
10815
  * @TODO: Remove when file-sharing feature becomes stable.
@@ -10677,363 +11060,6 @@ var getParticipantsWhoHaveReadMessage = (message, readReceiptsBySenderId) => {
10677
11060
  .map(([id, readReceipt]) => ({ id, displayName: readReceipt.displayName })));
10678
11061
  };
10679
11062
 
10680
- // Copyright (c) Microsoft Corporation.
10681
- // Licensed under the MIT License.
10682
- // These color records are required for createV9Theme
10683
- // For more info, check https://react.fluentui.dev/iframe.html?viewMode=docs&id=concepts-migration-from-v8-components-theme-migration--page#compatible-themes
10684
- /**
10685
- * @private
10686
- */
10687
- const grey = {
10688
- '0': '#000000',
10689
- '2': '#050505',
10690
- '4': '#0a0a0a',
10691
- '6': '#0f0f0f',
10692
- '8': '#141414',
10693
- '10': '#1a1a1a',
10694
- '12': '#1f1f1f',
10695
- '14': '#242424',
10696
- '16': '#292929',
10697
- '18': '#2e2e2e',
10698
- '20': '#333333',
10699
- '22': '#383838',
10700
- '24': '#3d3d3d',
10701
- '26': '#424242',
10702
- '28': '#474747',
10703
- '30': '#4d4d4d',
10704
- '32': '#525252',
10705
- '34': '#575757',
10706
- '36': '#5c5c5c',
10707
- '38': '#616161',
10708
- '40': '#666666',
10709
- '42': '#6b6b6b',
10710
- '44': '#707070',
10711
- '46': '#757575',
10712
- '48': '#7a7a7a',
10713
- '50': '#808080',
10714
- '52': '#858585',
10715
- '54': '#8a8a8a',
10716
- '56': '#8f8f8f',
10717
- '58': '#949494',
10718
- '60': '#999999',
10719
- '62': '#9e9e9e',
10720
- '64': '#a3a3a3',
10721
- '66': '#a8a8a8',
10722
- '68': '#adadad',
10723
- '70': '#b3b3b3',
10724
- '72': '#b8b8b8',
10725
- '74': '#bdbdbd',
10726
- '76': '#c2c2c2',
10727
- '78': '#c7c7c7',
10728
- '80': '#cccccc',
10729
- '82': '#d1d1d1',
10730
- '84': '#d6d6d6',
10731
- '86': '#dbdbdb',
10732
- '88': '#e0e0e0',
10733
- '90': '#e6e6e6',
10734
- '92': '#ebebeb',
10735
- '94': '#f0f0f0',
10736
- '96': '#f5f5f5',
10737
- '98': '#fafafa',
10738
- '100': '#ffffff'
10739
- };
10740
- /**
10741
- * @private
10742
- */
10743
- const whiteAlpha = {
10744
- '5': 'rgba(255, 255, 255, 0.05)',
10745
- '10': 'rgba(255, 255, 255, 0.1)',
10746
- '20': 'rgba(255, 255, 255, 0.2)',
10747
- '30': 'rgba(255, 255, 255, 0.3)',
10748
- '40': 'rgba(255, 255, 255, 0.4)',
10749
- '50': 'rgba(255, 255, 255, 0.5)',
10750
- '60': 'rgba(255, 255, 255, 0.6)',
10751
- '70': 'rgba(255, 255, 255, 0.7)',
10752
- '80': 'rgba(255, 255, 255, 0.8)',
10753
- '90': 'rgba(255, 255, 255, 0.9)'
10754
- };
10755
- /**
10756
- * @private
10757
- */
10758
- const blackAlpha = {
10759
- '5': 'rgba(0, 0, 0, 0.05)',
10760
- '10': 'rgba(0, 0, 0, 0.1)',
10761
- '20': 'rgba(0, 0, 0, 0.2)',
10762
- '30': 'rgba(0, 0, 0, 0.3)',
10763
- '40': 'rgba(0, 0, 0, 0.4)',
10764
- '50': 'rgba(0, 0, 0, 0.5)',
10765
- '60': 'rgba(0, 0, 0, 0.6)',
10766
- '70': 'rgba(0, 0, 0, 0.7)',
10767
- '80': 'rgba(0, 0, 0, 0.8)',
10768
- '90': 'rgba(0, 0, 0, 0.9)'
10769
- };
10770
- /**
10771
- * @private
10772
- */
10773
- const grey10Alpha = {
10774
- '5': 'rgba(26, 26, 26, 0.05)',
10775
- '10': 'rgba(26, 26, 26, 0.1)',
10776
- '20': 'rgba(26, 26, 26, 0.2)',
10777
- '30': 'rgba(26, 26, 26, 0.3)',
10778
- '40': 'rgba(26, 26, 26, 0.4)',
10779
- '50': 'rgba(26, 26, 26, 0.5)',
10780
- '60': 'rgba(26, 26, 26, 0.6)',
10781
- '70': 'rgba(26, 26, 26, 0.7)',
10782
- '80': 'rgba(26, 26, 26, 0.8)',
10783
- '90': 'rgba(26, 26, 26, 0.9)'
10784
- };
10785
- /**
10786
- * @private
10787
- */
10788
- const grey12Alpha = {
10789
- '5': 'rgba(31, 31, 31, 0.05)',
10790
- '10': 'rgba(31, 31, 31, 0.1)',
10791
- '20': 'rgba(31, 31, 31, 0.2)',
10792
- '30': 'rgba(31, 31, 31, 0.3)',
10793
- '40': 'rgba(31, 31, 31, 0.4)',
10794
- '50': 'rgba(31, 31, 31, 0.5)',
10795
- '60': 'rgba(31, 31, 31, 0.6)',
10796
- '70': 'rgba(31, 31, 31, 0.7)',
10797
- '80': 'rgba(31, 31, 31, 0.8)',
10798
- '90': 'rgba(31, 31, 31, 0.9)'
10799
- };
10800
-
10801
- // Copyright (c) Microsoft Corporation.
10802
- // Licensed under the MIT License.
10803
- // These mappings are required for createV9Theme
10804
- // For more info, check https://react.fluentui.dev/iframe.html?viewMode=docs&id=concepts-migration-from-v8-components-theme-migration--page#compatible-themes
10805
- /**
10806
- * Creates v9 color tokens from a v8 palette.
10807
- */
10808
- const mapAliasColors = (palette, inverted) => {
10809
- return {
10810
- colorNeutralForeground1: palette.neutralPrimary,
10811
- colorNeutralForeground1Hover: palette.neutralPrimary,
10812
- colorNeutralForeground1Pressed: palette.neutralPrimary,
10813
- colorNeutralForeground1Selected: palette.neutralPrimary,
10814
- colorNeutralForeground2: palette.neutralSecondary,
10815
- colorNeutralForeground2Hover: palette.neutralPrimary,
10816
- colorNeutralForeground2Pressed: palette.neutralPrimary,
10817
- colorNeutralForeground2Selected: palette.neutralPrimary,
10818
- colorNeutralForeground2BrandHover: palette.themePrimary,
10819
- colorNeutralForeground2BrandPressed: palette.themeDarkAlt,
10820
- colorNeutralForeground2BrandSelected: palette.themePrimary,
10821
- colorNeutralForeground3: palette.neutralTertiary,
10822
- colorNeutralForeground3Hover: palette.neutralSecondary,
10823
- colorNeutralForeground3Pressed: palette.neutralSecondary,
10824
- colorNeutralForeground3Selected: palette.neutralSecondary,
10825
- colorNeutralForeground3BrandHover: palette.themePrimary,
10826
- colorNeutralForeground3BrandPressed: palette.themeDarkAlt,
10827
- colorNeutralForeground3BrandSelected: palette.themePrimary,
10828
- colorNeutralForeground4: palette.neutralQuaternary,
10829
- colorNeutralForegroundDisabled: palette.neutralTertiaryAlt,
10830
- colorNeutralForegroundInvertedDisabled: whiteAlpha[40],
10831
- colorBrandForegroundLink: palette.themeDarkAlt,
10832
- colorBrandForegroundLinkHover: palette.themeDark,
10833
- colorBrandForegroundLinkPressed: palette.themeDarker,
10834
- colorBrandForegroundLinkSelected: palette.themeDarkAlt,
10835
- colorNeutralForeground2Link: palette.neutralSecondary,
10836
- colorNeutralForeground2LinkHover: palette.neutralPrimary,
10837
- colorNeutralForeground2LinkPressed: palette.neutralPrimary,
10838
- colorNeutralForeground2LinkSelected: palette.neutralPrimary,
10839
- colorCompoundBrandForeground1: palette.themePrimary,
10840
- colorCompoundBrandForeground1Hover: palette.themeDarkAlt,
10841
- colorCompoundBrandForeground1Pressed: palette.themeDark,
10842
- colorBrandForeground1: palette.themePrimary,
10843
- colorBrandForeground2: palette.themeDarkAlt,
10844
- colorBrandForeground2Hover: palette.themeDarkAlt,
10845
- colorBrandForeground2Pressed: palette.themeDarkAlt,
10846
- colorNeutralForeground1Static: palette.neutralPrimary,
10847
- colorNeutralForegroundInverted: palette.white,
10848
- colorNeutralForegroundInvertedHover: palette.white,
10849
- colorNeutralForegroundInvertedPressed: palette.white,
10850
- colorNeutralForegroundInvertedSelected: palette.white,
10851
- colorNeutralForegroundOnBrand: palette.white,
10852
- colorNeutralForegroundStaticInverted: palette.white,
10853
- colorNeutralForegroundInvertedLink: palette.white,
10854
- colorNeutralForegroundInvertedLinkHover: palette.white,
10855
- colorNeutralForegroundInvertedLinkPressed: palette.white,
10856
- colorNeutralForegroundInvertedLinkSelected: palette.white,
10857
- colorNeutralForegroundInverted2: palette.white,
10858
- colorBrandForegroundInverted: palette.themeSecondary,
10859
- colorBrandForegroundInvertedHover: palette.themeTertiary,
10860
- colorBrandForegroundInvertedPressed: palette.themeSecondary,
10861
- colorBrandForegroundOnLight: palette.themePrimary,
10862
- colorBrandForegroundOnLightHover: palette.themeDarkAlt,
10863
- colorBrandForegroundOnLightPressed: palette.themeDark,
10864
- colorBrandForegroundOnLightSelected: palette.themeDark,
10865
- colorNeutralBackground1: palette.white,
10866
- colorNeutralBackground1Hover: palette.neutralLighter,
10867
- colorNeutralBackground1Pressed: palette.neutralQuaternaryAlt,
10868
- colorNeutralBackground1Selected: palette.neutralLight,
10869
- colorNeutralBackground2: palette.neutralLighterAlt,
10870
- colorNeutralBackground2Hover: palette.neutralLighter,
10871
- colorNeutralBackground2Pressed: palette.neutralQuaternaryAlt,
10872
- colorNeutralBackground2Selected: palette.neutralLight,
10873
- colorNeutralBackground3: palette.neutralLighter,
10874
- colorNeutralBackground3Hover: palette.neutralLight,
10875
- colorNeutralBackground3Pressed: palette.neutralQuaternary,
10876
- colorNeutralBackground3Selected: palette.neutralQuaternaryAlt,
10877
- colorNeutralBackground4: palette.neutralLighter,
10878
- colorNeutralBackground4Hover: palette.neutralLighterAlt,
10879
- colorNeutralBackground4Pressed: palette.neutralLighter,
10880
- colorNeutralBackground4Selected: palette.white,
10881
- colorNeutralBackground5: palette.neutralLight,
10882
- colorNeutralBackground5Hover: palette.neutralLighter,
10883
- colorNeutralBackground5Pressed: palette.neutralLighter,
10884
- colorNeutralBackground5Selected: palette.neutralLighterAlt,
10885
- colorNeutralBackground6: palette.neutralLight,
10886
- colorNeutralBackgroundStatic: grey[20],
10887
- colorNeutralBackgroundInverted: palette.neutralSecondary,
10888
- colorNeutralBackgroundAlpha: inverted ? grey10Alpha[50] : whiteAlpha[50],
10889
- colorNeutralBackgroundAlpha2: inverted ? grey12Alpha[70] : whiteAlpha[80],
10890
- colorSubtleBackground: 'transparent',
10891
- colorSubtleBackgroundHover: palette.neutralLighter,
10892
- colorSubtleBackgroundPressed: palette.neutralQuaternaryAlt,
10893
- colorSubtleBackgroundSelected: palette.neutralLight,
10894
- colorSubtleBackgroundLightAlphaHover: inverted ? whiteAlpha[10] : whiteAlpha[80],
10895
- colorSubtleBackgroundLightAlphaPressed: inverted ? whiteAlpha[5] : whiteAlpha[50],
10896
- colorSubtleBackgroundLightAlphaSelected: 'transparent',
10897
- colorSubtleBackgroundInverted: 'transparent',
10898
- colorSubtleBackgroundInvertedHover: blackAlpha[10],
10899
- colorSubtleBackgroundInvertedPressed: blackAlpha[30],
10900
- colorSubtleBackgroundInvertedSelected: blackAlpha[20],
10901
- colorTransparentBackground: 'transparent',
10902
- colorTransparentBackgroundHover: 'transparent',
10903
- colorTransparentBackgroundPressed: 'transparent',
10904
- colorTransparentBackgroundSelected: 'transparent',
10905
- colorNeutralBackgroundDisabled: palette.neutralLighter,
10906
- colorNeutralBackgroundInvertedDisabled: whiteAlpha[10],
10907
- colorNeutralStencil1: palette.neutralLight,
10908
- colorNeutralStencil2: palette.neutralLighterAlt,
10909
- colorNeutralStencil1Alpha: inverted ? whiteAlpha[10] : blackAlpha[10],
10910
- colorNeutralStencil2Alpha: inverted ? whiteAlpha[5] : blackAlpha[5],
10911
- colorBackgroundOverlay: blackAlpha[40],
10912
- colorScrollbarOverlay: blackAlpha[50],
10913
- colorBrandBackground: palette.themePrimary,
10914
- colorBrandBackgroundHover: palette.themeDarkAlt,
10915
- colorBrandBackgroundPressed: palette.themeDarker,
10916
- colorBrandBackgroundSelected: palette.themeDark,
10917
- colorCompoundBrandBackground: palette.themePrimary,
10918
- colorCompoundBrandBackgroundHover: palette.themeDarkAlt,
10919
- colorCompoundBrandBackgroundPressed: palette.themeDark,
10920
- colorBrandBackgroundStatic: palette.themePrimary,
10921
- colorBrandBackground2: palette.themeLighterAlt,
10922
- colorBrandBackground2Hover: palette.themeLighterAlt,
10923
- colorBrandBackground2Pressed: palette.themeLighterAlt,
10924
- colorBrandBackground3Static: palette.themeDark,
10925
- colorBrandBackground4Static: palette.themeDarker,
10926
- colorBrandBackgroundInverted: palette.white,
10927
- colorBrandBackgroundInvertedHover: palette.themeLighterAlt,
10928
- colorBrandBackgroundInvertedPressed: palette.themeLight,
10929
- colorBrandBackgroundInvertedSelected: palette.themeLighter,
10930
- colorNeutralCardBackground: inverted ? grey[20] : grey[98],
10931
- colorNeutralCardBackgroundHover: inverted ? grey[24] : palette.white,
10932
- colorNeutralCardBackgroundPressed: inverted ? grey[18] : grey[96],
10933
- colorNeutralCardBackgroundSelected: inverted ? grey[22] : grey[92],
10934
- colorNeutralCardBackgroundDisabled: inverted ? grey[8] : grey[94],
10935
- colorNeutralStrokeAccessible: palette.neutralSecondary,
10936
- colorNeutralStrokeAccessibleHover: palette.neutralSecondary,
10937
- colorNeutralStrokeAccessiblePressed: palette.neutralSecondary,
10938
- colorNeutralStrokeAccessibleSelected: palette.themePrimary,
10939
- colorNeutralStroke1: palette.neutralQuaternary,
10940
- colorNeutralStroke1Hover: palette.neutralTertiaryAlt,
10941
- colorNeutralStroke1Pressed: palette.neutralTertiaryAlt,
10942
- colorNeutralStroke1Selected: palette.neutralTertiaryAlt,
10943
- colorNeutralStroke2: palette.neutralQuaternaryAlt,
10944
- colorNeutralStroke3: palette.neutralLighter,
10945
- colorNeutralStrokeSubtle: palette.neutralQuaternaryAlt,
10946
- colorNeutralStrokeOnBrand: palette.white,
10947
- colorNeutralStrokeOnBrand2: palette.white,
10948
- colorNeutralStrokeOnBrand2Hover: palette.white,
10949
- colorNeutralStrokeOnBrand2Pressed: palette.white,
10950
- colorNeutralStrokeOnBrand2Selected: palette.white,
10951
- colorBrandStroke1: palette.themePrimary,
10952
- colorBrandStroke2: palette.themeLight,
10953
- colorBrandStroke2Hover: palette.themeLight,
10954
- colorBrandStroke2Pressed: palette.themeLight,
10955
- colorBrandStroke2Contrast: palette.themeLight,
10956
- colorCompoundBrandStroke: palette.themePrimary,
10957
- colorCompoundBrandStrokeHover: palette.themeDarkAlt,
10958
- colorCompoundBrandStrokePressed: palette.themeDark,
10959
- colorNeutralStrokeDisabled: palette.neutralQuaternaryAlt,
10960
- colorNeutralStrokeInvertedDisabled: whiteAlpha[40],
10961
- colorTransparentStroke: 'transparent',
10962
- colorTransparentStrokeInteractive: 'transparent',
10963
- colorTransparentStrokeDisabled: 'transparent',
10964
- colorNeutralStrokeAlpha: inverted ? whiteAlpha[10] : blackAlpha[5],
10965
- colorNeutralStrokeAlpha2: whiteAlpha[20],
10966
- colorStrokeFocus1: palette.white,
10967
- colorStrokeFocus2: palette.black,
10968
- colorNeutralShadowAmbient: 'rgba(0,0,0,0.12)',
10969
- colorNeutralShadowKey: 'rgba(0,0,0,0.14)',
10970
- colorNeutralShadowAmbientLighter: 'rgba(0,0,0,0.06)',
10971
- colorNeutralShadowKeyLighter: 'rgba(0,0,0,0.07)',
10972
- colorNeutralShadowAmbientDarker: 'rgba(0,0,0,0.20)',
10973
- colorNeutralShadowKeyDarker: 'rgba(0,0,0,0.24)',
10974
- colorBrandShadowAmbient: 'rgba(0,0,0,0.30)',
10975
- colorBrandShadowKey: 'rgba(0,0,0,0.25)'
10976
- };
10977
- };
10978
- /**
10979
- * Creates v9 shadow tokens from v8 effects.
10980
- */
10981
- const mapShadowTokens = (effects) => {
10982
- return {
10983
- shadow4: effects.elevation4,
10984
- shadow8: effects.elevation8,
10985
- shadow16: effects.elevation16,
10986
- shadow64: effects.elevation64
10987
- };
10988
- };
10989
- /**
10990
- * Creates v9 border radius tokens from v8 effects
10991
- */
10992
- const mapBorderRadiusTokens = (effects) => {
10993
- return {
10994
- borderRadiusSmall: effects.roundedCorner2,
10995
- borderRadiusMedium: effects.roundedCorner4,
10996
- borderRadiusLarge: effects.roundedCorner6
10997
- };
10998
- };
10999
- /**
11000
- * Creates a v9 theme from a v8 theme and base v9 theme.
11001
- * FluentUI webLightTheme is used in case if no baseThemeV9 is provided.
11002
- *
11003
- * @private
11004
- */
11005
- const createV9Theme = (themeV8, baseThemeV9) => {
11006
- const baseTheme = baseThemeV9 !== null && baseThemeV9 !== void 0 ? baseThemeV9 : reactComponents.webLightTheme;
11007
- return Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({}, baseTheme), mapAliasColors(themeV8.palette, themeV8.isInverted)), mapShadowTokens(themeV8.effects)), mapBorderRadiusTokens(themeV8.effects)), { colorBrandBackground2: themeV8.palette.themeLight, colorBrandBackground2Hover: themeV8.palette.themeLight, colorBrandBackground2Pressed: themeV8.palette.themeLight, colorStatusWarningBackground3: '#D83B01', errorText: themeV8.semanticColors.errorText, colorNeutralStroke1Selected: themeV8.palette.neutralQuaternary, colorNeutralForeground2: themeV8.palette.neutralSecondary, colorBrandForegroundLink: themeV8.palette.themePrimary, colorBrandForegroundLinkHover: themeV8.palette.themeDarker, colorNeutralBackground1Selected: themeV8.palette.neutralQuaternaryAlt,
11008
- // Fix for an issue with black borders for iOS that are added with 'after' selector
11009
- colorStrokeFocus2: 'transparent' });
11010
- };
11011
-
11012
- // Copyright (c) Microsoft Corporation.
11013
- // Licensed under the MIT License.
11014
- /**
11015
- * @private
11016
- */
11017
- const useFluentV9Wrapper = reactComponents.makeStyles({
11018
- body: Object.assign(Object.assign(Object.assign(Object.assign({ height: '100%' }, reactComponents.shorthands.margin(0)), reactComponents.shorthands.overflow('hidden')), reactComponents.shorthands.padding(0)), { width: '100%' })
11019
- });
11020
- /**
11021
- * @private
11022
- */
11023
- const FluentV9ThemeProvider = (props) => {
11024
- const { v8Theme, children } = props;
11025
- const v9Theme = createV9Theme(v8Theme);
11026
- const dir = v8Theme.rtl ? 'rtl' : 'ltr';
11027
- return (
11028
- // TextDirectionProvider is needed to fix issue with direction value update in FluentProvider
11029
- React.createElement(react$1.TextDirectionProvider, { dir: dir },
11030
- React.createElement(FluentProviderWithStylesOverrides, { theme: v9Theme, dir: dir }, children)));
11031
- };
11032
- const FluentProviderWithStylesOverrides = (props) => {
11033
- const classes = useFluentV9Wrapper();
11034
- return React.createElement(reactComponents.FluentProvider, Object.assign({}, props, { className: classes.body }));
11035
- };
11036
-
11037
11063
  // Copyright (c) Microsoft Corporation.
11038
11064
  // Licensed under the MIT License.
11039
11065
  /// Adapted from: https://github.com/AlmeroSteyn/react-aria-live/blob/master/src/modules/MessageBlock.js
@@ -11218,12 +11244,12 @@ const ChatMessageComponentAsEditBox = (props) => {
11218
11244
  /* @conditional-compile-remove(mention) */
11219
11245
  const { mentionLookupOptions } = props;
11220
11246
  const [textValue, setTextValue] = React.useState(message.content || '');
11221
- /* @conditional-compile-remove(file-sharing) */
11247
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
11222
11248
  const [attachmentMetadata, setAttachedFilesMetadata] = React.useState(getMessageAttachedFilesMetadata(message));
11223
11249
  const editTextFieldRef = React.useRef(null);
11224
11250
  const theme = useTheme();
11225
11251
  const messageState = getMessageState(textValue,
11226
- /* @conditional-compile-remove(file-sharing) */ attachmentMetadata !== null && attachmentMetadata !== void 0 ? attachmentMetadata : []);
11252
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */ attachmentMetadata !== null && attachmentMetadata !== void 0 ? attachmentMetadata : []);
11227
11253
  const submitEnabled = messageState === 'OK';
11228
11254
  const editContainerStyles = useChatMessageEditContainerStyles();
11229
11255
  const chatMyMessageStyles = useChatMyMessageStyles();
@@ -11250,7 +11276,7 @@ const ChatMessageComponentAsEditBox = (props) => {
11250
11276
  const editBoxStyles = React.useMemo(() => {
11251
11277
  return react.concatStyleSets(editBoxStyleSet, { textField: { borderColor: theme.palette.themePrimary } });
11252
11278
  }, [theme.palette.themePrimary]);
11253
- /* @conditional-compile-remove(file-sharing) */
11279
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
11254
11280
  const onRenderFileUploads = React.useCallback(() => {
11255
11281
  return (!!attachmentMetadata &&
11256
11282
  attachmentMetadata.length > 0 && (React.createElement("div", { style: { margin: '0.25rem' } },
@@ -11271,7 +11297,7 @@ const ChatMessageComponentAsEditBox = (props) => {
11271
11297
  }, onEnterKeyDown: () => {
11272
11298
  submitEnabled &&
11273
11299
  onSubmit(textValue, message.metadata,
11274
- /* @conditional-compile-remove(file-sharing) */ {
11300
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */ {
11275
11301
  attachmentMetadata
11276
11302
  });
11277
11303
  }, supportNewline: false, maxLength: MAXIMUM_LENGTH_OF_MESSAGE, errorMessage: textTooLongMessage, styles: editBoxStyles,
@@ -11288,12 +11314,12 @@ const ChatMessageComponentAsEditBox = (props) => {
11288
11314
  React.createElement(InputBoxButton, { className: editingButtonStyle, ariaLabel: strings.editBoxSubmitButton, tooltipContent: strings.editBoxSubmitButton, onRenderIcon: onRenderThemedSubmitIcon, onClick: (e) => {
11289
11315
  submitEnabled &&
11290
11316
  onSubmit(textValue, message.metadata,
11291
- /* @conditional-compile-remove(file-sharing) */ {
11317
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */ {
11292
11318
  attachmentMetadata
11293
11319
  });
11294
11320
  e.stopPropagation();
11295
- }, id: 'submitIconWrapper' }))), /* @conditional-compile-remove(file-sharing) */
11296
- onRenderFileUploads()));
11321
+ }, id: 'submitIconWrapper' }))),
11322
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */ onRenderFileUploads()));
11297
11323
  };
11298
11324
  const attached = message.attached === true ? 'center' : message.attached === 'bottom' ? 'bottom' : 'top';
11299
11325
  return (React.createElement(reactChat.ChatMyMessage, { attached: attached, root: {
@@ -11649,7 +11675,6 @@ var __awaiter$C = (window && window.__awaiter) || function (thisArg, _arguments,
11649
11675
  const attachmentDownloadCardsStyle = {
11650
11676
  marginTop: '0.25rem'
11651
11677
  };
11652
- const actionIconStyle = { height: '1rem' };
11653
11678
  /**
11654
11679
  * @internal
11655
11680
  */
@@ -11664,13 +11689,13 @@ const _AttachmentDownloadCards = (props) => {
11664
11689
  }, [(_a = props.strings) === null || _a === void 0 ? void 0 : _a.downloadAttachment, localeStrings.downloadAttachment]);
11665
11690
  const isShowDownloadIcon = React.useCallback((attachment) => {
11666
11691
  var _a;
11667
- /* @conditional-compile-remove(file-sharing) */
11692
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
11668
11693
  return ((_a = attachment.payload) === null || _a === void 0 ? void 0 : _a.teamsFileAttachment) !== 'true';
11669
11694
  }, []);
11670
11695
  const attachmentCardGroupDescription = React.useMemo(() => () => {
11671
11696
  var _a, _b, _c;
11672
11697
  const fileGroupLocaleString = (_b = (_a = props.strings) === null || _a === void 0 ? void 0 : _a.attachmentCardGroupMessage) !== null && _b !== void 0 ? _b : localeStrings.attachmentCardGroupMessage;
11673
- /* @conditional-compile-remove(file-sharing) */
11698
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
11674
11699
  return _formatString(fileGroupLocaleString, {
11675
11700
  attachmentCount: `${(_c = fileMetadata === null || fileMetadata === void 0 ? void 0 : fileMetadata.length) !== null && _c !== void 0 ? _c : 0}`
11676
11701
  });
@@ -11702,18 +11727,17 @@ const _AttachmentDownloadCards = (props) => {
11702
11727
  return (React.createElement("div", { style: attachmentDownloadCardsStyle, "data-ui-id": "file-download-card-group" },
11703
11728
  React.createElement(_AttachmentCardGroup, { ariaLabel: attachmentCardGroupDescription() }, fileMetadata &&
11704
11729
  fileMetadata.map((attachment) => (React.createElement(react.TooltipHost, { content: downloadAttachmentButtonString(), key: attachment.name },
11705
- React.createElement(_AttachmentCard, { attachmentName: attachment.name, key: attachment.name, attachmentExtension: attachment.extension, actionIcon: showSpinner ? (React.createElement(react.Spinner, { size: react.SpinnerSize.medium, "aria-live": 'polite', role: 'status' })) : isShowDownloadIcon(attachment) ? (React.createElement(react.IconButton, { className: iconButtonClassName, ariaLabel: downloadAttachmentButtonString() },
11706
- React.createElement(DownloadIconTrampoline, null))) : undefined, actionHandler: () => fileDownloadHandler(userId, attachment) })))))));
11730
+ React.createElement(_AttachmentCard, { attachmentName: attachment.name, key: attachment.name, attachmentExtension: attachment.extension, actionIcon: showSpinner ? (React.createElement(react.Spinner, { size: react.SpinnerSize.medium, "aria-live": 'polite', role: 'status' })) : isShowDownloadIcon(attachment) ? (React.createElement(DownloadIconTrampoline, null)) : (React.createElement(reactIcons.Open20Regular, null)), actionHandler: () => fileDownloadHandler(userId, attachment) })))))));
11707
11731
  };
11708
11732
  /**
11709
11733
  * @private
11710
11734
  */
11711
11735
  const DownloadIconTrampoline = () => {
11712
- // @conditional-compile-remove(file-sharing)
11713
- return React.createElement(react.Icon, { "data-ui-id": "file-download-card-download-icon", iconName: "DownloadFile", style: actionIconStyle });
11736
+ // @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload)
11737
+ return React.createElement(reactIcons.ArrowDownload20Regular, { "data-ui-id": 'file-download-card-download-icon' });
11714
11738
  };
11715
11739
  const useLocaleStringsTrampoline = () => {
11716
- /* @conditional-compile-remove(file-sharing) */
11740
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
11717
11741
  return useLocale$1().strings.messageThread;
11718
11742
  };
11719
11743
 
@@ -11810,11 +11834,11 @@ const getFluentUIAttachedValue = (messageAttachedStatus) => {
11810
11834
  * Get the message bubble content for the message.
11811
11835
  */
11812
11836
  function getMessageBubbleContent(message, strings, userId, inlineImageOptions,
11813
- /* @conditional-compile-remove(file-sharing) */
11837
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
11814
11838
  onRenderFileDownloads,
11815
11839
  /* @conditional-compile-remove(mention) */
11816
11840
  mentionDisplayOptions,
11817
- /* @conditional-compile-remove(file-sharing) */
11841
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
11818
11842
  fileDownloadHandler) {
11819
11843
  /* @conditional-compile-remove(data-loss-prevention) */
11820
11844
  if (message.messageType === 'blocked') {
@@ -11825,25 +11849,25 @@ fileDownloadHandler) {
11825
11849
  React.createElement(ChatMessageContent, { message: message, strings: strings,
11826
11850
  /* @conditional-compile-remove(mention) */
11827
11851
  mentionDisplayOptions: mentionDisplayOptions, inlineImageOptions: inlineImageOptions }),
11828
- /* @conditional-compile-remove(file-sharing) */ onRenderFileDownloads
11852
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */ onRenderFileDownloads
11829
11853
  ? onRenderFileDownloads(userId, message)
11830
11854
  : defaultOnRenderFileDownloads(userId, message, strings,
11831
- /* @conditional-compile-remove(file-sharing) */ fileDownloadHandler)));
11855
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */ fileDownloadHandler)));
11832
11856
  }
11833
11857
  /**
11834
11858
  * Default component for rendering file downloads.
11835
11859
  */
11836
- /* @conditional-compile-remove(file-sharing) */
11860
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
11837
11861
  const defaultOnRenderFileDownloads = (userId, message, strings,
11838
- /* @conditional-compile-remove(file-sharing) */
11862
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
11839
11863
  fileDownloadHandler) => {
11840
- /* @conditional-compile-remove(file-sharing) */
11864
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
11841
11865
  return (React.createElement(_AttachmentDownloadCards, { userId: userId,
11842
- /* @conditional-compile-remove(file-sharing) */
11866
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
11843
11867
  fileMetadata: message.files || [],
11844
- /* @conditional-compile-remove(file-sharing) */
11868
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
11845
11869
  downloadHandler: fileDownloadHandler,
11846
- /* @conditional-compile-remove(file-sharing) */
11870
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
11847
11871
  strings: {
11848
11872
  downloadAttachment: strings.downloadAttachment,
11849
11873
  attachmentCardGroupMessage: strings.attachmentCardGroupMessage
@@ -11887,9 +11911,9 @@ const MessageBubble$1 = (props) => {
11887
11911
  const theme = useTheme();
11888
11912
  const locale = useLocale$1();
11889
11913
  const { userId, message, onRemoveClick, onResendClick, disableEditing, showDate, messageContainerStyle, strings, onEditClick, remoteParticipantsCount = 0, onRenderAvatar, showMessageStatus, messageStatus,
11890
- /* @conditional-compile-remove(file-sharing) */
11914
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
11891
11915
  fileDownloadHandler, inlineImageOptions,
11892
- /* @conditional-compile-remove(file-sharing) */
11916
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
11893
11917
  onRenderFileDownloads,
11894
11918
  /* @conditional-compile-remove(mention) */
11895
11919
  mentionDisplayOptions, onDisplayDateTimeString } = props;
@@ -11945,18 +11969,18 @@ const MessageBubble$1 = (props) => {
11945
11969
  }, [message, messageStatus, strings.editedTag, strings.failToSendTag, theme]);
11946
11970
  const getContent = React.useCallback(() => {
11947
11971
  return getMessageBubbleContent(message, strings, userId, inlineImageOptions,
11948
- /* @conditional-compile-remove(file-sharing) */
11972
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
11949
11973
  onRenderFileDownloads,
11950
11974
  /* @conditional-compile-remove(mention) */
11951
11975
  mentionDisplayOptions,
11952
- /* @conditional-compile-remove(file-sharing) */
11976
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
11953
11977
  fileDownloadHandler);
11954
11978
  }, [
11955
- /* @conditional-compile-remove(file-sharing) */ fileDownloadHandler,
11979
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */ fileDownloadHandler,
11956
11980
  inlineImageOptions,
11957
11981
  /* @conditional-compile-remove(mention) */ mentionDisplayOptions,
11958
11982
  message,
11959
- /* @conditional-compile-remove(file-sharing) */ onRenderFileDownloads,
11983
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */ onRenderFileDownloads,
11960
11984
  strings,
11961
11985
  userId
11962
11986
  ]);
@@ -12095,30 +12119,32 @@ const FluentChatMyMessageComponent = (props) => {
12095
12119
  onDisplayDateTimeString, inlineImageOptions,
12096
12120
  /* @conditional-compile-remove(mention) */
12097
12121
  mentionOptions,
12098
- /* @conditional-compile-remove(file-sharing) */
12122
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
12099
12123
  fileDownloadHandler, userId,
12100
- /* @conditional-compile-remove(file-sharing) */
12124
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
12101
12125
  onRenderFileDownloads, defaultStatusRenderer, statusToRender } = props;
12102
12126
  const chatMessageRenderStyles = useChatMessageRenderStyles();
12103
12127
  const onRenderFileDownloadsMemo = React.useMemo(() => {
12104
- /* @conditional-compile-remove(file-sharing) */
12128
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
12105
12129
  return onRenderFileDownloads;
12106
- }, [/* @conditional-compile-remove(file-sharing) */ onRenderFileDownloads]);
12130
+ }, [
12131
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */ onRenderFileDownloads
12132
+ ]);
12107
12133
  // To rerender the defaultChatMessageRenderer if app running across days(every new day chat time stamp
12108
12134
  // needs to be regenerated), the dependency on "new Date().toDateString()"" is added.
12109
12135
  const defaultChatMessageRenderer = React.useCallback((messageProps) => {
12110
12136
  if (messageProps.message.messageType === 'chat' ||
12111
12137
  /* @conditional-compile-remove(data-loss-prevention) */ messageProps.message.messageType === 'blocked') {
12112
12138
  return (React.createElement(ChatMyMessageComponent, Object.assign({}, messageProps, {
12113
- /* @conditional-compile-remove(file-sharing) */
12139
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
12114
12140
  onRenderFileDownloads: onRenderFileDownloadsMemo,
12115
- /* @conditional-compile-remove(file-sharing) */
12141
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
12116
12142
  strings: messageProps.strings, message: messageProps.message, userId: userId, remoteParticipantsCount: participantCount ? participantCount - 1 : 0, shouldOverlapAvatarAndMessage: shouldOverlapAvatarAndMessage, onRenderAvatar: onRenderAvatar, showMessageStatus: showMessageStatus, messageStatus: messageProps.message.status, onActionButtonClick: onActionButtonClick,
12117
12143
  /* @conditional-compile-remove(date-time-customization) */
12118
12144
  onDisplayDateTimeString: onDisplayDateTimeString, inlineImageOptions: inlineImageOptions,
12119
12145
  /* @conditional-compile-remove(mention) */
12120
12146
  mentionOptions: mentionOptions,
12121
- /* @conditional-compile-remove(file-sharing) */
12147
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
12122
12148
  fileDownloadHandler: fileDownloadHandler })));
12123
12149
  }
12124
12150
  return React.createElement(React.Fragment, null);
@@ -12135,7 +12161,7 @@ const FluentChatMyMessageComponent = (props) => {
12135
12161
  inlineImageOptions,
12136
12162
  /* @conditional-compile-remove(mention) */
12137
12163
  mentionOptions,
12138
- /* @conditional-compile-remove(file-sharing) */
12164
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
12139
12165
  fileDownloadHandler,
12140
12166
  // eslint-disable-next-line react-hooks/exhaustive-deps
12141
12167
  new Date().toDateString()
@@ -12201,9 +12227,9 @@ const MessageBubble = (props) => {
12201
12227
  const theme = useTheme();
12202
12228
  const locale = useLocale$1();
12203
12229
  const { userId, message, showDate, messageContainerStyle, strings,
12204
- /* @conditional-compile-remove(file-sharing) */
12230
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
12205
12231
  fileDownloadHandler, inlineImageOptions, shouldOverlapAvatarAndMessage,
12206
- /* @conditional-compile-remove(file-sharing) */
12232
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
12207
12233
  onRenderFileDownloads,
12208
12234
  /* @conditional-compile-remove(mention) */
12209
12235
  mentionDisplayOptions, onDisplayDateTimeString } = props;
@@ -12221,18 +12247,18 @@ const MessageBubble = (props) => {
12221
12247
  }, [strings.editedTag, theme, message]);
12222
12248
  const getContent = React.useCallback(() => {
12223
12249
  return getMessageBubbleContent(message, strings, userId, inlineImageOptions,
12224
- /* @conditional-compile-remove(file-sharing) */
12250
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
12225
12251
  onRenderFileDownloads,
12226
12252
  /* @conditional-compile-remove(mention) */
12227
12253
  mentionDisplayOptions,
12228
- /* @conditional-compile-remove(file-sharing) */
12254
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
12229
12255
  fileDownloadHandler);
12230
12256
  }, [
12231
- /* @conditional-compile-remove(file-sharing) */ fileDownloadHandler,
12257
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */ fileDownloadHandler,
12232
12258
  inlineImageOptions,
12233
12259
  /* @conditional-compile-remove(mention) */ mentionDisplayOptions,
12234
12260
  message,
12235
- /* @conditional-compile-remove(file-sharing) */ onRenderFileDownloads,
12261
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */ onRenderFileDownloads,
12236
12262
  strings,
12237
12263
  userId
12238
12264
  ]);
@@ -12282,30 +12308,32 @@ const FluentChatMessageComponent = (props) => {
12282
12308
  const { message, styles, shouldOverlapAvatarAndMessage, onRenderMessage, onRenderAvatar,
12283
12309
  /* @conditional-compile-remove(date-time-customization) */
12284
12310
  onDisplayDateTimeString, inlineImageOptions,
12285
- /* @conditional-compile-remove(file-sharing) */
12311
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
12286
12312
  fileDownloadHandler, userId,
12287
- /* @conditional-compile-remove(file-sharing) */
12313
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
12288
12314
  onRenderFileDownloads,
12289
12315
  /* @conditional-compile-remove(mention) */
12290
12316
  mentionOptions } = props;
12291
12317
  const chatMessageRenderStyles = useChatMessageRenderStyles();
12292
12318
  const onRenderFileDownloadsMemo = React.useMemo(() => {
12293
- /* @conditional-compile-remove(file-sharing) */
12319
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
12294
12320
  return onRenderFileDownloads;
12295
- }, [/* @conditional-compile-remove(file-sharing) */ onRenderFileDownloads]);
12321
+ }, [
12322
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */ onRenderFileDownloads
12323
+ ]);
12296
12324
  // To rerender the defaultChatMessageRenderer if app running across days(every new day chat time stamp
12297
12325
  // needs to be regenerated), the dependency on "new Date().toDateString()"" is added.
12298
12326
  const defaultChatMessageRenderer = React.useCallback((messageProps) => {
12299
12327
  if (messageProps.message.messageType === 'chat' ||
12300
12328
  /* @conditional-compile-remove(data-loss-prevention) */ messageProps.message.messageType === 'blocked') {
12301
12329
  return (React.createElement(ChatMessageComponentAsMessageBubble, Object.assign({}, messageProps, {
12302
- /* @conditional-compile-remove(file-sharing) */
12330
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
12303
12331
  onRenderFileDownloads: onRenderFileDownloadsMemo,
12304
- /* @conditional-compile-remove(file-sharing) */
12332
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
12305
12333
  strings: messageProps.strings, message: messageProps.message, userId: userId, shouldOverlapAvatarAndMessage: shouldOverlapAvatarAndMessage,
12306
12334
  /* @conditional-compile-remove(date-time-customization) */
12307
12335
  onDisplayDateTimeString: onDisplayDateTimeString, inlineImageOptions: inlineImageOptions,
12308
- /* @conditional-compile-remove(file-sharing) */
12336
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
12309
12337
  fileDownloadHandler: fileDownloadHandler,
12310
12338
  /* @conditional-compile-remove(mention) */
12311
12339
  mentionDisplayOptions: mentionOptions === null || mentionOptions === void 0 ? void 0 : mentionOptions.displayOptions })));
@@ -12318,7 +12346,7 @@ const FluentChatMessageComponent = (props) => {
12318
12346
  /* @conditional-compile-remove(date-time-customization) */
12319
12347
  onDisplayDateTimeString,
12320
12348
  inlineImageOptions,
12321
- /* @conditional-compile-remove(file-sharing) */
12349
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
12322
12350
  fileDownloadHandler,
12323
12351
  /* @conditional-compile-remove(mention) */
12324
12352
  mentionOptions,
@@ -12592,7 +12620,7 @@ const MessageThreadWrapper = (props) => {
12592
12620
  onDisplayDateTimeString,
12593
12621
  /* @conditional-compile-remove(mention) */
12594
12622
  mentionOptions, inlineImageOptions,
12595
- /* @conditional-compile-remove(file-sharing) */
12623
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
12596
12624
  onRenderFileDownloads } = props;
12597
12625
  // We need this state to wait for one tick and scroll to bottom after messages have been initialized.
12598
12626
  // Otherwise chatScrollDivRef.current.clientHeight is wrong if we scroll to bottom before messages are initialized.
@@ -12927,13 +12955,13 @@ const MessageThreadWrapper = (props) => {
12927
12955
  // styles?.chatContainer used in className and style prop as style prop can't handle CSS selectors
12928
12956
  className: reactComponents.mergeClasses(classes.root, react.mergeStyles(styles === null || styles === void 0 ? void 0 : styles.chatContainer)), ref: chatScrollDivRef, style: Object.assign({}, createStyleFromV8Style(styles === null || styles === void 0 ? void 0 : styles.chatContainer)) }, messagesToDisplay.map((message) => {
12929
12957
  return (React.createElement(MemoChatMessageComponentWrapper, Object.assign({}, message, { userId: userId, key: message.key, styles: styles, shouldOverlapAvatarAndMessage: isNarrow, strings: strings, onRenderAvatar: onRenderAvatar, onRenderMessage: onRenderMessage, onRenderMessageStatus: onRenderMessageStatus, defaultStatusRenderer: defaultStatusRenderer, onActionButtonClick: onActionButtonClickMemo, readCount: readCountForHoveredIndicator, participantCount: participantCount,
12930
- /* @conditional-compile-remove(file-sharing) */
12958
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
12931
12959
  fileDownloadHandler: props.fileDownloadHandler, inlineImageOptions: inlineImageOptions,
12932
12960
  /* @conditional-compile-remove(date-time-customization) */
12933
12961
  onDisplayDateTimeString: onDisplayDateTimeString,
12934
12962
  /* @conditional-compile-remove(mention) */
12935
12963
  mentionOptions: mentionOptions,
12936
- /* @conditional-compile-remove(file-sharing) */
12964
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
12937
12965
  onRenderFileDownloads: onRenderFileDownloads })));
12938
12966
  }))))));
12939
12967
  };
@@ -22786,7 +22814,7 @@ const memoizedAllConvertChatMessage = memoizeFnAll((_key, chatMessage, userId, i
22786
22814
  return convertToUiSystemMessage(chatMessage);
22787
22815
  }
22788
22816
  });
22789
- /* @conditional-compile-remove(file-sharing) */
22817
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
22790
22818
  const extractAttachedFilesMetadata = (metadata) => {
22791
22819
  const fileMetadata = metadata.fileSharingMetadata;
22792
22820
  if (!fileMetadata) {
@@ -22800,7 +22828,7 @@ const extractAttachedFilesMetadata = (metadata) => {
22800
22828
  return [];
22801
22829
  }
22802
22830
  };
22803
- /* @conditional-compile-remove(file-sharing) */
22831
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
22804
22832
  const extractTeamsAttachmentsMetadata = (attachments) => {
22805
22833
  const files = [];
22806
22834
  attachments.forEach((attachment) => {
@@ -22837,7 +22865,7 @@ const convertToUiBlockedMessage = (message, userId, isSeen, isLargeGroup) => {
22837
22865
  link: DEFAULT_DATA_LOSS_PREVENTION_POLICY_URL
22838
22866
  };
22839
22867
  };
22840
- /* @conditional-compile-remove(file-sharing) */
22868
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
22841
22869
  const extractAttachmentUrl = (attachment) => {
22842
22870
  return attachment.previewUrl ? attachment.previewUrl : attachment.url || '';
22843
22871
  };
@@ -22910,7 +22938,7 @@ const extractAttachmentContentTypeFromName = (name) => {
22910
22938
  const contentType = name.substring(indexOfLastDot + 1);
22911
22939
  return contentType;
22912
22940
  };
22913
- /* @conditional-compile-remove(file-sharing) */
22941
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
22914
22942
  const extractAttachmentsMetadata = (message) => {
22915
22943
  var _a, _b;
22916
22944
  let files = [];
@@ -22925,7 +22953,7 @@ const extractAttachmentsMetadata = (message) => {
22925
22953
  };
22926
22954
  const convertToUiChatMessage = (message, userId, isSeen, isLargeGroup) => {
22927
22955
  const messageSenderId = message.sender !== undefined ? toFlatCommunicationIdentifier(message.sender) : userId;
22928
- /* @conditional-compile-remove(file-sharing) */
22956
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
22929
22957
  const { files } = extractAttachmentsMetadata(message);
22930
22958
  return {
22931
22959
  messageType: 'chat',
@@ -22941,7 +22969,7 @@ const convertToUiChatMessage = (message, userId, isSeen, isLargeGroup) => {
22941
22969
  deletedOn: message.deletedOn,
22942
22970
  mine: messageSenderId === userId,
22943
22971
  metadata: message.metadata,
22944
- /* @conditional-compile-remove(file-sharing) */
22972
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
22945
22973
  files
22946
22974
  };
22947
22975
  };
@@ -24683,7 +24711,7 @@ const COMPOSITE_ONLY_ICONS = {
24683
24711
  NoticePageRoomNotValid: React.createElement(reactIcons.Info20Filled, null),
24684
24712
  NoticePageCallRejected: React.createElement(reactIcons.Info20Filled, null),
24685
24713
  NoticePageCallTimeout: React.createElement(reactIcons.Info20Filled, null),
24686
- /* @conditional-compile-remove(file-sharing) */
24714
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
24687
24715
  SendBoxAttachFile: React.createElement(reactIcons.Attach20Regular, null),
24688
24716
  /* @conditional-compile-remove(PSTN-calls) */
24689
24717
  PeoplePaneAddPerson: React.createElement(reactIcons.PersonAdd20Regular, null),
@@ -24818,7 +24846,7 @@ const FileUploadButton = (props) => {
24818
24846
  } })));
24819
24847
  };
24820
24848
  const SendBoxAttachFileIconTrampoline = () => {
24821
- // @conditional-compile-remove(file-sharing)
24849
+ // @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload)
24822
24850
  return React.createElement(ChatCompositeIcon, { iconName: "SendBoxAttachFile" });
24823
24851
  };
24824
24852
  /**
@@ -24831,19 +24859,19 @@ const FileUploadButtonWrapper = (
24831
24859
  // eslint-disable-next-line @typescript-eslint/no-unused-vars
24832
24860
  props) => {
24833
24861
  return (React.createElement(React.Fragment, null,
24834
- /* @conditional-compile-remove(file-sharing) */
24862
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
24835
24863
  React.createElement(FileUploadButton, Object.assign({}, props))));
24836
24864
  };
24837
24865
  const uploadFileButtonStringTrampoline = () => {
24838
- //@conditional-compile-remove(file-sharing)
24866
+ //@conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload)
24839
24867
  //eslint-disable-next-line react-hooks/rules-of-hooks
24840
24868
  return useLocale().strings.chat.uploadFile;
24841
24869
  };
24842
24870
 
24843
24871
  // Copyright (c) Microsoft Corporation.
24844
24872
  // Licensed under the MIT License.
24845
- /* @conditional-compile-remove(file-sharing) */
24846
- /* @conditional-compile-remove(file-sharing) */
24873
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
24874
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
24847
24875
  /**
24848
24876
  * @internal
24849
24877
  */
@@ -24883,7 +24911,7 @@ class FileUploadContext {
24883
24911
  }));
24884
24912
  }
24885
24913
  }
24886
- /* @conditional-compile-remove(file-sharing) */
24914
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
24887
24915
  /**
24888
24916
  * @internal
24889
24917
  */
@@ -24961,7 +24989,7 @@ class AzureCommunicationFileUploadAdapter {
24961
24989
  fileUpload === null || fileUpload === void 0 ? void 0 : fileUpload.off('uploadFail', this.updateFileUploadErrorMessage.bind(this));
24962
24990
  }
24963
24991
  }
24964
- /* @conditional-compile-remove(file-sharing) */
24992
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
24965
24993
  /**
24966
24994
  * @param fileUploadUiState {@link FileUploadsUiState}
24967
24995
  * @private
@@ -24981,7 +25009,7 @@ const convertFileUploadsUiStateToMessageMetadata = (fileUploads) => {
24981
25009
  }
24982
25010
  return undefined;
24983
25011
  };
24984
- /* @conditional-compile-remove(file-sharing) */
25012
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
24985
25013
  /**
24986
25014
  * @private
24987
25015
  */
@@ -25061,7 +25089,7 @@ class ChatContext {
25061
25089
  thread,
25062
25090
  latestErrors: clientState.latestErrors
25063
25091
  };
25064
- /* @conditional-compile-remove(file-sharing) */
25092
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
25065
25093
  updatedState = Object.assign(Object.assign({}, updatedState), { fileUploads: this.state.fileUploads });
25066
25094
  this.setState(updatedState);
25067
25095
  }
@@ -25076,7 +25104,7 @@ class AzureCommunicationChatAdapter {
25076
25104
  this.chatClient = chatClient;
25077
25105
  this.chatThreadClient = chatThreadClient;
25078
25106
  this.context = new ChatContext(chatClient.getState(), chatThreadClient.threadId);
25079
- /* @conditional-compile-remove(file-sharing) */
25107
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
25080
25108
  this.fileUploadAdapter = new AzureCommunicationFileUploadAdapter(this.context);
25081
25109
  const onStateChange = (clientState) => {
25082
25110
  // unsubscribe when the instance gets disposed
@@ -25106,19 +25134,19 @@ class AzureCommunicationChatAdapter {
25106
25134
  this.loadPreviousChatMessages = this.loadPreviousChatMessages.bind(this);
25107
25135
  this.on = this.on.bind(this);
25108
25136
  this.off = this.off.bind(this);
25109
- /* @conditional-compile-remove(file-sharing) */
25137
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
25110
25138
  this.registerActiveFileUploads = this.registerActiveFileUploads.bind(this);
25111
- /* @conditional-compile-remove(file-sharing) */
25139
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
25112
25140
  this.registerCompletedFileUploads = this.registerCompletedFileUploads.bind(this);
25113
- /* @conditional-compile-remove(file-sharing) */
25141
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
25114
25142
  this.clearFileUploads = this.clearFileUploads.bind(this);
25115
- /* @conditional-compile-remove(file-sharing) */
25143
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
25116
25144
  this.cancelFileUpload = this.cancelFileUpload.bind(this);
25117
- /* @conditional-compile-remove(file-sharing) */
25145
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
25118
25146
  this.updateFileUploadProgress = this.updateFileUploadProgress.bind(this);
25119
- /* @conditional-compile-remove(file-sharing) */
25147
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
25120
25148
  this.updateFileUploadErrorMessage = this.updateFileUploadErrorMessage.bind(this);
25121
- /* @conditional-compile-remove(file-sharing) */
25149
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
25122
25150
  this.updateFileUploadMetadata = this.updateFileUploadMetadata.bind(this);
25123
25151
  this.downloadResourceToCache = this.downloadResourceToCache.bind(this);
25124
25152
  this.removeResourceFromCache = this.removeResourceFromCache.bind(this);
@@ -25168,9 +25196,9 @@ class AzureCommunicationChatAdapter {
25168
25196
  sendMessage(content_1) {
25169
25197
  return __awaiter$n(this, arguments, void 0, function* (content, options = {}) {
25170
25198
  yield this.asyncTeeErrorToEventEmitter(() => __awaiter$n(this, void 0, void 0, function* () {
25171
- /* @conditional-compile-remove(file-sharing) */
25199
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
25172
25200
  options.metadata = Object.assign(Object.assign({}, options.metadata), convertFileUploadsUiStateToMessageMetadata(this.context.getState().fileUploads));
25173
- /* @conditional-compile-remove(file-sharing) */
25201
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
25174
25202
  /**
25175
25203
  * All the current uploads need to be clear from the state before a message has been sent.
25176
25204
  * This ensures the following behavior:
@@ -25221,9 +25249,9 @@ class AzureCommunicationChatAdapter {
25221
25249
  updateMessage(messageId, content, metadata, options) {
25222
25250
  return __awaiter$n(this, void 0, void 0, function* () {
25223
25251
  return yield this.asyncTeeErrorToEventEmitter(() => __awaiter$n(this, void 0, void 0, function* () {
25224
- /* @conditional-compile-remove(file-sharing) */
25252
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
25225
25253
  const updatedOptions = { attachmentMetadata: options === null || options === void 0 ? void 0 : options.attachmentMetadata, metadata: metadata };
25226
- /* @conditional-compile-remove(file-sharing) */
25254
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
25227
25255
  return yield this.handlers.onUpdateMessage(messageId, content, updatedOptions);
25228
25256
  }));
25229
25257
  });
@@ -25235,31 +25263,31 @@ class AzureCommunicationChatAdapter {
25235
25263
  }));
25236
25264
  });
25237
25265
  }
25238
- /* @conditional-compile-remove(file-sharing) */
25266
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
25239
25267
  registerActiveFileUploads(files) {
25240
25268
  return this.fileUploadAdapter.registerActiveFileUploads(files);
25241
25269
  }
25242
- /* @conditional-compile-remove(file-sharing) */
25270
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
25243
25271
  registerCompletedFileUploads(metadata) {
25244
25272
  return this.fileUploadAdapter.registerCompletedFileUploads(metadata);
25245
25273
  }
25246
- /* @conditional-compile-remove(file-sharing) */
25274
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
25247
25275
  clearFileUploads() {
25248
25276
  this.fileUploadAdapter.clearFileUploads();
25249
25277
  }
25250
- /* @conditional-compile-remove(file-sharing) */
25278
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
25251
25279
  cancelFileUpload(id) {
25252
25280
  this.fileUploadAdapter.cancelFileUpload(id);
25253
25281
  }
25254
- /* @conditional-compile-remove(file-sharing) */
25282
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
25255
25283
  updateFileUploadProgress(id, progress) {
25256
25284
  this.fileUploadAdapter.updateFileUploadProgress(id, progress);
25257
25285
  }
25258
- /* @conditional-compile-remove(file-sharing) */
25286
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
25259
25287
  updateFileUploadErrorMessage(id, errorMessage) {
25260
25288
  this.fileUploadAdapter.updateFileUploadErrorMessage(id, errorMessage);
25261
25289
  }
25262
- /* @conditional-compile-remove(file-sharing) */
25290
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
25263
25291
  updateFileUploadMetadata(id, metadata) {
25264
25292
  this.fileUploadAdapter.updateFileUploadMetadata(id, metadata);
25265
25293
  }
@@ -25922,13 +25950,13 @@ const createCompositeHandlers$1 = memoizeOne((adapter) => ({
25922
25950
  onRemoveParticipant: adapter.removeParticipant,
25923
25951
  updateThreadTopicName: adapter.setTopic,
25924
25952
  onUpdateMessage: (messageId, content,
25925
- /* @conditional-compile-remove(file-sharing) */
25953
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
25926
25954
  options) => {
25927
25955
  const metadata = options === null || options === void 0 ? void 0 : options.metadata;
25928
- /* @conditional-compile-remove(file-sharing) */
25956
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
25929
25957
  const updatedOptions = (options === null || options === void 0 ? void 0 : options.attachmentMetadata) ? Object.assign({}, options.attachmentMetadata) : {};
25930
25958
  return adapter.updateMessage(messageId, content, metadata,
25931
- /* @conditional-compile-remove(file-sharing) */ updatedOptions);
25959
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */ updatedOptions);
25932
25960
  },
25933
25961
  onDeleteMessage: adapter.deleteMessage
25934
25962
  }));
@@ -26198,7 +26226,7 @@ const FileDownloadErrorBar = (props) => {
26198
26226
  * @private
26199
26227
  */
26200
26228
  const getFileUploads = (state) => {
26201
- /* @conditional-compile-remove(file-sharing) */
26229
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
26202
26230
  return state === null || state === void 0 ? void 0 : state.fileUploads;
26203
26231
  };
26204
26232
 
@@ -26225,30 +26253,30 @@ const useSelector$2 = (selector, selectorProps) => {
26225
26253
  // Copyright (c) Microsoft Corporation.
26226
26254
  // Licensed under the MIT License.
26227
26255
  /* @conditional-compile-remove(rich-text-editor) */
26228
- const RichTextSendBoxWrapper = React.lazy(() => Promise.resolve().then(function () { return require('./RichTextSendBoxWrapper-BRqOsupu.js'); }).then((module) => ({ default: module.RichTextSendBoxWrapper })));
26256
+ const RichTextSendBoxWrapper = React.lazy(() => Promise.resolve().then(function () { return require('./RichTextSendBoxWrapper-Yty3fOoA.js'); }).then((module) => ({ default: module.RichTextSendBoxWrapper })));
26229
26257
  /**
26230
26258
  * @private
26231
26259
  */
26232
26260
  const SendBox = (props) => {
26233
26261
  const { options, styles,
26234
- /* @conditional-compile-remove(file-sharing) */
26262
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
26235
26263
  adapter } = props;
26236
26264
  const sendBoxProps = usePropsFor$2(SendBox$1);
26237
- /* @conditional-compile-remove(file-sharing) */
26265
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
26238
26266
  const activeFileUploads = useSelector$2(fileUploadsSelector).files;
26239
26267
  const sendBoxStyles = React.useMemo(() => {
26240
26268
  return Object.assign({}, styles);
26241
26269
  }, [styles]);
26242
26270
  const simpleSendBox = React.useMemo(() => (React.createElement(SendBox$1, Object.assign({}, sendBoxProps, { autoFocus: options === null || options === void 0 ? void 0 : options.autoFocus, styles: sendBoxStyles,
26243
- /* @conditional-compile-remove(file-sharing) */
26271
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
26244
26272
  activeFileUploads: activeFileUploads,
26245
- /* @conditional-compile-remove(file-sharing) */
26273
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
26246
26274
  onCancelFileUpload: adapter.cancelFileUpload }))), [
26247
26275
  sendBoxProps,
26248
26276
  options,
26249
26277
  sendBoxStyles,
26250
- /* @conditional-compile-remove(file-sharing) */ activeFileUploads,
26251
- /* @conditional-compile-remove(file-sharing) */ adapter
26278
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */ activeFileUploads,
26279
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */ adapter
26252
26280
  ]);
26253
26281
  // /* @conditional-compile-remove(rich-text-editor) */
26254
26282
  if ((options === null || options === void 0 ? void 0 : options.richTextEditor) === true) {
@@ -26275,7 +26303,7 @@ var __awaiter$l = (window && window.__awaiter) || function (thisArg, _arguments,
26275
26303
  const ChatScreen = (props) => {
26276
26304
  const { onFetchAvatarPersonaData, onRenderMessage, onRenderTypingIndicator, options, styles, fileSharing, formFactor } = props;
26277
26305
  const defaultNumberOfChatMessagesToReload = 5;
26278
- /* @conditional-compile-remove(file-sharing) */
26306
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
26279
26307
  const [downloadErrorMessage, setDownloadErrorMessage] = React.useState('');
26280
26308
  const [overlayImageItem, setOverlayImageItem] = React.useState();
26281
26309
  const [isImageOverlayOpen, setIsImageOverlayOpen] = React.useState(false);
@@ -26338,12 +26366,12 @@ const ChatScreen = (props) => {
26338
26366
  if (!files) {
26339
26367
  return;
26340
26368
  }
26341
- /* @conditional-compile-remove(file-sharing) */
26369
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
26342
26370
  const fileUploads = adapter.registerActiveFileUploads(Array.from(files));
26343
- /* @conditional-compile-remove(file-sharing) */
26371
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
26344
26372
  fileSharing === null || fileSharing === void 0 ? void 0 : fileSharing.uploadHandler(userId, fileUploads);
26345
26373
  }, [adapter, fileSharing, userId]);
26346
- /* @conditional-compile-remove(file-sharing) */
26374
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
26347
26375
  const onRenderFileDownloads = React.useCallback((userId, message) => (React.createElement(_AttachmentDownloadCards, { userId: userId, fileMetadata: message.files || [], downloadHandler: fileSharing === null || fileSharing === void 0 ? void 0 : fileSharing.downloadHandler, onDownloadErrorMessage: (errorMessage) => {
26348
26376
  setDownloadErrorMessage(errorMessage);
26349
26377
  } })), [fileSharing === null || fileSharing === void 0 ? void 0 : fileSharing.downloadHandler]);
@@ -26445,12 +26473,12 @@ const ChatScreen = (props) => {
26445
26473
  React.createElement(react.Stack, { className: chatArea, tokens: participantListContainerPadding, horizontal: true, grow: true },
26446
26474
  React.createElement(react.Stack, { className: chatWrapper, grow: true },
26447
26475
  (options === null || options === void 0 ? void 0 : options.errorBar) !== false && React.createElement(ErrorBar, Object.assign({}, errorBarProps)),
26448
- /* @conditional-compile-remove(file-sharing) */
26476
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
26449
26477
  React.createElement(FileDownloadErrorBar, { onDismissDownloadErrorMessage: React.useCallback(() => {
26450
26478
  setDownloadErrorMessage('');
26451
26479
  }, []), fileDownloadErrorMessage: downloadErrorMessage || '' }),
26452
26480
  React.createElement(MessageThread, Object.assign({}, messageThreadProps, { onRenderAvatar: onRenderAvatarCallback, onRenderMessage: onRenderMessage,
26453
- /* @conditional-compile-remove(file-sharing) */
26481
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
26454
26482
  onRenderFileDownloads: onRenderFileDownloads, inlineImageOptions: inlineImageOptions, numberOfChatMessagesToReload: defaultNumberOfChatMessagesToReload, styles: messageThreadStyles })),
26455
26483
  React.createElement(react.Stack, { className: react.mergeStyles(sendboxContainerStyles) },
26456
26484
  React.createElement("div", { className: react.mergeStyles(typingIndicatorContainerStyles) }, onRenderTypingIndicator ? (onRenderTypingIndicator(typingIndicatorProps.typingUsers)) : (React.createElement(TypingIndicator, Object.assign({}, typingIndicatorProps, { styles: typingIndicatorStyles })))),
@@ -26459,7 +26487,7 @@ const ChatScreen = (props) => {
26459
26487
  React.createElement(AttachFileButton, null))),
26460
26488
  React.createElement(react.Stack, { grow: true },
26461
26489
  React.createElement(SendBox, { options: options, styles: styles === null || styles === void 0 ? void 0 : styles.sendBox,
26462
- /* @conditional-compile-remove(file-sharing) */
26490
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
26463
26491
  adapter: adapter })),
26464
26492
  formFactor !== 'mobile' && React.createElement(AttachFileButton, null)))),
26465
26493
  /* @conditional-compile-remove(chat-composite-participant-pane) */
@@ -26486,17 +26514,17 @@ const ChatScreen = (props) => {
26486
26514
  */
26487
26515
  const ChatComposite = (props) => {
26488
26516
  const { adapter, options, onFetchAvatarPersonaData, onRenderTypingIndicator, onRenderMessage, onFetchParticipantMenuItems } = props;
26489
- /* @conditional-compile-remove(file-sharing) */
26517
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
26490
26518
  const formFactor = props['formFactor'] || 'desktop';
26491
26519
  return (React.createElement("div", { className: chatScreenContainerStyle },
26492
26520
  React.createElement(BaseProvider, Object.assign({}, props),
26493
26521
  React.createElement(ChatAdapterProvider, { adapter: adapter },
26494
26522
  React.createElement(ChatScreen
26495
- /* @conditional-compile-remove(file-sharing) */
26523
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
26496
26524
  , {
26497
- /* @conditional-compile-remove(file-sharing) */
26525
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
26498
26526
  formFactor: formFactor, options: options, onFetchAvatarPersonaData: onFetchAvatarPersonaData, onRenderTypingIndicator: onRenderTypingIndicator, onRenderMessage: onRenderMessage, onFetchParticipantMenuItems: onFetchParticipantMenuItems,
26499
- /* @conditional-compile-remove(file-sharing) */
26527
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
26500
26528
  fileSharing: options === null || options === void 0 ? void 0 : options.fileSharing })))));
26501
26529
  };
26502
26530
 
@@ -36718,31 +36746,31 @@ class CallWithChatBackedChatAdapter {
36718
36746
  this.setTopic = (topicName) => __awaiter$3(this, void 0, void 0, function* () {
36719
36747
  throw new Error(`Chat Topics are not supported in CallWithChatComposite.`);
36720
36748
  });
36721
- /* @conditional-compile-remove(file-sharing) */
36749
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
36722
36750
  this.registerActiveFileUploads = (files) => {
36723
36751
  return this.callWithChatAdapter.registerActiveFileUploads(files);
36724
36752
  };
36725
- /* @conditional-compile-remove(file-sharing) */
36753
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
36726
36754
  this.registerCompletedFileUploads = (metadata) => {
36727
36755
  return this.callWithChatAdapter.registerCompletedFileUploads(metadata);
36728
36756
  };
36729
- /* @conditional-compile-remove(file-sharing) */
36757
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
36730
36758
  this.clearFileUploads = () => {
36731
36759
  this.callWithChatAdapter.clearFileUploads();
36732
36760
  };
36733
- /* @conditional-compile-remove(file-sharing) */
36761
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
36734
36762
  this.cancelFileUpload = (id) => {
36735
36763
  this.callWithChatAdapter.cancelFileUpload(id);
36736
36764
  };
36737
- /* @conditional-compile-remove(file-sharing) */
36765
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
36738
36766
  this.updateFileUploadProgress = (id, progress) => {
36739
36767
  this.callWithChatAdapter.updateFileUploadProgress(id, progress);
36740
36768
  };
36741
- /* @conditional-compile-remove(file-sharing) */
36769
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
36742
36770
  this.updateFileUploadErrorMessage = (id, errorMessage) => {
36743
36771
  this.callWithChatAdapter.updateFileUploadErrorMessage(id, errorMessage);
36744
36772
  };
36745
- /* @conditional-compile-remove(file-sharing) */
36773
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
36746
36774
  this.updateFileUploadMetadata = (id, metadata) => {
36747
36775
  this.callWithChatAdapter.updateFileUploadMetadata(id, metadata);
36748
36776
  };
@@ -36766,7 +36794,7 @@ function chatAdapterStateFromCallWithChatAdapterState(callWithChatAdapterState)
36766
36794
  displayName: callWithChatAdapterState.displayName || '',
36767
36795
  thread: callWithChatAdapterState.chat,
36768
36796
  latestErrors: callWithChatAdapterState.latestChatErrors,
36769
- /* @conditional-compile-remove(file-sharing) */
36797
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
36770
36798
  fileUploads: callWithChatAdapterState.fileUploads
36771
36799
  };
36772
36800
  }
@@ -37079,11 +37107,11 @@ const CallWithChatScreen = (props) => {
37079
37107
  topic: false,
37080
37108
  /* @conditional-compile-remove(chat-composite-participant-pane) */
37081
37109
  participantPane: false,
37082
- /* @conditional-compile-remove(file-sharing) */
37110
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
37083
37111
  fileSharing: props.fileSharing
37084
37112
  }, onFetchAvatarPersonaData: props.onFetchAvatarPersonaData })), [
37085
37113
  chatAdapter,
37086
- /* @conditional-compile-remove(file-sharing) */ props.fileSharing,
37114
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */ props.fileSharing,
37087
37115
  props.onFetchAvatarPersonaData,
37088
37116
  theme
37089
37117
  ]);
@@ -37133,7 +37161,7 @@ const CallWithChatComposite = (props) => {
37133
37161
  React.createElement(CallWithChatScreen, Object.assign({}, props, {
37134
37162
  /* @conditional-compile-remove(call-readiness) */
37135
37163
  deviceChecks: options === null || options === void 0 ? void 0 : options.deviceChecks, callWithChatAdapter: adapter, formFactor: formFactor, callControls: options === null || options === void 0 ? void 0 : options.callControls, joinInvitationURL: joinInvitationURL, fluentTheme: fluentTheme, remoteVideoTileMenuOptions: options === null || options === void 0 ? void 0 : options.remoteVideoTileMenuOptions,
37136
- /* @conditional-compile-remove(file-sharing) */
37164
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
37137
37165
  fileSharing: options === null || options === void 0 ? void 0 : options.fileSharing, localVideoTile: options === null || options === void 0 ? void 0 : options.localVideoTile, galleryOptions: options === null || options === void 0 ? void 0 : options.galleryOptions,
37138
37166
  /* @conditional-compile-remove(custom-branding) */
37139
37167
  logo: (_a = options === null || options === void 0 ? void 0 : options.branding) === null || _a === void 0 ? void 0 : _a.logo,
@@ -37186,7 +37214,7 @@ function callWithChatAdapterStateFromBackingStates(callAdapter, chatAdapter) {
37186
37214
  isTeamsCall: callAdapterState.isTeamsCall,
37187
37215
  latestCallErrors: callAdapterState.latestErrors,
37188
37216
  latestChatErrors: chatAdapterState.latestErrors,
37189
- /* @conditional-compile-remove(file-sharing) */
37217
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
37190
37218
  fileUploads: chatAdapterState.fileUploads,
37191
37219
  /* @conditional-compile-remove(PSTN-calls) */
37192
37220
  alternateCallerId: callAdapterState.alternateCallerId,
@@ -37207,7 +37235,7 @@ function callWithChatAdapterStateFromBackingStates(callAdapter, chatAdapter) {
37207
37235
  */
37208
37236
  function mergeChatAdapterStateIntoCallWithChatAdapterState(existingCallWithChatAdapterState, chatAdapterState) {
37209
37237
  return Object.assign(Object.assign({}, existingCallWithChatAdapterState), { chat: chatAdapterState.thread, latestChatErrors: chatAdapterState.latestErrors,
37210
- /* @conditional-compile-remove(file-sharing) */
37238
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
37211
37239
  fileUploads: chatAdapterState.fileUploads });
37212
37240
  }
37213
37241
  /**
@@ -37288,31 +37316,31 @@ class CallWithChatContext {
37288
37316
  */
37289
37317
  class AzureCommunicationCallWithChatAdapter {
37290
37318
  constructor(callAdapter, chatAdapter) {
37291
- /* @conditional-compile-remove(file-sharing) */
37319
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
37292
37320
  this.registerActiveFileUploads = (files) => {
37293
37321
  return this.chatAdapter.registerActiveFileUploads(files);
37294
37322
  };
37295
- /* @conditional-compile-remove(file-sharing) */
37323
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
37296
37324
  this.registerCompletedFileUploads = (metadata) => {
37297
37325
  return this.chatAdapter.registerCompletedFileUploads(metadata);
37298
37326
  };
37299
- /* @conditional-compile-remove(file-sharing) */
37327
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
37300
37328
  this.clearFileUploads = () => {
37301
37329
  this.chatAdapter.clearFileUploads();
37302
37330
  };
37303
- /* @conditional-compile-remove(file-sharing) */
37331
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
37304
37332
  this.cancelFileUpload = (id) => {
37305
37333
  this.chatAdapter.cancelFileUpload(id);
37306
37334
  };
37307
- /* @conditional-compile-remove(file-sharing) */
37335
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
37308
37336
  this.updateFileUploadProgress = (id, progress) => {
37309
37337
  this.chatAdapter.updateFileUploadProgress(id, progress);
37310
37338
  };
37311
- /* @conditional-compile-remove(file-sharing) */
37339
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
37312
37340
  this.updateFileUploadErrorMessage = (id, errorMessage) => {
37313
37341
  this.chatAdapter.updateFileUploadErrorMessage(id, errorMessage);
37314
37342
  };
37315
- /* @conditional-compile-remove(file-sharing) */
37343
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
37316
37344
  this.updateFileUploadMetadata = (id, metadata) => {
37317
37345
  this.chatAdapter.updateFileUploadMetadata(id, metadata);
37318
37346
  };
@@ -37369,19 +37397,19 @@ class AzureCommunicationCallWithChatAdapter {
37369
37397
  this.deleteMessage.bind(this);
37370
37398
  this.on.bind(this);
37371
37399
  this.off.bind(this);
37372
- /* @conditional-compile-remove(file-sharing) */
37400
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
37373
37401
  this.registerActiveFileUploads = this.registerActiveFileUploads.bind(this);
37374
- /* @conditional-compile-remove(file-sharing) */
37402
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
37375
37403
  this.registerCompletedFileUploads = this.registerCompletedFileUploads.bind(this);
37376
- /* @conditional-compile-remove(file-sharing) */
37404
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
37377
37405
  this.clearFileUploads = this.clearFileUploads.bind(this);
37378
- /* @conditional-compile-remove(file-sharing) */
37406
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
37379
37407
  this.cancelFileUpload = this.cancelFileUpload.bind(this);
37380
- /* @conditional-compile-remove(file-sharing) */
37408
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
37381
37409
  this.updateFileUploadProgress = this.updateFileUploadProgress.bind(this);
37382
- /* @conditional-compile-remove(file-sharing) */
37410
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
37383
37411
  this.updateFileUploadErrorMessage = this.updateFileUploadErrorMessage.bind(this);
37384
- /* @conditional-compile-remove(file-sharing) */
37412
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
37385
37413
  this.updateFileUploadMetadata = this.updateFileUploadMetadata.bind(this);
37386
37414
  this.downloadResourceToCache = this.downloadResourceToCache.bind(this);
37387
37415
  this.removeResourceFromCache = this.removeResourceFromCache.bind(this);
@@ -37624,7 +37652,7 @@ class AzureCommunicationCallWithChatAdapter {
37624
37652
  updateMessage(messageId, content, metadata, options) {
37625
37653
  return __awaiter$2(this, void 0, void 0, function* () {
37626
37654
  return yield this.chatAdapter.updateMessage(messageId, content, metadata,
37627
- /* @conditional-compile-remove(file-sharing) */ options);
37655
+ /* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */ options);
37628
37656
  });
37629
37657
  }
37630
37658
  /** Delete an existing message. */
@@ -38611,4 +38639,4 @@ exports.useTeamsCall = useTeamsCall;
38611
38639
  exports.useTeamsCallAdapter = useTeamsCallAdapter;
38612
38640
  exports.useTeamsCallAgent = useTeamsCallAgent;
38613
38641
  exports.useTheme = useTheme;
38614
- //# sourceMappingURL=index-Ba2HAv_Y.js.map
38642
+ //# sourceMappingURL=index-BEomNZbT.js.map