From a6cd592141af607c7be9dd581a6180f94d28a7b6 Mon Sep 17 00:00:00 2001 From: Jeffrey Yu <35394596+JeffreytheCoder@users.noreply.github.com> Date: Fri, 8 Mar 2024 07:19:26 -0800 Subject: [PATCH] Add download function and file name to messages attachments (#489) * Add download function and file name to messages attachments * Fix linting errors --- .../Attachments/AttachmentMetadata.js | 39 +++++++++++++++++++ .../components/Attachments/AudioAttachment.js | 6 ++- .../components/Attachments/ImageAttachment.js | 6 ++- .../components/Attachments/VideoAttachment.js | 6 ++- .../src/components/Icon/icons/Download.js | 14 +++++++ .../react/src/components/Icon/icons/index.js | 2 + 6 files changed, 70 insertions(+), 3 deletions(-) create mode 100644 packages/react/src/components/Attachments/AttachmentMetadata.js create mode 100644 packages/react/src/components/Icon/icons/Download.js diff --git a/packages/react/src/components/Attachments/AttachmentMetadata.js b/packages/react/src/components/Attachments/AttachmentMetadata.js new file mode 100644 index 000000000..3e8aee462 --- /dev/null +++ b/packages/react/src/components/Attachments/AttachmentMetadata.js @@ -0,0 +1,39 @@ +import React from 'react'; +import { ActionButton } from '../ActionButton'; +import { Box } from '../Box'; + +const AttachmentMetadata = ({ attachment, url }) => { + const handleDownload = () => { + const anchor = document.createElement('a'); + anchor.href = url; + anchor.download = attachment.title; + + document.body.appendChild(anchor); + anchor.click(); + document.body.removeChild(anchor); + }; + + return ( + <> +

{attachment.description}

+ +

{attachment.title}

+ +
+ + ); +}; + +export default AttachmentMetadata; diff --git a/packages/react/src/components/Attachments/AudioAttachment.js b/packages/react/src/components/Attachments/AudioAttachment.js index f2349ce39..fe1da9406 100644 --- a/packages/react/src/components/Attachments/AudioAttachment.js +++ b/packages/react/src/components/Attachments/AudioAttachment.js @@ -1,10 +1,14 @@ import React from 'react'; import PropTypes from 'prop-types'; import { Box } from '../Box'; +import AttachmentMetadata from './AttachmentMetadata'; const AudioAttachment = ({ attachment, host }) => ( -

{attachment?.description}

+
); diff --git a/packages/react/src/components/Attachments/ImageAttachment.js b/packages/react/src/components/Attachments/ImageAttachment.js index e3a650be8..7d356ba92 100644 --- a/packages/react/src/components/Attachments/ImageAttachment.js +++ b/packages/react/src/components/Attachments/ImageAttachment.js @@ -1,10 +1,14 @@ import React from 'react'; import PropTypes from 'prop-types'; import { Box } from '../Box'; +import AttachmentMetadata from './AttachmentMetadata'; const ImageAttachment = ({ attachment, host }) => ( -

{attachment?.description}

+ ( -

{attachment?.description}

+ diff --git a/packages/react/src/components/Icon/icons/Download.js b/packages/react/src/components/Icon/icons/Download.js new file mode 100644 index 000000000..7127ed3e3 --- /dev/null +++ b/packages/react/src/components/Icon/icons/Download.js @@ -0,0 +1,14 @@ +import React from 'react'; + +const Download = (props) => ( + + + +); + +export default Download; diff --git a/packages/react/src/components/Icon/icons/index.js b/packages/react/src/components/Icon/icons/index.js index b66ac20cc..13cf98f97 100644 --- a/packages/react/src/components/Icon/icons/index.js +++ b/packages/react/src/components/Icon/icons/index.js @@ -39,6 +39,7 @@ import PinFilled from './PinFilled'; import VideoRecorder from './VideoRecoder'; import DisabledRecorder from './DisableRecorder'; import Clipboard from './Clipboard'; +import Download from './Download'; import At from './At'; const icons = { @@ -83,6 +84,7 @@ const icons = { 'arrow-down': ArrowDown, 'pin-filled': PinFilled, clipboard: Clipboard, + download: Download, at: At, };