/* * Copyright © 2024 Hexastack. All rights reserved. * * Licensed under the GNU Affero General Public License v3.0 (AGPLv3) with the following additional terms: * 1. The name "Hexabot" is a trademark of Hexastack. You may not use this name in derivative works without express written permission. * 2. All derivative works must include clear attribution to the original creator and software, Hexastack and Hexabot, in a prominent location (e.g., in the software's "About" section, documentation, and README file). */ import React from "react"; import { useTranslation } from "../../hooks/useTranslation"; import { useColors } from "../../providers/ColorProvider"; import { Direction, TMessage } from "../../types/message.types"; import FileIcon from "../icons/FileIcon"; import "./FileMessage.scss"; interface FileMessageProps { message: TMessage; } const FileMessage: React.FC = ({ message }) => { const { t } = useTranslation(); const { colors: allColors } = useColors(); const colors = allColors[message.direction || Direction.received]; if (!("type" in message.data)) { throw new Error("Unable to detect type for file message"); } if ( message.data && message.data.type !== "image" && message.data.type !== "audio" && message.data.type !== "video" && message.data.type !== "file" ) { throw new Error("Uknown type for file message"); } return (
{message.data.type === "image" && (
File
)} {message.data.type === "audio" && (
)} {message.data.type === "video" && (
)} {message.data.type === "file" && (
{t("messages.file_message.download")}
)}
); }; export default FileMessage;