@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.
- package/dist/communication-react.d.ts +1 -1
- package/dist/dist-cjs/communication-react/{RichTextSendBoxWrapper-BRqOsupu.js → RichTextSendBoxWrapper-Yty3fOoA.js} +6 -6
- package/dist/dist-cjs/communication-react/{RichTextSendBoxWrapper-BRqOsupu.js.map → RichTextSendBoxWrapper-Yty3fOoA.js.map} +1 -1
- package/dist/dist-cjs/communication-react/{index-Ba2HAv_Y.js → index-BEomNZbT.js} +675 -647
- package/dist/dist-cjs/communication-react/index-BEomNZbT.js.map +1 -0
- package/dist/dist-cjs/communication-react/index.js +3 -3
- package/dist/dist-esm/acs-ui-common/src/telemetryVersion.js +1 -1
- package/dist/dist-esm/acs-ui-common/src/telemetryVersion.js.map +1 -1
- package/dist/dist-esm/chat-component-bindings/src/handlers/createHandlers.js.map +1 -1
- package/dist/dist-esm/chat-component-bindings/src/messageThreadSelector.js +6 -6
- package/dist/dist-esm/chat-component-bindings/src/messageThreadSelector.js.map +1 -1
- package/dist/dist-esm/communication-react/src/index.js.map +1 -1
- package/dist/dist-esm/react-components/src/components/AttachmentCard.d.ts +3 -1
- package/dist/dist-esm/react-components/src/components/AttachmentCard.js +75 -59
- package/dist/dist-esm/react-components/src/components/AttachmentCard.js.map +1 -1
- package/dist/dist-esm/react-components/src/components/AttachmentDownloadCards.d.ts +1 -1
- package/dist/dist-esm/react-components/src/components/AttachmentDownloadCards.js +11 -10
- package/dist/dist-esm/react-components/src/components/AttachmentDownloadCards.js.map +1 -1
- package/dist/dist-esm/react-components/src/components/AttachmentUploadCards.js +2 -12
- package/dist/dist-esm/react-components/src/components/AttachmentUploadCards.js.map +1 -1
- package/dist/dist-esm/react-components/src/components/ChatMessage/ChatMessageComponentAsEditBox.js +8 -8
- package/dist/dist-esm/react-components/src/components/ChatMessage/ChatMessageComponentAsEditBox.js.map +1 -1
- package/dist/dist-esm/react-components/src/components/ChatMessage/ChatMessageComponentAsRichTextEditBox.js +5 -5
- package/dist/dist-esm/react-components/src/components/ChatMessage/ChatMessageComponentAsRichTextEditBox.js.map +1 -1
- package/dist/dist-esm/react-components/src/components/ChatMessage/ChatMessageComponentWrapper.js.map +1 -1
- package/dist/dist-esm/react-components/src/components/ChatMessage/MessageComponents/ChatMessageComponentAsMessageBubble.js +6 -6
- package/dist/dist-esm/react-components/src/components/ChatMessage/MessageComponents/ChatMessageComponentAsMessageBubble.js.map +1 -1
- package/dist/dist-esm/react-components/src/components/ChatMessage/MessageComponents/FluentChatMessageComponent.js +10 -8
- package/dist/dist-esm/react-components/src/components/ChatMessage/MessageComponents/FluentChatMessageComponent.js.map +1 -1
- package/dist/dist-esm/react-components/src/components/ChatMessage/MyMessageComponents/ChatMyMessageComponentAsMessageBubble.js +6 -6
- package/dist/dist-esm/react-components/src/components/ChatMessage/MyMessageComponents/ChatMyMessageComponentAsMessageBubble.js.map +1 -1
- package/dist/dist-esm/react-components/src/components/ChatMessage/MyMessageComponents/FluentChatMyMessageComponent.js +10 -8
- package/dist/dist-esm/react-components/src/components/ChatMessage/MyMessageComponents/FluentChatMyMessageComponent.js.map +1 -1
- package/dist/dist-esm/react-components/src/components/MessageThread.js +3 -3
- package/dist/dist-esm/react-components/src/components/MessageThread.js.map +1 -1
- package/dist/dist-esm/react-components/src/components/RichTextEditor/RichTextInputBoxComponent.js +7 -6
- package/dist/dist-esm/react-components/src/components/RichTextEditor/RichTextInputBoxComponent.js.map +1 -1
- package/dist/dist-esm/react-components/src/components/RichTextEditor/RichTextSendBox.js +24 -24
- package/dist/dist-esm/react-components/src/components/RichTextEditor/RichTextSendBox.js.map +1 -1
- package/dist/dist-esm/react-components/src/components/RichTextEditor/RichTextSendBoxErrors.js +6 -6
- package/dist/dist-esm/react-components/src/components/RichTextEditor/RichTextSendBoxErrors.js.map +1 -1
- package/dist/dist-esm/react-components/src/components/SendBox.js +33 -23
- package/dist/dist-esm/react-components/src/components/SendBox.js.map +1 -1
- package/dist/dist-esm/react-components/src/components/index.js.map +1 -1
- package/dist/dist-esm/react-components/src/components/styles/AttachmentCard.styles.d.ts +9 -0
- package/dist/dist-esm/react-components/src/components/styles/AttachmentCard.styles.js +27 -0
- package/dist/dist-esm/react-components/src/components/styles/AttachmentCard.styles.js.map +1 -0
- package/dist/dist-esm/react-components/src/components/styles/SendBox.styles.js +3 -2
- package/dist/dist-esm/react-components/src/components/styles/SendBox.styles.js.map +1 -1
- package/dist/dist-esm/react-components/src/components/utils/ChatMessageComponentAsEditBoxUtils.js +6 -5
- package/dist/dist-esm/react-components/src/components/utils/ChatMessageComponentAsEditBoxUtils.js.map +1 -1
- package/dist/dist-esm/react-components/src/components/utils/ChatMessageComponentUtils.js +10 -10
- package/dist/dist-esm/react-components/src/components/utils/ChatMessageComponentUtils.js.map +1 -1
- package/dist/dist-esm/react-components/src/components/utils/SendBoxUtils.js +2 -2
- package/dist/dist-esm/react-components/src/components/utils/SendBoxUtils.js.map +1 -1
- package/dist/dist-esm/react-components/src/components/utils/common.js +2 -2
- package/dist/dist-esm/react-components/src/components/utils/common.js.map +1 -1
- package/dist/dist-esm/react-components/src/theming/FluentV9ThemeProvider.js +1 -1
- package/dist/dist-esm/react-components/src/theming/FluentV9ThemeProvider.js.map +1 -1
- package/dist/dist-esm/react-components/src/theming/icons.js +3 -3
- package/dist/dist-esm/react-components/src/theming/icons.js.map +1 -1
- package/dist/dist-esm/react-components/src/types/Attachment.d.ts +9 -0
- package/dist/dist-esm/react-components/src/types/Attachment.js.map +1 -1
- package/dist/dist-esm/react-components/src/types/ChatMessage.js.map +1 -1
- package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/CallWithChatComposite.js +3 -3
- package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/CallWithChatComposite.js.map +1 -1
- package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/AzureCommunicationCallWithChatAdapter.js +15 -15
- package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/AzureCommunicationCallWithChatAdapter.js.map +1 -1
- package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/CallWithChatAdapter.js.map +1 -1
- package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/CallWithChatBackedChatAdapter.js +8 -8
- package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/CallWithChatBackedChatAdapter.js.map +1 -1
- package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/state/CallWithChatAdapterState.js +2 -2
- package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/state/CallWithChatAdapterState.js.map +1 -1
- package/dist/dist-esm/react-composites/src/composites/ChatComposite/ChatComposite.js +4 -4
- package/dist/dist-esm/react-composites/src/composites/ChatComposite/ChatComposite.js.map +1 -1
- package/dist/dist-esm/react-composites/src/composites/ChatComposite/ChatScreen.js +8 -8
- package/dist/dist-esm/react-composites/src/composites/ChatComposite/ChatScreen.js.map +1 -1
- package/dist/dist-esm/react-composites/src/composites/ChatComposite/Strings.js.map +1 -1
- package/dist/dist-esm/react-composites/src/composites/ChatComposite/adapter/AzureCommunicationChatAdapter.js +22 -22
- package/dist/dist-esm/react-composites/src/composites/ChatComposite/adapter/AzureCommunicationChatAdapter.js.map +1 -1
- package/dist/dist-esm/react-composites/src/composites/ChatComposite/adapter/AzureCommunicationFileUploadAdapter.js +6 -6
- package/dist/dist-esm/react-composites/src/composites/ChatComposite/adapter/AzureCommunicationFileUploadAdapter.js.map +1 -1
- package/dist/dist-esm/react-composites/src/composites/ChatComposite/adapter/ChatAdapter.js.map +1 -1
- package/dist/dist-esm/react-composites/src/composites/ChatComposite/adapter/ChatAdapterProvider.js +1 -1
- package/dist/dist-esm/react-composites/src/composites/ChatComposite/adapter/ChatAdapterProvider.js.map +1 -1
- package/dist/dist-esm/react-composites/src/composites/ChatComposite/file-sharing/FileUploadButton.js +4 -4
- package/dist/dist-esm/react-composites/src/composites/ChatComposite/file-sharing/FileUploadButton.js.map +1 -1
- package/dist/dist-esm/react-composites/src/composites/ChatComposite/hooks/useHandlers.js +3 -3
- package/dist/dist-esm/react-composites/src/composites/ChatComposite/hooks/useHandlers.js.map +1 -1
- package/dist/dist-esm/react-composites/src/composites/ChatComposite/index.js.map +1 -1
- package/dist/dist-esm/react-composites/src/composites/ChatComposite/selectors/baseSelectors.js +1 -1
- package/dist/dist-esm/react-composites/src/composites/ChatComposite/selectors/baseSelectors.js.map +1 -1
- package/dist/dist-esm/react-composites/src/composites/common/SendBox.js +8 -8
- package/dist/dist-esm/react-composites/src/composites/common/SendBox.js.map +1 -1
- package/dist/dist-esm/react-composites/src/composites/common/icons.js +2 -2
- package/dist/dist-esm/react-composites/src/composites/common/icons.js.map +1 -1
- package/package.json +1 -1
- package/dist/dist-cjs/communication-react/index-Ba2HAv_Y.js.map +0 -1
- package/dist/dist-esm/react-components/src/components/styles/IconButton.styles.d.ts +0 -5
- package/dist/dist-esm/react-components/src/components/styles/IconButton.styles.js +0 -17
- 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-
|
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(
|
6358
|
-
const hasNoContent = !hasText &&
|
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(
|
6703
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
6703
6704
|
CancelFileUpload: React.createElement(reactIcons.Dismiss16Regular, null),
|
6704
|
-
/* @conditional-compile-remove(
|
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(
|
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(
|
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
|
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
|
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(
|
8829
|
-
|
8830
|
-
|
8831
|
-
|
8832
|
-
|
8833
|
-
|
8834
|
-
React.createElement(
|
8835
|
-
|
8836
|
-
|
8837
|
-
|
8838
|
-
|
8839
|
-
|
8840
|
-
|
8841
|
-
|
8842
|
-
|
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.
|
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(
|
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(
|
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(
|
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(
|
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(
|
9366
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
8994
9367
|
setAttachmentUploadsPendingError(undefined);
|
8995
|
-
/* @conditional-compile-remove(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
9058
|
-
|
9059
|
-
|
9060
|
-
|
9061
|
-
|
9062
|
-
|
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
|
-
) },
|
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(
|
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(
|
10046
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
9666
10047
|
onRenderFileUploads,
|
9667
|
-
/* @conditional-compile-remove(
|
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(
|
10087
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */ !hasFiles);
|
9707
10088
|
}, [
|
9708
10089
|
isHorizontalLayoutDisabled,
|
9709
10090
|
showRichTextEditorFormatting,
|
9710
|
-
/* @conditional-compile-remove(
|
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 })),
|
9720
|
-
|
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(
|
10113
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
9732
10114
|
attachmentUploadError,
|
9733
|
-
/* @conditional-compile-remove(
|
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(
|
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(
|
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(
|
9775
|
-
/* @conditional-compile-remove(
|
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(
|
10181
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
9800
10182
|
activeFileUploads,
|
9801
|
-
/* @conditional-compile-remove(
|
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(
|
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(
|
10213
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
9832
10214
|
setFileUploadsPendingError(undefined);
|
9833
|
-
/* @conditional-compile-remove(
|
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(
|
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(
|
9854
|
-
/* @conditional-compile-remove(
|
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(
|
10242
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
9861
10243
|
!!attachmentUploadsPendingError ||
|
9862
|
-
/* @conditional-compile-remove(
|
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(
|
10247
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
9866
10248
|
activeFileUploads,
|
9867
10249
|
contentTooLongMessage,
|
9868
|
-
/* @conditional-compile-remove(
|
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(
|
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(
|
10266
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
9885
10267
|
attachmentUploadsPendingError: attachmentUploadsPendingError,
|
9886
|
-
/* @conditional-compile-remove(
|
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(
|
10274
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
9893
10275
|
activeFileUploads,
|
9894
10276
|
contentTooLongMessage,
|
9895
|
-
/* @conditional-compile-remove(
|
10277
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
9896
10278
|
attachmentUploadsPendingError,
|
9897
10279
|
systemMessage
|
9898
10280
|
]);
|
9899
|
-
/* @conditional-compile-remove(
|
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(
|
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(
|
10303
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
9922
10304
|
onRenderFileUploads: onRenderFileUploads,
|
9923
|
-
/* @conditional-compile-remove(
|
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(
|
10795
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
10414
10796
|
attachmentMetadata) {
|
10415
|
-
/* @conditional-compile-remove(
|
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(
|
10423
|
-
return isMessageEmpty(messageText,
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
11317
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */ {
|
11292
11318
|
attachmentMetadata
|
11293
11319
|
});
|
11294
11320
|
e.stopPropagation();
|
11295
|
-
}, id: 'submitIconWrapper' }))),
|
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(
|
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(
|
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(
|
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(
|
11713
|
-
return React.createElement(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
11860
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
11837
11861
|
const defaultOnRenderFileDownloads = (userId, message, strings,
|
11838
|
-
/* @conditional-compile-remove(
|
11862
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
11839
11863
|
fileDownloadHandler) => {
|
11840
|
-
/* @conditional-compile-remove(
|
11864
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
11841
11865
|
return (React.createElement(_AttachmentDownloadCards, { userId: userId,
|
11842
|
-
/* @conditional-compile-remove(
|
11866
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
11843
11867
|
fileMetadata: message.files || [],
|
11844
|
-
/* @conditional-compile-remove(
|
11868
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
11845
11869
|
downloadHandler: fileDownloadHandler,
|
11846
|
-
/* @conditional-compile-remove(
|
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(
|
11914
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
11891
11915
|
fileDownloadHandler, inlineImageOptions,
|
11892
|
-
/* @conditional-compile-remove(
|
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(
|
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(
|
11976
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
11953
11977
|
fileDownloadHandler);
|
11954
11978
|
}, [
|
11955
|
-
/* @conditional-compile-remove(
|
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(
|
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(
|
12122
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
12099
12123
|
fileDownloadHandler, userId,
|
12100
|
-
/* @conditional-compile-remove(
|
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(
|
12128
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
12105
12129
|
return onRenderFileDownloads;
|
12106
|
-
}, [
|
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(
|
12139
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
12114
12140
|
onRenderFileDownloads: onRenderFileDownloadsMemo,
|
12115
|
-
/* @conditional-compile-remove(
|
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(
|
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(
|
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(
|
12230
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
12205
12231
|
fileDownloadHandler, inlineImageOptions, shouldOverlapAvatarAndMessage,
|
12206
|
-
/* @conditional-compile-remove(
|
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(
|
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(
|
12254
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
12229
12255
|
fileDownloadHandler);
|
12230
12256
|
}, [
|
12231
|
-
/* @conditional-compile-remove(
|
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(
|
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(
|
12311
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
12286
12312
|
fileDownloadHandler, userId,
|
12287
|
-
/* @conditional-compile-remove(
|
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(
|
12319
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
12294
12320
|
return onRenderFileDownloads;
|
12295
|
-
}, [
|
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(
|
12330
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
12303
12331
|
onRenderFileDownloads: onRenderFileDownloadsMemo,
|
12304
|
-
/* @conditional-compile-remove(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
24846
|
-
/* @conditional-compile-remove(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
25137
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
25110
25138
|
this.registerActiveFileUploads = this.registerActiveFileUploads.bind(this);
|
25111
|
-
/* @conditional-compile-remove(
|
25139
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
25112
25140
|
this.registerCompletedFileUploads = this.registerCompletedFileUploads.bind(this);
|
25113
|
-
/* @conditional-compile-remove(
|
25141
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
25114
25142
|
this.clearFileUploads = this.clearFileUploads.bind(this);
|
25115
|
-
/* @conditional-compile-remove(
|
25143
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
25116
25144
|
this.cancelFileUpload = this.cancelFileUpload.bind(this);
|
25117
|
-
/* @conditional-compile-remove(
|
25145
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
25118
25146
|
this.updateFileUploadProgress = this.updateFileUploadProgress.bind(this);
|
25119
|
-
/* @conditional-compile-remove(
|
25147
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
25120
25148
|
this.updateFileUploadErrorMessage = this.updateFileUploadErrorMessage.bind(this);
|
25121
|
-
/* @conditional-compile-remove(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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-
|
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(
|
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(
|
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(
|
26271
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
26244
26272
|
activeFileUploads: activeFileUploads,
|
26245
|
-
/* @conditional-compile-remove(
|
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(
|
26251
|
-
/* @conditional-compile-remove(
|
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(
|
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(
|
26369
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
26342
26370
|
const fileUploads = adapter.registerActiveFileUploads(Array.from(files));
|
26343
|
-
/* @conditional-compile-remove(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
26523
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
26496
26524
|
, {
|
26497
|
-
/* @conditional-compile-remove(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
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(
|
37400
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
37373
37401
|
this.registerActiveFileUploads = this.registerActiveFileUploads.bind(this);
|
37374
|
-
/* @conditional-compile-remove(
|
37402
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
37375
37403
|
this.registerCompletedFileUploads = this.registerCompletedFileUploads.bind(this);
|
37376
|
-
/* @conditional-compile-remove(
|
37404
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
37377
37405
|
this.clearFileUploads = this.clearFileUploads.bind(this);
|
37378
|
-
/* @conditional-compile-remove(
|
37406
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
37379
37407
|
this.cancelFileUpload = this.cancelFileUpload.bind(this);
|
37380
|
-
/* @conditional-compile-remove(
|
37408
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
37381
37409
|
this.updateFileUploadProgress = this.updateFileUploadProgress.bind(this);
|
37382
|
-
/* @conditional-compile-remove(
|
37410
|
+
/* @conditional-compile-remove(attachment-download) @conditional-compile-remove(attachment-upload) */
|
37383
37411
|
this.updateFileUploadErrorMessage = this.updateFileUploadErrorMessage.bind(this);
|
37384
|
-
/* @conditional-compile-remove(
|
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(
|
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-
|
38642
|
+
//# sourceMappingURL=index-BEomNZbT.js.map
|