/* ┌──────────────────────────────────────────────────────────────────────────────┐ │ @author: Davidson Gomes │ │ @file: /app/chat/components/AttachedFiles.tsx │ │ Developed by: Davidson Gomes │ │ Creation date: August 24, 2025 │ │ Contact: contato@evolution-api.com │ ├──────────────────────────────────────────────────────────────────────────────┤ │ @copyright © Evolution API 2025. All rights reserved. │ │ Licensed under the Apache License, Version 2.0 │ │ │ │ You may not use this file except in compliance with the License. │ │ You may obtain a copy of the License at │ │ │ │ http://www.apache.org/licenses/LICENSE-2.0 │ │ │ │ Unless required by applicable law or agreed to in writing, software │ │ distributed under the License is distributed on an "AS IS" BASIS, │ │ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. │ │ See the License for the specific language governing permissions and │ │ limitations under the License. │ ├──────────────────────────────────────────────────────────────────────────────┤ │ @important │ │ For any future changes to the code in this file, it is recommended to │ │ include, together with the modification, the information of the developer │ │ who changed it and the date of modification. │ └──────────────────────────────────────────────────────────────────────────────┘ */ "use client"; import React from "react"; import { formatFileSize, isImageFile } from "@/lib/file-utils"; import { File, FileText, Download, Image } from "lucide-react"; import { toast } from "@/hooks/use-toast"; interface AttachedFile { filename: string; content_type: string; data?: string; size?: number; preview_url?: string; } interface AttachedFilesProps { files: AttachedFile[]; className?: string; } export function AttachedFiles({ files, className = "" }: AttachedFilesProps) { if (!files || files.length === 0) return null; const downloadFile = (file: AttachedFile) => { if (!file.data) { toast({ title: "File without data for download", description: file.filename, }); return; } try { const link = document.createElement("a"); const dataUrl = file.data.startsWith("data:") ? file.data : `data:${file.content_type};base64,${file.data}`; link.href = dataUrl; link.download = file.filename; document.body.appendChild(link); link.click(); document.body.removeChild(link); } catch (error) { toast({ title: "Error downloading file", description: file.filename, }); } }; return (
Attached files:
{files .map((file, index) => { if (!file.data) { toast({ title: "File without data for display", description: file.filename, }); return null; } return (
{isImageFile(file.content_type) && file.data && (
{file.filename} { toast({ title: "Error loading image", description: file.filename, }); (e.target as HTMLImageElement).src = "data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNCIgaGVpZ2h0PSIyNCIgdmlld0JveD0iMCAwIDI0IDI0IiBmaWxsPSJub25lIiBzdHJva2U9IiNmZjY2NjYiIHN0cm9rZS13aWR0aD0iMiIgc3Ryb2tlLWxpbmVjYXA9InJvdW5kIiBzdHJva2UtbGluZWpvaW49InJvdW5kIiBjbGFzcz0ibHVjaWRlIGx1Y2lkZS1pbWFnZS1vZmYiPjxsaW5lIHgxPSIyIiB5MT0iMiIgeDI9IjIyIiB5Mj0iMjIiLz48PHJlY3QgdyA"; }} />
)}
{isImageFile(file.content_type) ? ( ) : file.content_type === "application/pdf" ? ( ) : ( )}
{file.filename}
{file.size && (
{formatFileSize(file.size)}
)}
{file.data && ( )}
); }) .filter(Boolean)}
); }