2021-07-05 11:23:23 +01:00
|
|
|
import {
|
2021-07-05 11:25:20 +01:00
|
|
|
Download,
|
|
|
|
LinkExternal,
|
|
|
|
File,
|
|
|
|
Headphone,
|
|
|
|
Video,
|
2021-07-05 11:23:23 +01:00
|
|
|
} from "@styled-icons/boxicons-regular";
|
2021-06-20 22:09:18 +01:00
|
|
|
import { Attachment } from "revolt.js/dist/api/objects";
|
2021-07-05 11:23:23 +01:00
|
|
|
|
|
|
|
import styles from "./Attachment.module.scss";
|
|
|
|
import classNames from "classnames";
|
|
|
|
import { useContext } from "preact/hooks";
|
|
|
|
|
|
|
|
import { determineFileSize } from "../../../../lib/fileSize";
|
|
|
|
|
|
|
|
import { AppContext } from "../../../../context/revoltjs/RevoltClient";
|
|
|
|
|
|
|
|
import IconButton from "../../../ui/IconButton";
|
2021-06-20 22:09:18 +01:00
|
|
|
|
|
|
|
interface Props {
|
2021-07-05 11:25:20 +01:00
|
|
|
attachment: Attachment;
|
2021-06-20 22:09:18 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
export default function AttachmentActions({ attachment }: Props) {
|
2021-07-05 11:25:20 +01:00
|
|
|
const client = useContext(AppContext);
|
|
|
|
const { filename, metadata, size } = attachment;
|
2021-06-20 22:09:18 +01:00
|
|
|
|
2021-07-05 11:25:20 +01:00
|
|
|
const url = client.generateFileURL(attachment)!;
|
|
|
|
const open_url = `${url}/${filename}`;
|
|
|
|
const download_url = url.replace("attachments", "attachments/download");
|
2021-06-20 22:09:18 +01:00
|
|
|
|
2021-07-05 11:25:20 +01:00
|
|
|
const filesize = determineFileSize(size);
|
2021-06-20 22:09:18 +01:00
|
|
|
|
2021-07-05 11:25:20 +01:00
|
|
|
switch (metadata.type) {
|
|
|
|
case "Image":
|
|
|
|
return (
|
|
|
|
<div className={classNames(styles.actions, styles.imageAction)}>
|
|
|
|
<span className={styles.filename}>{filename}</span>
|
|
|
|
<span className={styles.filesize}>
|
|
|
|
{metadata.width + "x" + metadata.height} ({filesize})
|
|
|
|
</span>
|
|
|
|
<a
|
|
|
|
href={open_url}
|
|
|
|
target="_blank"
|
|
|
|
className={styles.iconType}>
|
|
|
|
<IconButton>
|
|
|
|
<LinkExternal size={24} />
|
|
|
|
</IconButton>
|
|
|
|
</a>
|
|
|
|
<a
|
|
|
|
href={download_url}
|
|
|
|
className={styles.downloadIcon}
|
|
|
|
download
|
|
|
|
target="_blank">
|
|
|
|
<IconButton>
|
|
|
|
<Download size={24} />
|
|
|
|
</IconButton>
|
|
|
|
</a>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
case "Audio":
|
|
|
|
return (
|
|
|
|
<div className={classNames(styles.actions, styles.audioAction)}>
|
|
|
|
<Headphone size={24} className={styles.iconType} />
|
|
|
|
<span className={styles.filename}>{filename}</span>
|
|
|
|
<span className={styles.filesize}>{filesize}</span>
|
|
|
|
<a
|
|
|
|
href={download_url}
|
|
|
|
className={styles.downloadIcon}
|
|
|
|
download
|
|
|
|
target="_blank">
|
|
|
|
<IconButton>
|
|
|
|
<Download size={24} />
|
|
|
|
</IconButton>
|
|
|
|
</a>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
case "Video":
|
|
|
|
return (
|
|
|
|
<div className={classNames(styles.actions, styles.videoAction)}>
|
|
|
|
<Video size={24} className={styles.iconType} />
|
|
|
|
<span className={styles.filename}>{filename}</span>
|
|
|
|
<span className={styles.filesize}>
|
|
|
|
{metadata.width + "x" + metadata.height} ({filesize})
|
|
|
|
</span>
|
|
|
|
<a
|
|
|
|
href={download_url}
|
|
|
|
className={styles.downloadIcon}
|
|
|
|
download
|
|
|
|
target="_blank">
|
|
|
|
<IconButton>
|
|
|
|
<Download size={24} />
|
|
|
|
</IconButton>
|
|
|
|
</a>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
default:
|
|
|
|
return (
|
|
|
|
<div className={styles.actions}>
|
|
|
|
<File size={24} className={styles.iconType} />
|
|
|
|
<span className={styles.filename}>{filename}</span>
|
|
|
|
<span className={styles.filesize}>{filesize}</span>
|
|
|
|
<a
|
|
|
|
href={download_url}
|
|
|
|
className={styles.downloadIcon}
|
|
|
|
download
|
|
|
|
target="_blank">
|
|
|
|
<IconButton>
|
|
|
|
<Download size={24} />
|
|
|
|
</IconButton>
|
|
|
|
</a>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
2021-06-20 22:09:18 +01:00
|
|
|
}
|