2021-08-27 16:29:34 +00:00
|
|
|
import React, { useContext } from 'react';
|
2021-02-26 16:01:45 +00:00
|
|
|
import { dequal } from 'dequal';
|
2019-05-20 20:43:50 +00:00
|
|
|
import PropTypes from 'prop-types';
|
2021-08-27 16:29:34 +00:00
|
|
|
import { Text } from 'react-native';
|
2019-05-20 20:43:50 +00:00
|
|
|
|
|
|
|
import Image from './Image';
|
|
|
|
import Audio from './Audio';
|
|
|
|
import Video from './Video';
|
|
|
|
import Reply from './Reply';
|
2021-08-27 16:29:34 +00:00
|
|
|
import Button from '../Button';
|
|
|
|
import styles from './styles';
|
|
|
|
import MessageContext from './Context';
|
|
|
|
|
|
|
|
const AttachedActions = ({
|
|
|
|
attachment, theme
|
|
|
|
}) => {
|
|
|
|
const { onAnswerButtonPress } = useContext(MessageContext);
|
|
|
|
|
|
|
|
const attachedButtons = attachment.actions.map((element) => {
|
|
|
|
if (element.type === 'button') {
|
|
|
|
return <Button theme={theme} onPress={() => onAnswerButtonPress(element.msg)} title={element.text} />;
|
|
|
|
} else {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
return (
|
|
|
|
<>
|
|
|
|
<Text style={styles.text}>{attachment.text}</Text>
|
|
|
|
{attachedButtons}
|
|
|
|
</>
|
|
|
|
);
|
|
|
|
};
|
2019-05-20 20:43:50 +00:00
|
|
|
|
|
|
|
const Attachments = React.memo(({
|
2020-04-30 20:05:59 +00:00
|
|
|
attachments, timeFormat, showAttachment, getCustomEmoji, theme
|
2019-05-20 20:43:50 +00:00
|
|
|
}) => {
|
|
|
|
if (!attachments || attachments.length === 0) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
return attachments.map((file, index) => {
|
2021-04-05 17:36:04 +00:00
|
|
|
if (file.image_url) {
|
2020-04-30 20:05:59 +00:00
|
|
|
return <Image key={file.image_url} file={file} showAttachment={showAttachment} getCustomEmoji={getCustomEmoji} theme={theme} />;
|
2019-05-20 20:43:50 +00:00
|
|
|
}
|
2021-04-05 17:36:04 +00:00
|
|
|
if (file.audio_url) {
|
2020-04-30 20:05:59 +00:00
|
|
|
return <Audio key={file.audio_url} file={file} getCustomEmoji={getCustomEmoji} theme={theme} />;
|
2019-05-20 20:43:50 +00:00
|
|
|
}
|
2021-04-05 17:36:04 +00:00
|
|
|
if (file.video_url) {
|
2020-04-30 20:05:59 +00:00
|
|
|
return <Video key={file.video_url} file={file} showAttachment={showAttachment} getCustomEmoji={getCustomEmoji} theme={theme} />;
|
2019-05-20 20:43:50 +00:00
|
|
|
}
|
2021-08-27 16:29:34 +00:00
|
|
|
if (file.actions && file.actions.length > 0) {
|
|
|
|
return <AttachedActions attachment={file} theme={theme} />;
|
|
|
|
}
|
2019-05-20 20:43:50 +00:00
|
|
|
|
|
|
|
// eslint-disable-next-line react/no-array-index-key
|
2020-04-30 20:05:59 +00:00
|
|
|
return <Reply key={index} index={index} attachment={file} timeFormat={timeFormat} getCustomEmoji={getCustomEmoji} theme={theme} />;
|
2019-05-20 20:43:50 +00:00
|
|
|
});
|
2021-02-26 16:01:45 +00:00
|
|
|
}, (prevProps, nextProps) => dequal(prevProps.attachments, nextProps.attachments) && prevProps.theme === nextProps.theme);
|
2019-05-20 20:43:50 +00:00
|
|
|
|
|
|
|
Attachments.propTypes = {
|
|
|
|
attachments: PropTypes.array,
|
|
|
|
timeFormat: PropTypes.string,
|
2019-12-18 21:13:11 +00:00
|
|
|
showAttachment: PropTypes.func,
|
2019-12-04 16:39:53 +00:00
|
|
|
getCustomEmoji: PropTypes.func,
|
|
|
|
theme: PropTypes.string
|
2019-05-20 20:43:50 +00:00
|
|
|
};
|
|
|
|
Attachments.displayName = 'MessageAttachments';
|
2021-08-27 16:29:34 +00:00
|
|
|
AttachedActions.propTypes = {
|
|
|
|
attachment: PropTypes.shape({
|
|
|
|
actions: PropTypes.array,
|
|
|
|
text: PropTypes.string
|
|
|
|
}),
|
|
|
|
theme: PropTypes.string
|
|
|
|
};
|
2019-05-20 20:43:50 +00:00
|
|
|
|
|
|
|
export default Attachments;
|