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,
};