2021-09-13 20:41:05 +00:00
|
|
|
import React, { useContext } from 'react';
|
|
|
|
import { dequal } from 'dequal';
|
|
|
|
|
2022-04-01 21:52:38 +00:00
|
|
|
import { IMessageAttachments } from './interfaces';
|
2021-09-13 20:41:05 +00:00
|
|
|
import Image from './Image';
|
|
|
|
import Audio from './Audio';
|
|
|
|
import Video from './Video';
|
|
|
|
import Reply from './Reply';
|
|
|
|
import Button from '../Button';
|
|
|
|
import MessageContext from './Context';
|
2022-03-21 20:44:06 +00:00
|
|
|
import { useTheme } from '../../theme';
|
2023-05-10 21:39:56 +00:00
|
|
|
import { IAttachment, TGetCustomEmoji } from '../../definitions';
|
2022-03-18 10:01:30 +00:00
|
|
|
import CollapsibleQuote from './Components/CollapsibleQuote';
|
2022-06-06 14:17:51 +00:00
|
|
|
import openLink from '../../lib/methods/helpers/openLink';
|
2023-05-10 21:39:56 +00:00
|
|
|
import Markdown from '../markdown';
|
2022-03-30 21:55:57 +00:00
|
|
|
|
|
|
|
export type TElement = {
|
|
|
|
type: string;
|
|
|
|
msg?: string;
|
|
|
|
url?: string;
|
|
|
|
text: string;
|
|
|
|
};
|
2021-09-13 20:41:05 +00:00
|
|
|
|
2023-05-10 21:39:56 +00:00
|
|
|
const AttachedActions = ({ attachment, getCustomEmoji }: { attachment: IAttachment; getCustomEmoji: TGetCustomEmoji }) => {
|
2022-04-11 18:01:43 +00:00
|
|
|
const { onAnswerButtonPress } = useContext(MessageContext);
|
|
|
|
|
2022-03-21 20:44:06 +00:00
|
|
|
if (!attachment.actions) {
|
|
|
|
return null;
|
|
|
|
}
|
2021-09-13 20:41:05 +00:00
|
|
|
|
2022-03-30 21:55:57 +00:00
|
|
|
const attachedButtons = attachment.actions.map((element: TElement) => {
|
|
|
|
const onPress = () => {
|
|
|
|
if (element.msg) {
|
|
|
|
onAnswerButtonPress(element.msg);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (element.url) {
|
|
|
|
openLink(element.url);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2021-09-13 20:41:05 +00:00
|
|
|
if (element.type === 'button') {
|
2022-05-20 16:37:57 +00:00
|
|
|
return <Button onPress={onPress} title={element.text} />;
|
2021-09-13 20:41:05 +00:00
|
|
|
}
|
2022-03-30 21:55:57 +00:00
|
|
|
|
2021-09-13 20:41:05 +00:00
|
|
|
return null;
|
|
|
|
});
|
|
|
|
return (
|
|
|
|
<>
|
2023-05-10 21:39:56 +00:00
|
|
|
<Markdown msg={attachment.text} getCustomEmoji={getCustomEmoji} />
|
2021-09-13 20:41:05 +00:00
|
|
|
{attachedButtons}
|
|
|
|
</>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
2022-04-01 21:52:38 +00:00
|
|
|
const Attachments: React.FC<IMessageAttachments> = React.memo(
|
2022-09-23 20:21:11 +00:00
|
|
|
({ attachments, timeFormat, showAttachment, style, getCustomEmoji, isReply, id }: IMessageAttachments) => {
|
2022-04-11 18:01:43 +00:00
|
|
|
const { theme } = useTheme();
|
|
|
|
|
2021-09-13 20:41:05 +00:00
|
|
|
if (!attachments || attachments.length === 0) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2022-04-01 21:52:38 +00:00
|
|
|
const attachmentsElements = attachments.map((file: IAttachment, index: number) => {
|
2022-03-21 20:44:06 +00:00
|
|
|
if (file && file.image_url) {
|
2021-09-13 20:41:05 +00:00
|
|
|
return (
|
2022-03-21 20:44:06 +00:00
|
|
|
<Image
|
|
|
|
key={file.image_url}
|
|
|
|
file={file}
|
|
|
|
showAttachment={showAttachment}
|
|
|
|
getCustomEmoji={getCustomEmoji}
|
|
|
|
style={style}
|
|
|
|
isReply={isReply}
|
|
|
|
/>
|
2021-09-13 20:41:05 +00:00
|
|
|
);
|
|
|
|
}
|
2022-03-21 20:44:06 +00:00
|
|
|
|
|
|
|
if (file && file.audio_url) {
|
|
|
|
return (
|
2022-09-23 20:21:11 +00:00
|
|
|
<Audio
|
|
|
|
key={file.audio_url}
|
|
|
|
file={file}
|
|
|
|
getCustomEmoji={getCustomEmoji}
|
|
|
|
isReply={isReply}
|
|
|
|
style={style}
|
|
|
|
theme={theme}
|
|
|
|
messageId={id}
|
|
|
|
/>
|
2022-03-21 20:44:06 +00:00
|
|
|
);
|
2021-09-13 20:41:05 +00:00
|
|
|
}
|
2022-03-21 20:44:06 +00:00
|
|
|
|
2021-09-13 20:41:05 +00:00
|
|
|
if (file.video_url) {
|
|
|
|
return (
|
2022-03-21 20:44:06 +00:00
|
|
|
<Video
|
|
|
|
key={file.video_url}
|
|
|
|
file={file}
|
|
|
|
showAttachment={showAttachment}
|
|
|
|
getCustomEmoji={getCustomEmoji}
|
|
|
|
style={style}
|
|
|
|
isReply={isReply}
|
|
|
|
/>
|
2021-09-13 20:41:05 +00:00
|
|
|
);
|
|
|
|
}
|
2022-03-21 20:44:06 +00:00
|
|
|
|
|
|
|
if (file && file.actions && file.actions.length > 0) {
|
2023-05-10 21:39:56 +00:00
|
|
|
return <AttachedActions attachment={file} getCustomEmoji={getCustomEmoji} />;
|
2021-09-13 20:41:05 +00:00
|
|
|
}
|
2022-03-28 15:08:18 +00:00
|
|
|
if (typeof file.collapsed === 'boolean') {
|
2022-03-18 10:01:30 +00:00
|
|
|
return (
|
|
|
|
<CollapsibleQuote key={index} index={index} attachment={file} timeFormat={timeFormat} getCustomEmoji={getCustomEmoji} />
|
|
|
|
);
|
2022-03-21 20:44:06 +00:00
|
|
|
}
|
2021-09-13 20:41:05 +00:00
|
|
|
|
2022-09-29 19:42:04 +00:00
|
|
|
return (
|
|
|
|
<Reply
|
|
|
|
key={index}
|
|
|
|
index={index}
|
|
|
|
attachment={file}
|
|
|
|
timeFormat={timeFormat}
|
|
|
|
getCustomEmoji={getCustomEmoji}
|
|
|
|
messageId={id}
|
|
|
|
/>
|
|
|
|
);
|
2021-09-13 20:41:05 +00:00
|
|
|
});
|
2022-04-01 21:52:38 +00:00
|
|
|
return <>{attachmentsElements}</>;
|
2021-09-13 20:41:05 +00:00
|
|
|
},
|
2022-03-21 20:44:06 +00:00
|
|
|
(prevProps, nextProps) => dequal(prevProps.attachments, nextProps.attachments)
|
2021-09-13 20:41:05 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
Attachments.displayName = 'MessageAttachments';
|
|
|
|
|
|
|
|
export default Attachments;
|